在winform中绘图

今天跟大家分享一下最近做的一个程序中绘图功能的实现。

先来看看实现的效果:

具体实现

页面的设计

绘图设置页面的设计如下所示:

4个label控件,控件如下所示:

2个DateEdit控件,控件如下所示:

1个ComboBoxEdit控件,控件如下所示:

1个CheckedListBoxControl控件,控件如下所示:

1个SimpleButton控件,控件如下所示:

绘图展示的页面设计如下:

只有一个ChartControl控件,控件如下所示:

代码

绘图的数据是之前文章提过的使用C#实现爬虫获取网页数据得到的数据,如下所示:

这些数据中只用了最低温度、最高温度、最低能见度、最高能见度来绘图。

第一步实现加载窗体时获取ComboBoxEdit与CheckedListBoxControl中的内容:

ini 复制代码
 public void init()
 {
     // 为下拉框框赋值
     var comboBoxItems = db.Queryable<WeatherData>().Select(x => x.StationName).Distinct().ToList();
     comboBoxEdit1.Properties.Items.AddRange(comboBoxItems);
     comboBoxEdit2.Properties.Items.AddRange(comboBoxItems);
​
     // 多选框的设置
     checkedListBoxControl1.CheckOnClick = true; // 设置为单击即选中或取消选中
​
     // 多选框中的值
     string[] indexs = { "最低温度(℃)", "最高温度(℃)", "最低可见度(km)", "最高可见度(km)" };
     // 多选框添加项
     var checkedItems = new List<CheckedListBoxItem>();
     foreach (var index in indexs)
     {
         var checkedItem = new CheckedListBoxItem();
         checkedItem.Value = index;
         checkedItems.Add(checkedItem);
     }
     checkedListBoxControl1.Items.AddRange(checkedItems.ToArray());
​
 }
 private void ToolbarForm1_Load(object sender, EventArgs e)
 {
     init();
 }

获取不同的站名:

ini 复制代码
 var comboBoxItems = db.Queryable<WeatherData>()
                       .Select(x => x.StationName).Distinct().ToList();

为下拉框添加值:

ini 复制代码
  comboBoxEdit1.Properties.Items.AddRange(comboBoxItems);

为多选框添加值:

ini 复制代码
     // 多选框的设置
     checkedListBoxControl1.CheckOnClick = true; // 设置为单击即选中或取消选中
​
     // 多选框中的值
     string[] indexs = { "最低温度(℃)", "最高温度(℃)", "最低可见度(km)", "最高可见度(km)" };
     // 多选框添加项
     var checkedItems = new List<CheckedListBoxItem>();
     foreach (var index in indexs)
     {
         var checkedItem = new CheckedListBoxItem();
         checkedItem.Value = index;
         checkedItems.Add(checkedItem);
     }
     checkedListBoxControl1.Items.AddRange(checkedItems.ToArray());

开始绘图按钮的点击事件代码:

ini 复制代码
 private void simpleButton3_Click(object sender, EventArgs e)
 {
     var date1 = dateEdit3.EditValue;
     var date2 = dateEdit4.EditValue;
     var name = comboBoxEdit2.Text;
     var checkedItems = checkedListBoxControl1.CheckedItems;
     if (date1 != null && date2 != null && name != "" && checkedItems.Count != 0)
     {
         var startDate = Convert.ToDateTime(date1);
         var endDate = Convert.ToDateTime(date2);
         var list = db.Queryable<WeatherData>().Where(x => x.Date >= startDate && x.Date < endDate.AddDays(1) && x.StationName == name).ToList();
         // 清空之前的图
         if (chartControl2.Series.Count > 0)
         {
             chartControl2.Series.Clear();
         }
         // 选中几个指标就画几个图
         foreach (CheckedListBoxItem item in checkedItems)
         {
             var indexKey = item.Value.ToString();
             switch (indexKey)
             {
                 case "最低温度(℃)":
                     Series series1 = new Series("最低温度(℃)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series1.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Tem_Low));
​
                     }
                     chartControl2.Series.Add(series1);
                     break;
                 case "最高温度(℃)":
                     Series series2 = new Series("最高温度(℃)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series2.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Tem_High));
​
                     }
                     chartControl2.Series.Add(series2);
                     break;
                 case "最低可见度(km)":
                     Series series3 = new Series("最低可见度(km)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series3.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Visibility_Low));
​
                     }
                     chartControl2.Series.Add(series3);
                     break;
                 case "最高可见度(km)":
                     Series series4 = new Series("最高可见度(km)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series4.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Visibility_High));
​
                     }
                     chartControl2.Series.Add(series4);
                     break;
             }
​
​
         }
         // 绘图完成提示
         MessageBox.Show("绘图已完成");
​
     }
     else
     {
         MessageBox.Show("请检查开始日期、结束日期、站名和绘图指标是否都已填写!!!");
     }
​
​
​
 }

