C# 绘制实时折线图,波形图

 更新时间:2020年07月10日 16:20:27   作者:Alan.hsiang  
这篇文章主要介绍了C# 绘制实时折线图,波形图的方法,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下

此Demo是采用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】

核心代码

代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Windows.Forms.DataVisualization.Charting;

namespace WindowsFormsApplication1
{
 public partial class RealChart : Form
 {
  private Queue<double> dataQueue = new Queue<double>(100);

  private int curValue = 0;

  private int num = 5;//每次删除增加几个点

  public RealChart()
  {
   InitializeComponent();
  }

  /// <summary>
  /// 初始化事件
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void btnInit_Click(object sender, EventArgs e)
  {
   InitChart();
  }

  /// <summary>
  /// 开始事件
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void btnStart_Click(object sender, EventArgs e)
  {
   this.timer1.Start();
  }

  /// <summary>
  /// 停止事件
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void btnStop_Click(object sender, EventArgs e)
  {
   this.timer1.Stop();
  }

  /// <summary>
  /// 定时器事件
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void timer1_Tick(object sender, EventArgs e)
  {
   UpdateQueueValue();
   this.chart1.Series[0].Points.Clear();
   for(int i=0;i<dataQueue.Count;i++){
    this.chart1.Series[0].Points.AddXY((i+1), dataQueue.ElementAt(i));
   }
  }

  /// <summary>
  /// 初始化图表
  /// </summary>
  private void InitChart() {
   //定义图表区域
   this.chart1.ChartAreas.Clear();
   ChartArea chartArea1 = new ChartArea("C1");
   this.chart1.ChartAreas.Add(chartArea1);
   //定义存储和显示点的容器
   this.chart1.Series.Clear();
   Series series1 = new Series("S1");
   series1.ChartArea = "C1";
   this.chart1.Series.Add(series1);
   //设置图表显示样式
   this.chart1.ChartAreas[0].AxisY.Minimum = 0;
   this.chart1.ChartAreas[0].AxisY.Maximum =100;
   this.chart1.ChartAreas[0].AxisX.Interval = 5;
   this.chart1.ChartAreas[0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;
   this.chart1.ChartAreas[0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;
   //设置标题
   this.chart1.Titles.Clear();
   this.chart1.Titles.Add("S01");
   this.chart1.Titles[0].Text = "XXX显示";
   this.chart1.Titles[0].ForeColor = Color.RoyalBlue;
   this.chart1.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F);
   //设置图表显示样式
   this.chart1.Series[0].Color = Color.Red;
   if (rb1.Checked)
   {
    this.chart1.Titles[0].Text =string.Format( "XXX {0} 显示",rb1.Text);
    this.chart1.Series[0].ChartType = SeriesChartType.Line;
   }
   if (rb2.Checked) {
    this.chart1.Titles[0].Text = string.Format("XXX {0} 显示", rb2.Text);
    this.chart1.Series[0].ChartType = SeriesChartType.Spline;
   }
   this.chart1.Series[0].Points.Clear();
  }

  //更新队列中的值
  private void UpdateQueueValue() {

   if (dataQueue.Count > 100) {
    //先出列
    for (int i = 0; i < num; i++)
    {
     dataQueue.Dequeue();
    }
   }
   if (rb1.Checked)
   {
    Random r = new Random();
    for (int i = 0; i < num; i++)
    {
     dataQueue.Enqueue(r.Next(0, 100));
    }
   }
   if (rb2.Checked) {
    for (int i = 0; i < num; i++)
    {
     //对curValue只取[0,360]之间的值
     curValue = curValue % 360;
     //对得到的正玄值,放大50倍,并上移50
     dataQueue.Enqueue((50*Math.Sin(curValue*Math.PI / 180))+50);
     curValue=curValue+10;
    }
   }
  }
 }
}

备注

关于定时器Timer【微软自带的控件】:

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

常用说明:

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

由于需要源码的比较多,故将源码下载链接放于此处,请自行下载,谢谢

源码下载

以上就是C# 绘制实时折线图,波形图的详细内容,更多关于C# 折线图,波形图的资料请关注脚本之家其它相关文章!

相关文章

  • C#实现简单订单管理程序

    C#实现简单订单管理程序

    这篇文章主要为大家详细介绍了C#实现简单订单管理程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C#自定义控件添加右键菜单的方法

    C#自定义控件添加右键菜单的方法

    这篇文章主要介绍了C#自定义控件添加右键菜单的方法,本文用到control控件,专门自定义右键菜单,下面小编给大家整理下,有需要的小伙伴可以来参考下
    2015-08-08
  • C#计算字符串相似性的方法

    C#计算字符串相似性的方法

    这篇文章主要介绍了C#计算字符串相似性的方法,实例分析了C#计算字符串相似性的原理与算法实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • C#窗体程序实现全屏及取消全屏步骤

    C#窗体程序实现全屏及取消全屏步骤

    这篇文章主要介绍了C#窗体程序实现全屏及取消全屏步骤,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • 深入分析WPF客户端读取高清图片卡以及缩略图的解决方法详解

    深入分析WPF客户端读取高清图片卡以及缩略图的解决方法详解

    本篇文章是对WPF客户端读取高清图片卡以及缩略图的解决方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 关于c#中枚举类型支持显示中文的扩展说明

    关于c#中枚举类型支持显示中文的扩展说明

    需求 : 枚举类型在界面显示的时候可以显示相应的中文信息, 这样界面对用户友好 . 场景 : 在一些业务中涉及到审核功能的时候, 往往有这几个状态 :未送审 , 审核中 ,审核通过, 驳回 . 这个时候我们会定义一个枚举类型来描述 :
    2013-03-03
  • C# SelectedIndexChanged事件详解

    C# SelectedIndexChanged事件详解

    这篇文章主要介绍了C# SelectedIndexChanged事件详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C#线程开发之System.Thread类详解

    C#线程开发之System.Thread类详解

    本文详细讲解了C#线程开发之System.Thread类,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • c#添加图片、文本水印到PDF文件

    c#添加图片、文本水印到PDF文件

    这篇文章主要介绍了如何用c#给PDF文件添加文本、图片水印,文中代码非常详细供大家学习参考,感兴趣的朋友可以了解下
    2020-06-06
  • C#实现打造气泡屏幕保护效果

    C#实现打造气泡屏幕保护效果

    本文是介给大家介绍一个很好玩的小程序:气泡屏幕保护!类似于windows的屏保功能,有需要的朋友可以参考一下。
    2016-10-10

最新评论