5

我在 winforms 应用程序中放置了一个图表控件,然后尝试添加一些数据以显示为堆积柱形图。无论我多么努力,我都无法正确显示第二个系列。我通过删除其他所有内容并仅留下 2 个系列和最少量的数据来隔离问题。

图表代码:

System.Windows.Forms.DataVisualization.Charting.ChartArea chartArea1 = new System.Windows.Forms.DataVisualization.Charting.ChartArea();
System.Windows.Forms.DataVisualization.Charting.Legend legend1 = new System.Windows.Forms.DataVisualization.Charting.Legend();
System.Windows.Forms.DataVisualization.Charting.Series series1 = new System.Windows.Forms.DataVisualization.Charting.Series();
System.Windows.Forms.DataVisualization.Charting.Series series2 = new System.Windows.Forms.DataVisualization.Charting.Series();
this.chart1 = new System.Windows.Forms.DataVisualization.Charting.Chart();
((System.ComponentModel.ISupportInitialize)(this.chart1)).BeginInit();
this.SuspendLayout();
// 
// chart1
// 
chartArea1.Name = "ChartArea1";
this.chart1.ChartAreas.Add(chartArea1);
legend1.Name = "Legend1";
this.chart1.Legends.Add(legend1);
this.chart1.Location = new System.Drawing.Point(49, 62);
this.chart1.Name = "chart1";
series1.ChartArea = "ChartArea1";
series1.ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.StackedColumn;
series1.Legend = "Legend1";
series1.Name = "Series2";
series2.ChartArea = "ChartArea1";
series2.ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.StackedColumn;
series2.Legend = "Legend1";
series2.Name = "Series3";
this.chart1.Series.Add(series1);
this.chart1.Series.Add(series2);
this.chart1.Size = new System.Drawing.Size(534, 300);
this.chart1.TabIndex = 0;
this.chart1.Text = "chart1";

数据代码:

chart1.Series["Series2"].Points.Add(new DataPoint(1, 1));
chart1.Series["Series2"].Points.Add(new DataPoint(2, 4));
chart1.Series["Series2"].Points.Add(new DataPoint(3, 5));
chart1.Series["Series3"].Points.Add(new DataPoint(2, 3));

在设计器图表中看起来像这样(正是我想要的样子):

设计师图表

但是当我运行应用程序时,永远不会显示一个系列(可能被第一个系列隐藏......)。

应用图

当我将第二点更改Series2

chart1.Series["Series2"].Points.Add(new DataPoint(2, 0));

然后它看起来像:

应用图2

我究竟做错了什么?它是一个错误吗?我还在我的实际应用程序中尝试使用堆叠和非堆叠的列组合,并且运行时结果总是与设计器中预览的不同(我的意思是列以完全不同的方式显示)。

4

2 回答 2

4

好的,我找到了解决方案。根据数据系列必须对齐(因此除其他事项外,它们需要具有相同数量的样本)。此处描述了数据的对齐方式。所以一行正在解决问题:

chart1.DataManipulator.InsertEmptyPoints(1, IntervalType.Number, "Series2, Series3");
于 2013-05-24T10:02:22.467 回答
0

如果系列中缺少值,则应始终添加零分。方法“插入空点”对我没有帮助。

于 2015-11-20T17:33:27.893 回答