C# WinForm动态添加MSChart控件

添加mschart.dll动态链接库

添加引用

System.Windows.Forms.DataVisualization

MSChart控件作为方便的用户数据展示控件,可以方便的使用控件提供的形状和展示形式展示数据,早Web应用中用的比较多,这几天一直在做一个基于Winform的CS结构的演示程序,用到了MSChart,由于一直也不太熟悉MSChart,又是动态自定义添加,所以一点一点的摸索着做起来,动态添加自定义的MSChart到WinForm程序中,上代码:

1、创建一条曲线形式的Chart

System.Windows.Forms.DataVisualization.Charting.Chart chart1 = new System.Windows.Forms.DataVisualization.Charting.Chart();

//定义一个chart
 System.Windows.Forms.DataVisualization.Charting.ChartArea chartArea1 = new System.Windows.Forms.DataVisualization.Charting.ChartArea();

//定义一个绘图区域
 System.Windows.Forms.DataVisualization.Charting.Series series1 = new System.Windows.Forms.DataVisualization.Charting.Series();

//定义一个数据列
 chartArea1.Name = "ChartArea1";

//其实没有必要,可以使用chart1。ChartAreas[0]就可以了
 chart1.ChartAreas.Add(chartArea1);

//完成Chart和chartArea的关联
 //System.Windows.Forms.DataVisualization.Charting.Legend legend1 = new System.Windows.Forms.DataVisualization.Charting.Legend();
 //legend1.Name = "图标";
 //chart1.Legends.Add(legend1);
 chart1.Name = "chart1";
 series1.ChartType = System.Windows.Forms.DataVisualization.Charting.SeriesChartType.Spline;

//设置线性
 Random rd = new Random();
 double[] num = new double[20];

for (int i = 0; i < 20; i++)
 {
 int valuey = rd.Next(20, 100);
 DataPoint point = new DataPoint((i + 1), valuey);
 series1.Points.Add(point);
 }

//产生点的坐标
 //chart1.Titles[0].Text = "";
 
 series1.ChartArea = "ChartArea1";
 chartArea1.AxisX.Title = "日期";
 chartArea1.AxisY.Title = "值";
 chartArea1.AxisX.Interval = 1;
 chartArea1.AxisY.Interval = 5;
 chartArea1.AxisY.Minimum = 20;
 series1.Legend = "图标";
 series1.Name = "Series1";
 chart1.Text = "测试";
 chart1.Size = new System.Drawing.Size(700, 500);
 //chart1.Location = new System.Drawing.Point(50,120);
 series1.Color = Color.Blue;
 chart1.Text = "ceshi";
 //chart1.Titles[0].Text = "fff";
 chart1.Series.Add(series1);
 //这一句很重要,缺少的话绘图区域将显示空白
 //chart1.SizeChanged += new System.EventHandler(DoSizeChanged);
 //chart1.AllowDrop = true;
 chart1.BackColor = Color.FromArgb(243, 223, 193);

//设置chart背景颜色
 chartArea1.BackColor = Color.FromArgb(243, 223, 193);

//设置c绘图区域背景颜色
 series1.BorderWidth = 2;
 series1.IsValueShownAsLabel = true;

//是否显示Y的值

//this.groupBox9.Controls.Add(chart1);
 this.panel21.Controls.Add(chart1);
 chart1.Visible = true;
 //this.label10.Visible = true;
 //this.label10.Text = "【" + tn.Name + "】图";
 chart1.Titles.Add("【" + tn.Name + "】图");
 //为Chart1添加标题
 chartArea1.AxisX.IsMarginVisible = true;

//是否显示X轴两端的空白

2、在上述chart的基础上添加一条线

Control[] controls = this.groupBox9.Controls.Find("chart1",true);

//找到已经有的Chart1
 System.Windows.Forms.DataVisualization.Charting.Chart ch = (System.Windows.Forms.DataVisualization.Charting.Chart)controls[0];
 System.Windows.Forms.DataVisualization.Charting.Series series2 = new System.Windows.Forms.DataVisualization.Charting.Series();

//新定义一个数据项
 Random rd=new Random();
 for (int i = 0; i < ch.Series[0].Points.Count; i++)
 {
 int valuey=rd.Next(20,100);
 DataPoint point = new DataPoint((i + 1), valuey);
 series2.Points.Add(point);
 }
 series2.Color = Color.FromArgb(rd.Next(100, 255), rd.Next(0, 150), rd.Next(0, 255));
 series2.BorderWidth = 2;
 series2.ChartType = ((System.Windows.Forms.DataVisualization.Charting.Chart)this.panel21.Controls[0]).Series[0].ChartType;

