c#chart控件折线图的X轴坐标不对 100
我想让上面的折线显示在柱形图119处开始下降,效果如下图所示代码如下for(intj=RowofQi;j<countx;j++)//这里的RowofQi就是119所在的行...
我想让上面的折线显示在柱形图119处开始下降,效果如下图所示
代码如下
for (int j =RowofQi; j<countx; j++) //这里的RowofQi就是119所在的行号,countx是总共有多少行
{
chart1.Series[1].Points.AddXY(strdt[j], p[j]);//Series[0]是柱形图,已经绑定好了XY,Series[1]是折线图
}
chart1.Series[1].ChartType = SeriesChartType.Spline;
数据如下:
日期 时间(月) 产量(万吨/月)
2000-08-01 0 95
2000-09-01 0 98
2000-10-01 0 102
2000-11-01 0 106
2000-12-01 0 108
2001-01-01 0 118
2001-02-01 0 119
2001-03-01 1 114
2001-04-01 2 110
2001-05-01 3 106
2001-06-01 4 100
2001-07-01 5 95
数据应该都没有问题,调试的时候我的strdt数组中存放的是(2001-02-01到2001-07-01) p[j]中存放的是119到95。。。
但是为何折线总是从横坐标为2000-08-01开始而不是我希望的从2001-02-01开始?? 展开
代码如下
for (int j =RowofQi; j<countx; j++) //这里的RowofQi就是119所在的行号,countx是总共有多少行
{
chart1.Series[1].Points.AddXY(strdt[j], p[j]);//Series[0]是柱形图,已经绑定好了XY,Series[1]是折线图
}
chart1.Series[1].ChartType = SeriesChartType.Spline;
数据如下:
日期 时间(月) 产量(万吨/月)
2000-08-01 0 95
2000-09-01 0 98
2000-10-01 0 102
2000-11-01 0 106
2000-12-01 0 108
2001-01-01 0 118
2001-02-01 0 119
2001-03-01 1 114
2001-04-01 2 110
2001-05-01 3 106
2001-06-01 4 100
2001-07-01 5 95
数据应该都没有问题,调试的时候我的strdt数组中存放的是(2001-02-01到2001-07-01) p[j]中存放的是119到95。。。
但是为何折线总是从横坐标为2000-08-01开始而不是我希望的从2001-02-01开始?? 展开
展开全部
楼主
chart1.Series[1].Points.AddXY(strdt[j], p[j]);
strdt数组是什么类型?
不是double类型吧?
我猜测你这样添加的点的横坐标没有被标记,而是默认的从1到N,所以才会又从1开始。造成图像也就是从横坐标的最左边开始绘制。
设定strdt数组是日期数组,p[j]是double类型数组,设定chart1.ChartAreas[0]横坐标为时间类型。
循环里面:
chart1.Series[1].Points.AddXY(strdt[j].ToOADate(), p[j]);
设定横坐标显示外观:
chart1.ChartAreas[0].AxisX.LabelStyle.Format ="yyyy-MM-dd";
追问
我strdt是字符数组,麻烦大神给出具体办法。。解决问题的话我再追加一百分给你
追答
//序列1
Series curse1 = new Series("s1");
curse1.XValueType = ChartValueType.DateTime;
curse1.YValueType = ChartValueType.Double;
curse1.ChartType = SeriesChartType.Column;
List<DateTime> xValue1 = new List<DateTime>();
List<double> yValue1 = new List<double>();
//模拟数据源,字数超过最大值限制就删除 了
//series添加数据点
for (int i = 0; i < xValue1.Count; i++)
{
curse1.Points.AddXY(xValue1[i].ToOADate(), yValue1[i]);
}
chart1.Series.Add(curse1);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询