关于解决C# WinForm中Chart控件增删数据时报错的解决方法

1.报错代码

  System.InvalidOperationException
  HResult=0x80131509
  Message=集合已修改;可能无法执行枚举操作。

具体报错表现为,在Application.Run(Form1())中断。

2.解决方法

这个错误通常是由于在枚举集合时对集合进行了修改而引起的。在修改完chart控件中的内容后,可能会导致chart控件的集合被修改,从而导致这个错误。解决这个问题的方法是在修改chart控件之前,先将其暂停更新,然后在修改完成后再恢复更新。
另外,如果在chart控件中使用了多线程,也可能会导致这个错误的出现。在这种情况下,需要确保在访问chart控件时使用线程安全的方法。
具体的代码实现如下:

2.1 在非多线程下

Chart_1.Series.SuspendUpdates(); // 暂停更新

// 在这里进行chart控件的修改操作
//AddDataToChart(xValues, i_Real_Time_Current)//为多线程下操作的步骤与2.2同步

Chart_1.Series.ResumeUpdates(); // 恢复更新

2.2 在多线程下

//定义一个委托,用于在UI线程中执行添加数据的操作
delegate void AddDataDelegate(List<string> xValues, List<int> yValues);

//在UI线程中执行向chart控件中添加数据的操作
private void AddDataToChart(List<string> xValues, List<int> yValues)
{
	if (Chart_1.InvokeRequired)
	{
		Chart_1.Invoke(new AddDataDelegate(AddDataToChart), new object[] { xValues, yValues });
	}
	else
	{
		Chart_1.Series[0].Points.Clear();

		for (int i = 0; i < xValues.Count; i++)
			Chart_1.Series[0].Points.AddXY(xValues[i], yValues[i]);
	}
}
  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# WinForms使用Chart控件联合数据库可以分为以下几个步骤: 1. 创建Chart控件数据库连接:在窗体上添加Chart控件,创建数据库连接对象。 2. 从数据读取数据:使用SQL语句从数据读取需要显示的数据。 3. 将数据绑定到Chart控件上:将数据读取到的数据绑定到Chart控件上,这里可以使用Series对象。 4. 设置Chart控件的属性:根据需要设置Chart控件的属性,如X轴和Y轴的标题、图例等。 5. 显示Chart控件:将Chart控件添加到窗体并显示。 下面是一个简单的示例代码: ```csharp // 创建数据库连接 string connectionString = "Data Source=.;Initial Catalog=MyDatabase;Integrated Security=True"; SqlConnection connection = new SqlConnection(connectionString); // 从数据读取数据 string sql = "SELECT * FROM Sale"; SqlDataAdapter adapter = new SqlDataAdapter(sql, connection); DataTable dataTable = new DataTable(); adapter.Fill(dataTable); // 将数据绑定到Chart控件chart1.Series.Clear(); chart1.DataSource = dataTable; chart1.Series.Add("Sales"); chart1.Series["Sales"].XValueMember = "Month"; chart1.Series["Sales"].YValueMembers = "Amount"; // 设置Chart控件的属性 chart1.Series["Sales"].ChartType = SeriesChartType.Column; chart1.ChartAreas[0].AxisX.Title = "Month"; chart1.ChartAreas[0].AxisY.Title = "Amount"; chart1.Legends[0].Enabled = true; // 显示Chart控件 this.Controls.Add(chart1); ``` 在上面的代码,我们从数据读取了“Sale”表数据,并将“Month”列作为X轴的值,“Amount”列作为Y轴的值,然后将数据绑定到Chart控件上。最后,我们设置了Chart控件的属性并将其添加到窗体
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值