winform中chart控件解决显示大量曲线数据卡顿方法——删旧添新法

在这里插入图片描述

前言:

大家好,我是上位机马工,硕士毕业4年年入40万,目前在一家自动化公司担任软件经理,从事C#上位机软件开发8年以上!我们在开发winform窗体程序的时候,有时候会往chart控件中添加大量的数据用于显示曲线,当数据太多时,会出现程序界面卡顿甚至软件崩溃的情况,本文就来帮助大家解决这个问题!

1、示例代码

 public partial class Form1 : Form
    {

        List<double> xList = new List<double>();
        List<double> yList = new List<double>();
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Run();
        }
        int maxCount = 10;
        private void Run()
        {
            Random random = new Random();
            int val = random.Next(0, 1000);//生成随机数

            if (yList.Count == maxCount)//判断数量达到上限,则删除一个旧数据
            {
                yList.RemoveAt(0);
            }
            yList.Add(val);
            GetxList();
            UpdateChart();
        }


        /// <summary>
        /// 获取x坐标
        /// </summary>
        private void GetxList()
        {
            xList.Clear();
            int count = yList.Count;
            for (int i = 0; i < count; i++)
            {
                xList.Add(i + 1);
            }
        }

        /// <summary>
        /// 显示曲线
        /// </summary>
        private void UpdateChart()
        {
            this.Invoke(new Action(() =>
            {

                chart1.Series[0].Points.Clear();
                chart1.Series[0].Points.DataBindXY(xList, yList);
            }));
        }
    }

2、删旧添新法

该方法的原理就是,我们设置一个显示数据的上限,比如1000,当曲线显示的数据等于1000时,这时又有新的数据需要显示时,我们先删除一定数量的旧数据,然后添加相等数量的新数据,这样保持显示的数据始终保持在1000个,这样我们就能确保控件不会因为需要显示太多数据而卡顿或者崩溃同时控件显示的数据又是最新的。

3、视频讲解

解决显示大量曲线数据卡顿——删旧添新法

马工撰写的年入30万+C#上位机项目实战必备教程(点击下方链接即可访问文章目录)

1、《C#串口通信从入门到精通》
2、《C#与PLC通信从入门到精通 》
3、《C# Modbus通信从入门到精通》
4、《C#Socket通信从入门到精通 》
5、《C# MES通信从入门到精通》
6、《winform控件从入门到精通》
7、《C#操作MySql数据库从入门到精通》

以上教程CSDN订阅已超过2000+~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

上位机马工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值