Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/21: Рейтинг темы: голосов - 21, средняя оценка - 4.76
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
.NET 4.x

Chart + datagridview

27.11.2015, 13:10. Показов 4581. Ответов 5

Студворк — интернет-сервис помощи студентам
Здравствуйте Дорогие Форумчани
Подскажите, как реализовать график в chart или zedgraph из значений в DataGridView
DataGridView получаем из Базы Данных MySql
Имее 4 таблицы : DataTime, Podacha, Vozvrat1, Vozvrat2, Vozvrat3
Строка DataTime должна показываться по оси Х как временная
а значения других строк по оси y строить график
Забираю значения в dataGridView
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
            dateTimePicker1.MinDate = new DateTime(2015, 10, 1);
            dateTimePicker1.MaxDate = DateTime.Now;
            dateTimePicker1.CustomFormat = "yyyy.MM.dd HH:mm:ss";
            dateTimePicker1.Format = DateTimePickerFormat.Custom;
            dateTimePicker1.Value.ToShortDateString();
            dateTimePicker2.MinDate = new DateTime(2015, 10, 1);
            dateTimePicker2.MaxDate = DateTime.Now;
            dateTimePicker2.CustomFormat = "yyyy.MM.dd HH:mm:ss";
            dateTimePicker2.Format = DateTimePickerFormat.Custom;
            dateTimePicker2.Value.ToShortDateString();
            string query = string.Format("Select * From Temperatura.Diet Where DataTime >= @DateStart And DataTime <= @DateFinish");
            MySqlConnection mcon = new MySqlConnection("datasource= localhost; port= 3306; User Id= root; password= 1234");
            using (MySqlCommand cmd = new MySqlCommand(query, mcon))
            {
                try
                {
                    mcon.Open();
                    cmd.Parameters.AddWithValue("@DateStart", dateTimePicker1.Value);
                    cmd.Parameters.AddWithValue("@DateFinish", dateTimePicker2.Value);
                    MySqlDataReader dr = cmd.ExecuteReader();
                    DataTable ds = new DataTable();
                    ds.Load(dr);
                    dataGridView1.DataSource = ds;
 
                }
                catch (MySqlException ex)
                {
                    MessageBox.Show(ex.Message, "Ошибка.", MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            }
После dataGridView1.DataSource = ds; пытаюсь ввести
сначала
C#
1
 chart1.DataSource = dataGridView1.DataSource;
результатов нет, нашёл другой способ в интернете, но он тоже особо не помогает
C#
1
2
3
4
5
6
7
8
9
10
var dataTime = dataGridView1.Rows[0].Cells[0].Value;
var Podacha = dataGridView1.Rows[0].Cells[1].Value;
var Vozvrat1 = dataGridView1.Rows[0].Cells[2].Value;
var Vozvrat2 = dataGridView1.Rows[0].Cells[3].Value;
var Vozvrat3 = dataGridView1.Rows[0].Cells[4].Value;
 
chart1.Series[0].Points.AddXY(Convert.ToString(dataTime),Convert.ToInt32(Podacha));
chart1.Series[0].Points.AddXY(Convert.ToString(dataTime),Convert.ToInt32(Vozvrat1));
chart1.Series[0].Points.AddXY(Convert.ToString(dataTime),Convert.ToInt32(Vozvrat2));
chart1.Series[0].Points.AddXY(Convert.ToString(dataTime),Convert.ToInt32(Vozvrat3));
Но он тоже не работает, точнее он работает, но я даже обьяснить как он работает не могу , больно странно он себя ведет. График делаю Line
Так вот дорогие форумчани, если кто-то делал графики такие подскажите как правильно или дайте кусок исходника -_-, а то я запутался окончательно.
Пробовал с zedGraph но там вообще беда (
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.11.2015, 13:10
Ответы с готовыми решениями:

Диаграмма Chart из DataGridView
Как сделать диаграмму с помощью Chart, используя данные из DataGridView?

Рисование графика в Chart по данным из DataGridView
Перелазил весь инет но так и не нашёл ответа. Есть datagridview и chart. Пользователь вводит данные в DataGridView и при нажатии на кнопку...

Построение графика chart с данными из dataGridView
Здравствуйте! Помогите решить проблему: есть dataGridView в который поступают данные из бд (но это к слову и не так важно), данные...

5
478 / 241 / 74
Регистрация: 25.05.2012
Сообщений: 1,138
Записей в блоге: 1
27.11.2015, 18:50
NightWar, вам не нужен DataGridView, чтобы построить график. И ZedGraph гораздо проще чем кажется.
1. Подключаете пространство имен
C#
1
using ZedGraph;
2. Извлекаете из базы точки, по которым хотите построить график, в виде DataTable с двумя столбцами

3. Ну а дальше как-то так:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
PointPairList list = new PointPairList();
for (int i = 0; i < dataTable.Rows.Count; i++)
    {
        double x = Convert.ToDouble(dataTable.Rows[i].ItemArray[0]);
        double y = Convert.ToDouble(dataTable.Rows[i].ItemArray[1]);
        list.Add(x, y);
    }
 
GraphPane mainPane = zedGraphControl1.GraphPane;
mainPane.CurveList.Clear();
LineItem Curve = mainPane.AddCurve("имя кривой", list, Color.Red, SymbolType.None);
zedGraphControl1.AxisChange();
zedGraphControl1.Invalidate();
Добавлено через 5 минут
NightWar, если ось Х - это время, то небольшие преобразования

C#
1
2
3
4
5
6
7
for (int i = 0; i < dataTable.Rows.Count; i++)
    {
        DateTime dt = Convert.ToDateTime(dataTable.Rows[i].ItemArray[0]);
        double x = (double)new XDate(dt.Year, dt.Month, dt.Day, dt.Hour, dt.Minute, dt.Second);
        double y = Convert.ToDouble(dataTable.Rows[i].ItemArray[1]);
        list.Add(x, y);
    }
и формат оси Х

C#
1
2
mainPane.XAxis.Scale.Format = "dd.MM.yyyy\n HH:mm:ss";
mainPane.XAxis.Type = AxisType.DateAsOrdinal;
1
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
28.11.2015, 07:19  [ТС]
NewOrdered, а можно по подробней Он не чего не хочет строить
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
                try
                {
                    mcon.Open();
                    cmd.Parameters.AddWithValue("@DateStart", dateTimePicker1.Value);
                    cmd.Parameters.AddWithValue("@DateFinish", dateTimePicker2.Value);
                    MySqlDataReader dr = cmd.ExecuteReader();
                    DataTable ds = new DataTable();
                    ds.Load(dr);
                    dataGridView1.DataSource = ds;
 
                    PointPairList list = new PointPairList();
                    for (int i = 0; i < ds.Rows.Count; i++)
                    {
                        DateTime dt = Convert.ToDateTime(ds.Rows[i].ItemArray[0]);
                        double x = (double)new XDate(dt.Year, dt.Month, dt.Day, dt.Hour, dt.Minute, dt.Second);
                        double y = Convert.ToDouble(ds.Rows[i].ItemArray[1]);
                        list.Add(x, y);
                    }
 
                    GraphPane mainPane = zedGraphControl1.GraphPane;
                    mainPane.CurveList.Clear();
                    LineItem Pod = mainPane.AddCurve("Подача", list, Color.Red, SymbolType.None);
                    LineItem Vozv1 = mainPane.AddCurve("Возврат 1", list, Color.Blue, SymbolType.None);
                    LineItem Vozv2 = mainPane.AddCurve("Возврат 2", list, Color.Yellow, SymbolType.None);
                    LineItem Vozv3 = mainPane.AddCurve("Возврат 3", list, Color.Green, SymbolType.None);
                    mainPane.XAxis.ScaleFormat = "yyyy.MM.dd HH:mm:ss";
                    mainPane.XAxis.Type = AxisType.Date;
                    zedGraphControl1.AxisChange();
                    zedGraphControl1.Invalidate();
 
                }
и почему только 1 обьект я так понимаю ложиться на ось У если у меня их 4
Больше всего не люблю строить графики
Если можно то совсем как для дебила расскажи

Добавлено через 20 минут
Я разобрался с интернетом не много получилось :
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
                    GraphPane mainPane = zedGraphControl1.GraphPane;
                    mainPane.CurveList.Clear();
                    PointPairList list = new PointPairList();
                    PointPairList list1 = new PointPairList();
                    PointPairList list2 = new PointPairList();
                    PointPairList list3 = new PointPairList();
 
                    for (int i = 0; i < ds.Rows.Count; i++)
                    {
                        DateTime dt = Convert.ToDateTime(ds.Rows[i].ItemArray[0]);
                        double x = (double)new XDate(dt.Year, dt.Month, dt.Day, dt.Hour, dt.Minute, dt.Second);
                        double y = Convert.ToDouble(ds.Rows[i].ItemArray[1]);
                        double y1 = Convert.ToDouble(ds.Rows[i].ItemArray[2]);
                        double y2 = Convert.ToDouble(ds.Rows[i].ItemArray[3]);
                        double y3 = Convert.ToDouble(ds.Rows[i].ItemArray[4]);
                        list.Add(x, y);
                        list1.Add(x, y1);
                        list2.Add(x, y2);
                        list3.Add(x, y3);
                    }
 
 
                    LineItem Pod = mainPane.AddCurve("Подача", list, Color.Red, SymbolType.None);
                    LineItem Vozv1 = mainPane.AddCurve("Возврат 1", list1, Color.Blue, SymbolType.None);
                    LineItem Vozv2 = mainPane.AddCurve("Возврат 2", list2, Color.Yellow, SymbolType.None);
                    LineItem Vozv3 = mainPane.AddCurve("Возврат 3", list3, Color.Green, SymbolType.None);
                    mainPane.XAxis.ScaleFontSpec.Size = 10;
                    mainPane.XAxis.Title = "Время";
                    mainPane.YAxis.Title = "Температура";
                    mainPane.Title = "Температура Цельномолочного цеха";
                    mainPane.XAxis.ScaleFormat = "yyyy.MM.dd HH:mm:ss";
                    mainPane.XAxis.Type = AxisType.Date;
                    zedGraphControl1.AxisChange();
                    zedGraphControl1.Invalidate();
Но вот как график сделать красивей?

Посмотри картинку пожалуйста, на ней начало оси почему-то не с угла а со средины, + заканчивается график не в конце + мне надо чтобы он по времени строил по минутно, а эта хрень строит по часам
ну и как сеточку влепить )
0
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
28.11.2015, 07:26  [ТС]
Картинка
Миниатюры
Chart + datagridview  
0
478 / 241 / 74
Регистрация: 25.05.2012
Сообщений: 1,138
Записей в блоге: 1
28.11.2015, 12:58
Лучший ответ Сообщение было отмечено NightWar как решение

Решение

Цитата Сообщение от NightWar Посмотреть сообщение
начало оси почему-то не с угла а со средины, + заканчивается график не в конце
Цитата Сообщение от NightWar Посмотреть сообщение
ну и как сеточку влепить
это все настраивается свойствами осей

Добавлено через 8 минут
http://jenyay.net/ZedGraph/DateAxis
1
6 / 6 / 3
Регистрация: 05.10.2015
Сообщений: 40
28.11.2015, 13:11  [ТС]
NewOrdered, Вот спасибо добрый человек ))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.11.2015, 13:11
Помогаю со студенческими работами здесь

Построение диаграммы chart с данными из dataGridView
Приветствую нужно создать диаграмму взятую из трех полей из Datagridview и подписать легенды название колонки Немножко поискал попробовал...

Создать диаграмму Chart из данных dataGridView
Здравствуйте. Подскажите как сделать диаграмму на основе двух столбцов из dataGridView. Тип диаграммы Column. Пробую вот так, но на экран...

Выбор строки из DataGridView по клику на график Chart
Добрый день! Есть DataGridView с данными (x и y). По этим данным строится график через компонент MS Chart. Нужно, чтобы по клику на...

Как установить для Chart чтобы он рисовался на основе строк DataGridView
Здравствуйте. Надеюсь кто-нибудь подскажет. На форме есть элемент Chart. Есть dataGridView. Как установить для Chart чтобы он рисовался на...

BindingSource. dataGridView. Как сделать независимый фильтр для двух dataGridView?
Из Access данные импортируются в dataGridView В качестве источника данных используется один и тот же файл Acs-dtgrDB2003.mdb Каждый...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru