.net C# Chart控件,如何动态画rangeColumn图和Bar图?

图画了,现在我想让这个图片能感知鼠标的操作,能实现吗?比如在所画曲线上一点悬停(或单击),在某个控件(文本区域)显示当前x,y坐标。... 图画了,现在我想让这个图片能感知鼠标的操作,能实现吗?比如在所画曲线上一点悬停(或单击),在某个控件(文本区域)显示当前x,y坐标。 展开
 我来答
bodhi1
推荐于2016-07-16
知道答主
回答量:14
采纳率:0%
帮助的人:17万
展开全部

HTML部分:

<asp:Chart ID="ChartBar" runat="server" Width="800px" BackColor="#FFFFCC" Palette="BrightPastel" BorderWidth = "2" BorderColor = "#cc9900" >

<Legends>

<asp:Legend IsTextAutoFit="False" Name="Default" BackColor="Transparent" Font="Trebuchet MS, 8.25pt, style=Bold">

</asp:Legend>

</Legends> 

<ChartAreas>

<asp:ChartArea Name="ChartArea1">

</asp:ChartArea>

</ChartAreas>

</asp:Chart>

<asp:Chart ID="ChartPie" runat="server" Width="400px" BackColor="#FFFFCC" Palette="BrightPastel" BorderWidth = "0" BorderColor = "#cc9900" >

<Legends>

<asp:Legend IsTextAutoFit="False" Name="Default" BackColor="Transparent" Font="Trebuchet MS, 8.25pt, style=Bold">

</asp:Legend>

</Legends> 

<ChartAreas>

<asp:ChartArea Name="ChartArea1">

</asp:ChartArea>

</ChartAreas>

 

</asp:Chart>

C#部分:

//获取每月销售情况

int[] arraySell=new int[]{10};

//获取月份

string[] arrayMonths = new string[] { "1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月" };

//获取部门

string[] arrayDeparts = new string[] { "部门1", "部门2", "部门3" };

Series seriess = new Series("销售情况");

seriess.BorderWidth = 3;

seriess.ShadowOffset = 2;

Series seriesPies = new Series("销售情况");

seriesPies.ChartType = SeriesChartType.Pie;

seriesPies.BorderWidth = 3;

seriesPies.ShadowOffset = 2;

this.ChartBar.Series.Add(seriess);

this.ChartPie.Series.Add(seriesPies);

Title tBar = new Title("销售情况柱状图");

this.ChartBar.Titles.Add(tBar);

Title tPie = new Title("销售情况饼状图");

this.ChartPie.Titles.Add(tPie);

this.ChartBar.ChartAreas["ChartArea1"].AxisX.Interval = 1;//x轴数据显示间隔

this.ChartBar.ChartAreas["ChartArea1"].AxisY.Interval = 50;

//画柱状图

foreach (string d in arrayDeparts)

{

Series tempseries = new Series(string.Format("{0}", d));

this.ChartBar.Series.Add(tempseries);

foreach (string m in arrayMonths)

{

foreach (int n in arraySell)

{

tempseries.Points.AddXY(m, n);

}

}

//画饼图

foreach (string d in arrayDeparts)

foreach(int n in arraySell)

{

seriesPies.Points.AddXY(d, n);

}

}

 

this.ChartBar.ChartAreas["ChartArea1"].AxisX.IsMarginVisible = false;

this.ChartBar.ChartAreas["ChartArea1"].Area3DStyle.Enable3D = false;

//背景色设置

this.ChartBar.ChartAreas["ChartArea1"].ShadowColor = Color.Transparent;

this.ChartBar.ChartAreas["ChartArea1"].BackColor = Color.Azure;

this.ChartBar.ChartAreas["ChartArea1"].BackGradientStyle = GradientStyle.TopBottom;

this.ChartBar.ChartAreas["ChartArea1"].BackSecondaryColor = Color.White;

//X,Y坐标线颜色和大小

this.ChartBar.ChartAreas["ChartArea1"].AxisX.LineColor = Color.Blue;

this.ChartBar.ChartAreas["ChartArea1"].AxisY.LineColor = Color.Blue;

this.ChartBar.ChartAreas["ChartArea1"].AxisX.LineWidth = 2;

this.ChartBar.ChartAreas["ChartArea1"].AxisY.LineWidth = 2;

this.ChartBar.ChartAreas["ChartArea1"].AxisY.Title = "销量";

//中间X,Y线条的颜色设置

this.ChartBar.ChartAreas["ChartArea1"].AxisX.MajorGrid.LineColor = Color.Blue;

this.ChartBar.ChartAreas["ChartArea1"].AxisY.MajorGrid.LineColor = Color.Blue;

//X.Y轴数据显示间隔

this.ChartBar.ChartAreas["ChartArea1"].AxisX.Interval = 1; //X轴数据显示间隔

this.ChartBar.ChartAreas["ChartArea1"].AxisY.Interval = 50;

//X轴线条显示间隔

this.ChartBar.ChartAreas["ChartArea1"].AxisX.MajorGrid.Interval = 1;

 

效果如下

 

 

xyz136299110
2012-07-06 · 超过60用户采纳过TA的回答
知道小有建树答主
回答量:251
采纳率:100%
帮助的人:147万
展开全部
MSCHART官方网站上有所有的例子,如果只是在webForm里写就最简单了。mvc3 razor引擎下的稍难点,其余的都挺简单的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
度娘通行证ABCD
2012-07-06
知道答主
回答量:80
采纳率:0%
帮助的人:13.2万
展开全部
高深啊,没试过
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
手机用户01728
2012-07-05 · 超过17用户采纳过TA的回答
知道答主
回答量:143
采纳率:0%
帮助的人:57.6万
展开全部
动态写x、y轴么
追问
画出来了,不过想问下高人,如何画椭圆,而且填充颜色呢?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式