C#--图表控件(Chart)

54 篇文章 1 订阅
43 篇文章 2 订阅

https://blog.csdn.net/qq_20936333/article/details/82020584

采用VS自带的Chart图表控件,制作实时动态显示的折线图,和波形图

涉及知识点:

  • Chart 控件,功能强大,可以绘制柱状图,折线图,波形图,饼状图,大大简化了对图的开发与定制。

Chart控件的相关概念:

  • ChartArea,表示图表区域,一个Chart可以绘制多个ChartArea,重叠在一起。
  • Series ,表示数据序列,每个ChartArea可以有多个数据线。即,Series属于ChartArea.
  • AxisX,AxisY,表示主坐标轴,每一个ChartArea都有对应的坐标轴,包括主坐标轴,辅坐标轴
  • Queue集合,表示先进先出的集合。

主要有两个方法:

  • Dequeue() 表示移除并返回位于 System.Collections.Generic.Queue<T> 开始处的对象。
  • Enqueue() 表示将对象添加到 System.Collections.Generic.Queue<T> 的结尾处。
  • Timer ,定时器,定时之行相应的功能,更新数据,刷新图表。

 

【折线图,是取[0,100]之间的随即数进行填充】:

【波形图,是取正玄值,并放大50倍,然后上移50】


 
 
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Windows.Forms;
  9. using System.Windows.Forms.DataVisualization.Charting;
  10. namespace WindowsFormsApplication1
  11. {
  12. public partial class RealChart : Form
  13. {
  14. private Queue< double> dataQueue = new Queue< double>( 100);
  15. private int curValue = 0;
  16. private int num = 5; //每次删除增加几个点
  17. public RealChart()
  18. {
  19. InitializeComponent();
  20. }
  21. /// <summary>
  22. /// 初始化事件
  23. /// </summary>
  24. /// <param name="sender"></param>
  25. /// <param name="e"></param>
  26. private void btnInit_Click(object sender, EventArgs e)
  27. {
  28. InitChart();
  29. }
  30. /// <summary>
  31. /// 开始事件
  32. /// </summary>
  33. /// <param name="sender"></param>
  34. /// <param name="e"></param>
  35. private void btnStart_Click(object sender, EventArgs e)
  36. {
  37. this.timer1.Start();
  38. }
  39. /// <summary>
  40. /// 停止事件
  41. /// </summary>
  42. /// <param name="sender"></param>
  43. /// <param name="e"></param>
  44. private void btnStop_Click(object sender, EventArgs e)
  45. {
  46. this.timer1.Stop();
  47. }
  48. /// <summary>
  49. /// 定时器事件
  50. /// </summary>
  51. /// <param name="sender"></param>
  52. /// <param name="e"></param>
  53. private void timer1_Tick(object sender, EventArgs e)
  54. {
  55. UpdateQueueValue();
  56. this.chart1.Series[ 0].Points.Clear();
  57. for( int i= 0;i<dataQueue.Count;i++){
  58. this.chart1.Series[ 0].Points.AddXY((i+ 1), dataQueue.ElementAt(i));
  59. }
  60. }
  61. /// <summary>
  62. /// 初始化图表
  63. /// </summary>
  64. private void InitChart() {
  65. //定义图表区域
  66. this.chart1.ChartAreas.Clear();
  67. ChartArea chartArea1 = new ChartArea( "C1");
  68. this.chart1.ChartAreas.Add(chartArea1);
  69. //定义存储和显示点的容器
  70. this.chart1.Series.Clear();
  71. Series series1 = new Series( "S1");
  72. series1.ChartArea = "C1";
  73. this.chart1.Series.Add(series1);
  74. //设置图表显示样式
  75. this.chart1.ChartAreas[ 0].AxisY.Minimum = 0;
  76. this.chart1.ChartAreas[ 0].AxisY.Maximum = 100;
  77. this.chart1.ChartAreas[ 0].AxisX.Interval = 5;
  78. this.chart1.ChartAreas[ 0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;
  79. this.chart1.ChartAreas[ 0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;
  80. //设置标题
  81. this.chart1.Titles.Clear();
  82. this.chart1.Titles.Add( "S01");
  83. this.chart1.Titles[ 0].Text = "XXX显示";
  84. this.chart1.Titles[ 0].ForeColor = Color.RoyalBlue;
  85. this.chart1.Titles[ 0].Font = new System.Drawing.Font( "Microsoft Sans Serif", 12F);
  86. //设置图表显示样式
  87. this.chart1.Series[ 0].Color = Color.Red;
  88. if (rb1.Checked)
  89. {
  90. this.chart1.Titles[ 0].Text = string.Format( "XXX {0} 显示",rb1.Text);
  91. this.chart1.Series[ 0].ChartType = SeriesChartType.Line;
  92. }
  93. if (rb2.Checked) {
  94. this.chart1.Titles[ 0].Text = string.Format( "XXX {0} 显示", rb2.Text);
  95. this.chart1.Series[ 0].ChartType = SeriesChartType.Spline;
  96. }
  97. this.chart1.Series[ 0].Points.Clear();
  98. }
  99. //更新队列中的值
  100. private void UpdateQueueValue() {
  101. if (dataQueue.Count > 100) {
  102. //先出列
  103. for ( int i = 0; i < num; i++)
  104. {
  105. dataQueue.Dequeue();
  106. }
  107. }
  108. if (rb1.Checked)
  109. {
  110. Random r = new Random();
  111. for ( int i = 0; i < num; i++)
  112. {
  113. dataQueue.Enqueue(r.Next( 0, 100));
  114. }
  115. }
  116. if (rb2.Checked) {
  117. for ( int i = 0; i < num; i++)
  118. {
  119. //对curValue只取[0,360]之间的值
  120. curValue = curValue % 360;
  121. //对得到的正玄值,放大50倍,并上移50
  122. dataQueue.Enqueue(( 50*Math.Sin(curValue*Math.PI / 180))+ 50);
  123. curValue=curValue+ 10;
  124. }
  125. }
  126. }
  127. }
  128. }

 

关于定时器Timer:

说明:表示在相同的时间间隔,引发用户自定义的事情 。实现用户需要的功能。本例中是用来定时更新队列中的数据,并刷新图表。

常用说明:

  1. Interval 时间间隔,以毫秒为单位,本例是300毫秒。
  2. Tick 定时触发的事件,本例对应timer1_Tick事件方法。
  3. Start(),Stop() 表示定时器的启动和停止。Enabled 表示定时器是否启用,默认值为 false,需要手动设置为true。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值