Создать график с отдельными линиями для каждого дня недели? - PullRequest
0 голосов
/ 16 января 2012

У меня есть следующие данные в таблице базы данных, Столбцы : дата, час (от 1 до 24) и температура.

Я хочу создать линейную диаграмму, которая будет показывать по оси X часы от 1 до 24, а по оси Y - Температуры.

Теперь сложность заключается в том, что я хочу иметь разные цветные линии для каждой даты. Так что, если дата 2012-01-15, то у меня есть красная линия от 1 до 24, показывающая изменения температуры. если дата 2012-01-14, то синяя также от 1 до 24.

Для ясности я хочу, чтобы на одном графике было несколько дат.

Вот код, который у меня есть

        SqlConnection conn2 = new SqlConnection(@"connectionString");
        conn2.Open();

        SqlCommand cmd2 = new SqlCommand();
        cmd2.Connection = conn2;
        cmd2.CommandText = "SELECT * FROM observation WHERE day BETWEEN @fromDate AND @toDate ORDER BY day ASC, hour ASC ";
        cmd2.Parameters.AddWithValue("fromDate", dateTimePicker2.Value.Date);
        cmd2.Parameters.AddWithValue("toDate", dateTimePicker3.Value.Date);



        SqlDataReader reader = cmd2.ExecuteReader();
        DataSet ds = new DataSet();
        DataTable dt = new DataTable("dateRange");
        dt.Columns.Add("day");
        dt.Columns.Add("hour");
        dt.Columns.Add("temp");

        DataRow dr = dt.NewRow();
        int counter = 0;

        while (reader.Read())
        {
            if (reader[1].ToString() != dt.TableName)
            {
                if (dt.Rows.Count != 0 && dt.TableName != "dateRange")
                {
                    dt.AcceptChanges();
                    ds.Tables.Add(dt);
                    counter++;
                }
                dt = new DataTable(reader[1].ToString());
                dt.Columns.Add("day"):                    
                dt.Columns.Add("hour");
                dt.Columns.Add("temp");

            }
            dr = dt.NewRow();
            dr[0] = reader[2];
            dr[1] = reader[3];
            dt.Rows.Add(dr);
        }
        if (dt.Rows.Count != 0)
        {
            dt.AcceptChanges();
            ds.Tables.Add(dt);
        }
        else
        {
            lblError.Visible = false;
        }

        for (int i = 0; i < counter; i++)
        {
            chart1.Series[i].Name = i.ToString();
            chart1.Series[i].ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.Line;
            chart1.Series[i].BorderWidth = 5;
            if (i % 2 == 0)
            {
                chart1.Series[i].Color = Color.Red;
            }
            else
            {
                chart1.Series[i].Color = Color.Green;
            }

            chart1.DataSource = ds.Tables[i];
            chart1.Series[i].XValueMember = "hour";
            chart1.Series[i].YValueMembers = "temp";
        }

        chart1.Legends[0].Alignment = StringAlignment.Center;
        chart1.Legends[0].Docking = System.Windows.Forms.DataVisualization.Charting.Docking.Top;

        chart1.DataBind();
        chart1.Visible = true;

        cmd2.Connection.Close();

Спасибо!

Ответы [ 3 ]

1 голос
/ 16 января 2012

Решение, которое я нашел, состояло в том, чтобы переформатировать мой источник данных.Я создал DataTable с первым столбцом «Часы», который переходит от 1 до 24. Следующие столбцы по одному для каждого дня, который я хочу представить.

Есть два запроса.Первый - узнать, сколько дней в интервале, и создать соответствующее количество столбцов и рядов.Второй запрос - это тот, который вводит все данные.

Вот код:

        SqlConnection conn = new SqlConnection(connectionString);

        SqlCommand cmd = new SqlCommand();
        cmd.Connection = conn;
        cmd.CommandText = "SELECT day FROM observation WHERE day BETWEEN @from AND @to GROUP BY day";
        cmd.Parameters.AddWithValue("from", Convert.ToDateTime(dateFrom));
        cmd.Parameters.AddWithValue("to", Convert.ToDateTime(dateTo));
        cmd.Connection.Open();

        SqlDataReader rdr = cmd.ExecuteReader();

        DataTable dt = new DataTable("DATA");
        dt.Columns.Add("Hour");

        int days = 0;
        chart1.DataSource = dt;
        while (rdr.Read())
        {
            dt.Columns.Add(((DateTime)rdr[0]).ToString("yyyy-MM-dd"));

            if (days == 0)
            {
                chart1.Series[days].Name = ((DateTime)rdr[0]).ToString("yyyy-MM-dd");
            }
            else
            {
                chart1.Series.Add(((DateTime)rdr[0]).ToString("yyyy-MM-dd"));
            }
            chart1.Series[((DateTime)rdr[0]).ToString("yyyy-MM-dd")].XValueMember = "Hour";
            chart1.Series[((DateTime)rdr[0]).ToString("yyyy-MM-dd")].YValueMembers = ((DateTime)rdr[0]).ToString("yyyy-MM-dd");
            chart1.Series[((DateTime)rdr[0]).ToString("yyyy-MM-dd")].ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.Line;
            days++;
        }
        rdr.Close();

        DataRow dr = dt.NewRow();
        for (int i = 1; i < 25; i++)
        {
            dr = dt.NewRow();
            dr["Hour"] = i;
            dt.Rows.Add(dr);
        }

        cmd.CommandText = "SELECT * FROM observation WHERE day BETWEEN @from2 AND @to2 ORDER BY day ASC, hour ASC ";
        cmd.Parameters.AddWithValue("from2", Convert.ToDateTime(fromDate));
        cmd.Parameters.AddWithValue("to2", Convert.ToDateTime(toDate));

        rdr = cmd.ExecuteReader();
        while (rdr.Read())
        {
            dt.Rows[((int)(rdr[2]) - 1)][(((DateTime)rdr[1]).ToString("yyyy-MM-dd"))] = rdr[3];   
        }

        cmd.Connection.Close();
        rdr.Close();

        dataGridView1.DataSource = dt;

        chart1.DataBind();
        chart1.Visible = true;
1 голос
/ 16 января 2012

Чтобы создать несколько строк, вам нужно создать несколько рядов, но я не уверен, какой тип диаграммы вы используете здесь, это очень хороший учебник о графиках

http://www.4guysfromrolla.com/articles/072209-1.aspx

Chart1.Series[0].Points.FindMinByValue().Color = Color.Red; это должно изменить цвет, который вы хотите для каждой точки.

0 голосов
/ 08 июля 2012
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

dtTest.Columns.Add("TimePoint", GetType(Integer))
dtTest.Columns.Add("Speed", GetType(Integer))

dtTest.Rows.Add(0, 0)
dtTest.Rows.Add(1000, 50)
dtTest.Rows.Add(2000, 50)
dtTest.Rows.Add(3000, 0)

With Chart1.ChartAreas(0)
  .AxisX.Minimum = 0
  .AxisX.Maximum = 3000
  .AxisY.Minimum = 0
  .AxisY.Maximum = 60
  .AxisY.Interval = 10
  .AxisX.Title = "Elapsed Time (ms)"
  .AxisY.Title = "Speed (km/hr)"
End With
End Sub

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
    With Chart1.Series(0)
      .Points.DataBind(dtTest.DefaultView, "TimePoint", "Speed", Nothing)
      .ChartType = DataVisualization.Charting.SeriesChartType.Line
      .BorderWidth = 4
    End With
End Sub
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...