winform chart画折线,波形图,多条数据

本文介绍了一个使用C#实现的波形回放显示程序。该程序通过Form界面布局,包含RadioButton选择不同的显示方式,Button控制开始、暂停及初始化图表,以及使用Chart进行波形绘制。通过Timer定时更新数据并绘制波形。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结果图

 

代码过程:

Form界面布局,控件:2个RadioButton, 3个button,1个chart,1个timer控件

代码区:Form1.cs

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

namespace boxinghuifang
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        private Queue<double> dataQueue = new Queue<double>(100);
        private Queue<double> dataQueue1 = new Queue<double>(100);

        private int curValue = 0;
        private int num = 5;//每次删除怎加几个点
        private void button1_Click(object sender, EventArgs e)
        {
            InitChart();
        }
        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);

            Series series2 = new Series("WW1");    /////////////////////////
            series2.ChartArea = "C1";                ///////////////////////////////
            this.chart1.Series.Add(series2);           /////////////////////////////////


            //设置图表显示样式
            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 = "波形回放显示";
            this.chart1.Titles[0].ForeColor = Color.RoyalBlue;
            this.chart1.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F);


            //设置标题


            //  this.chart1.Titles[1].ForeColor = Color.RosyBrown;
            this.chart1.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F);
            //设置图表显示样式
            this.chart1.Series[0].Color = Color.Red;
            this.chart1.Series[1].Color = Color.Green;

            if (rb1.Checked)
            {
                this.chart1.Titles[0].Text = string.Format("XXX {0} 显示", rb1.Text);
                this.chart1.Series[0].ChartType = SeriesChartType.Line;
                this.chart1.Series[1].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[1].ChartType = SeriesChartType.Spline;
            }
            this.chart1.Series[0].Points.Clear();
            this.chart1.Series[1].Points.Clear();
        }

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

            if (dataQueue.Count > 100)
            {
                //先出列
                for (int i = 0; i < num; i++)
                {
                    dataQueue.Dequeue();
                }
            }
            if (dataQueue1.Count > 100)
            {
                //先出列
                for (int i = 0; i < num; i++)
                {
                    dataQueue1.Dequeue();
                }
            }
            if (rb1.Checked)
            {
                Random r = new Random();
                for (int i = 0; i < num;i++ )
                {
                    dataQueue.Enqueue(r.Next(0, 100));
                    int[] A = new int[100];
                    A[i] = i + r.Next(0, 100);
                    dataQueue1.Enqueue(A[i]);
                }
            }
            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);
                    dataQueue1.Enqueue((50 * Math.Sin(curValue * Math.PI / 180)) + 30);
                    curValue = curValue + 10;
                }
            }
        }

        private void button2_Click(object sender, EventArgs e)
        {
            this.timer1.Start();
        }
        public static bool S = false;
        private void button3_Click(object sender, EventArgs e)
        {
            if(S==false)
            {
                button3.Text = "继续";
                this.timer1.Stop();
                S = true;
            }
            else
            {
                button3.Text = "暂停";
                this.timer1.Start();
                S = false;
            }
        }

        private void timer1_Tick(object sender, EventArgs e)
        {
            UpdateQueueValue();
            this.chart1.Series[0].Points.Clear();
            this.chart1.Series[1].Points.Clear();
            for (int i = 0; i < dataQueue.Count; i++)
            {
                this.chart1.Series[0].Points.AddXY((i + 1), dataQueue.ElementAt(i));
            }
            for (int i = 0; i < dataQueue1.Count; i++)
            {
                this.chart1.Series[1].Points.AddXY((i + 1), dataQueue1.ElementAt(i));
            }
        }
    }
}

 

完整代码下载地址:

 

https://download.youkuaiyun.com/my/uploads

### 使用 WinForms Chart 控件绘制多条折线图 要在 WinForms 中使用 `Chart` 控件绘制多条折线图,可以通过设置多个系列(Series),并将它们的数据类型指定为 `Line` 来实现。以下是详细的实现方法以及示例代码。 #### 设置 Chart 控件的属性 为了绘制多条折线图,需要重点配置以下几个属性: 1. **ChartAreas**: 定义图表区域及其样式。 2. **Series**: 添加多个系列来表示不同的数据集,并将其 `ChartType` 属性设为 `SeriesChartType.Line`[^1]。 3. **Legends**: 可选地添加图例以便区分不同线条代表的意义。 #### 示例代码 以下是一个完整的 C# 实现示例: ```csharp using System; using System.Windows.Forms; using System.Windows.Forms.DataVisualization.Charting; public class MultiLineChart : Form { private Chart chart; public MultiLineChart() { InitializeChart(); } private void InitializeChart() { // 创建并初始化 Chart 控件 chart = new Chart(); chart.Dock = DockStyle.Fill; // 添加图表区域 var chartArea = new ChartArea("MainChartArea"); chart.ChartAreas.Add(chartArea); // 配置第一个 Series 数据 var series1 = new Series("Series1"); series1.ChartType = SeriesChartType.Line; // 设定为折线图 series1.Points.AddXY(1, 10); series1.Points.AddXY(2, 20); series1.Points.AddXY(3, 15); series1.Points.AddXY(4, 25); series1.Color = System.Drawing.Color.Red; // 配置第二个 Series 数据 var series2 = new Series("Series2"); series2.ChartType = SeriesChartType.Line; // 设定为折线图 series2.Points.AddXY(1, 8); series2.Points.AddXY(2, 18); series2.Points.AddXY(3, 17); series2.Points.AddXY(4, 22); series2.Color = System.Drawing.Color.Blue; // 将 Series 添加到 Chart 控件中 chart.Series.Add(series1); chart.Series.Add(series2); // 添加图例 (可选) var legend = new Legend("Legend1"); chart.Legends.Add(legend); this.Controls.Add(chart); // 将 Chart 控件添加到窗体中 } } // 启动应用程序 static class Program { [STAThread] static void Main() { Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Application.Run(new MultiLineChart()); } } ``` #### 关键点解析 1. **创建多个 Series**:通过实例化多个 `Series` 对象,并分别为其赋值数据点和颜色,可以轻松实现多条折线的效果[^1]。 2. **设定 Series 的 ChartType**:将每个 `Series` 的 `ChartType` 属性设置为 `SeriesChartType.Line`,从而定义其为折线图。 3. **自定义颜色**:通过设置 `Color` 属性,可以让每条折线具有独特的视觉效果。 4. **添加图例**:如果希望用户能够直观地区分各条折线,则可通过 `Legend` 提供额外的信息。 #### 注意事项 - 如果数据量较大,建议优化性能,例如禁用不必要的动或调整绘图模式。 - 确保所有 `XValue` 和 `YValues` 均有效,否则可能导致异常或不正确的渲染结果。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值