数据查询:

ini 复制代码
 var list = db.Queryable<WeatherData>().Where(x => x.Date >= startDate && x.Date < endDate.AddDays(1) && x.StationName == name).ToList();

这里获取时间范围内的数据不用var list = db.Queryable<WeatherData>().Where(x => x.Date >= startDate && x.Date <=endDate && x.StationName == name).ToList();的原因是比如我选择的是2023-11-1到2023-11-15之间的数据,如下所示:

获取的数据,如下所示:

并没有获取到2023-11-15数据,是因为我们要获取的是2023-11-14511:00 与2023-11-15 17:00的数据,因此可以选择使用DateTime.AddDays(1)的方法解决,如下所示:

绘图:

这里考虑的是选择几个指标就画几个图,因此可以使用switch case实现:

java 复制代码
 switch (indexKey)
             {
                 case "最低温度(℃)":
                     Series series1 = new Series("最低温度(℃)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series1.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Tem_Low));
​
                     }
                     chartControl2.Series.Add(series1);
                     break;
                 case "最高温度(℃)":
                     Series series2 = new Series("最高温度(℃)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series2.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Tem_High));
​
                     }
                     chartControl2.Series.Add(series2);
                     break;
                 case "最低可见度(km)":
                     Series series3 = new Series("最低可见度(km)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series3.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Visibility_Low));
​
                     }
                     chartControl2.Series.Add(series3);
                     break;
                 case "最高可见度(km)":
                     Series series4 = new Series("最高可见度(km)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series4.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Visibility_High));
​
                     }
                     chartControl2.Series.Add(series4);
                     break;
             }

绘图代码:

ini 复制代码
Series series1 = new Series("最低温度(℃)", ViewType.Line);
                     foreach (var dataPoint in list)
                     {
                         series1.Points.Add(new SeriesPoint(dataPoint.Date, dataPoint.Tem_Low));
​
                     }
                     chartControl2.Series.Add(series1);

最后的绘图效果如下所示:

以上就是在本案例中在winform中绘图的实现过程,希望对你有所帮助。

相关推荐
没什么本事6 小时前
关于C# panel 添加lable问题 -- 明确X和Y 位置错误
android·java·c#
火星papa8 小时前
C# 实现平滑流畅的进度条ProgressBar
c#·进度条·progressbar·平滑流畅
游乐码9 小时前
UnityGUI(五)GUI控件综合使用
开发语言·unity·c#
程序leo源9 小时前
C语言知识总结
c语言·开发语言·c++·经验分享·笔记·青少年编程·c#
烛阴10 小时前
TEngine 入门系列(二):三件套环境搭建 -- Unity + TEngine + AI 助手
前端·c#·unity3d
The Shio14 小时前
OptiByte 操练场:面向 IoT/嵌入式的协议可视化调试工具
网络·嵌入式硬件·物联网·c#·.net·业界资讯·iot
龙侠九重天16 小时前
C# 调用 TensorFlow:迁移学习与模型推理实战指南
人工智能·深度学习·机器学习·c#·tensorflow·迁移学习·tensorflow.net
我是唐青枫17 小时前
C#.NET YARP 认证授权实战:在网关层统一接入 JWT
开发语言·c#·.net
程序leo源18 小时前
Linux深度理解
linux·运维·服务器·c语言·c++·青少年编程·c#
白菜上路18 小时前
C# .net 生成版本号自动变更
c#·.net·visual studio