//定义线性和原有的线条形状一致
 series2.IsValueShownAsLabel = true;
 ch.Series.Add(series2);

//添加数据列

3、减少一条曲线

Control[] controls = this.groupBox9.Controls.Find("chart1", true);
 System.Windows.Forms.DataVisualization.Charting.Chart ch = (System.Windows.Forms.DataVisualization.Charting.Chart)controls[0];
 if (ch.Series.Count>1)
 {
 //MessageBox.Show(this, "去掉一条线!", "信息提示");
 int i = ch.Series.Count - 1;
 while (i>1)
 {
 if (ch.Series[i].Points.Count>0)
 {
 break;
 }
 i -=1;
 }

ch.Series[i].Points.Clear();
 this.toolStripStatusLabel2.Text = "减少对比曲线完成!";
 }
 else
 {
 MessageBox.Show(this, "绘图区域至少要有一条线!", "信息提示");
 
 }

效果图:

C# WinForm动态添加MSChart控件

时间: 2024-08-09 16:10:18

C# WinForm动态添加MSChart控件的相关文章

js动态添加file控件

<html></head><script language="javascript" type="text/ecmascript">//======================//功能:在表单中input file控件//参数:parentID---要插入input file控件的父元素ID// inputID----input file控件的ID//======================function createI

VB动态添加WebBrowser控件,并拦截弹出窗口(不用引用任何组件)

新建空白窗体,然后粘帖下面代码: 1 Option Explicit 2 Public WithEvents br As VBControlExtender 3 4 Private Sub br_ObjectEvent(Info As EventInfo) 5 If Info.Name = "NewWindow2" Then 6 'Dim fm As New Form1 7 'fm.Show 8 'Info.EventParameters(0) = br.object ‘根据需要可实现

AngularJS:实现动态添加输入控件功能(转)

http://www.cnblogs.com/ilovewindy/p/3849428.html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="http://code.jquery.com/jquery.js"></script> <script s

easyui表单多重验证,动态设置easyui控件

要实现的功能:在做添加学生信息的时候,利用easyui的验证功能判断 学号是否重复和学号只能为数字 最终效果如下图: 但在做这个的过程中,遇到了一系列的问题: 扩展validatebox的验证方法,最开始的验证代码如下: 1 //学号格式只能为数字 ****//这里没有问题**** 2 number: {//value值为文本框中的值 3 validator: function (value) { 4 var reg = /^[0-9]*$/; 5 return reg.test(value);

asp.net动态增加服务器端控件并提交表单

为什么要用原生的呢? 1.目的 原生出现浏览器兼容性问题 极少,不用测试多浏览兼容性 .需要考虑到市面上的其他垃圾浏览器. 2.性能不好 如果不考虑第一条 你可以换一种方式 直接上代码 .aspx页面 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta http-equiv="Content-

利用MsChart控件绘制多曲线图表(转载)

在.Net4.0框架中,微软已经将Mschart控件集成了进来,以前一直在web下面用过,原来winform下的Mschart控件更加简单更加方便,今天我们用mschart绘制一个多曲线图,话不多说,直接上效果图: 发现,MsChart 的显示效果还是不错的. 代码如下,供大家参考: public partial class FrmMain : Form { public FrmMain() { InitializeComponent(); InitializeChart(); this.Loa

利用MsChart控件绘制多曲线图表

在.Net4.0框架中,微软已经将Mschart控件集成了进来,以前一直在web下面用过,原来winform下的Mschart控件更加简单更加方便,今天我们用mschart绘制一个多曲线图,发现MsChart 的显示效果还是不错的,话不多说,直接上效果图: 代码如下,供大家参考: public partial class FrmMain : Form { public FrmMain() { InitializeComponent(); InitializeChart(); this.Load

android 动态背景的实现以及SurfaceView中添加EditText控件

      首先还是一贯作风,我们先看案例: 静态图看不出来效果,如果用过此软件(扎客)的同学们都知道,她的背景会动.怎么样,是不是觉得很时尚,起码比静态的要好(个人观点).其实实现起来并 不复杂,这个如果让做游戏程序员做简直太小儿科了,这里我说明一点,其实我们做应用的也应该多少了解下游戏编程思维,起码对我们做应用有很好的帮助. 下面我简单介绍下实现方式. 实现原理:自定义一个SurfaceView控件.对之不停的onDraw,使得其背景动起来. 对于SurfaceView如果不了解的同学们麻烦

Android动态布局,并动态为TextView控件设置drawableLeft、drawableRight等属性添加图标

注:(图中每一个条目和图标都是由代码动态生成) 代码动态布局,并需要为每一个条目设置图标,此时用到了 android:drawableLeft="@drawable/icon"  父xml文件: [html] view plaincopyprint? <?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.andr