使用Chart控件进行实时监控
Chart作为微软提供绘制图表的控件,在刚开始使用时非常的迷茫,因为功能强大,涉及到的知识多,
一开始难以接收过来,但后天经过查找资料,耐心学习,终于还是有了一定的收获。
Chart相当于一个大的图纸,可以包含很多小的图纸ChartArea,一个ChartArea可以包含很多的Series,
Series即Point,画在ChartArea上的数据。
主要的思想就是添加Points的同时改变X轴的显示范围,以此来达到动态显示的目的。
代码解析:
Chart的相关设置
因为Chart控件是直接托入的,系统帮助初始化了,可以在对应的desiger.cs文件中找到。
还有事件的注册,属性等都可以在这个文件中找到。 //设置大小
MotorTestingChart.Height = 200;
MotorTestingChart.Width = 500; //设置在series上显示数值 Series是一个集合,需要有索引的方式指定
//MotorTestingChart.Series[0].IsValueShownAsLabel = true;//IsValueShowAsLable表示是否在图表的曲线上标出以标签的形式标出值 //设置Chart的边框样式
MotorTestingChart.BorderlineColor = Color.Blue;//边框颜色
MotorTestingChart.BorderlineDashStyle = ChartDashStyle.Solid;//边框的样式 Solid表示是实线
MotorTestingChart.BorderlineWidth = ;//边框的宽度 //拖入Chart控件会自带一个ChartArea
ChartArea mtxChartArea = MotorTestingChart.ChartAreas[];//获取ChartArea mtxChartArea.BackColor = Color.Lavender;//设置ChartArea的背景颜色
//X显示的最小值
mtxChartArea.AxisX.Minimum = ; //设置X轴的显示范围,在后续程序中将会用到
//X轴显示的最大值
mtxChartArea.AxisX.Maximum = ;
mtxChartArea.AxisY.Minimum = -;
mtxChartArea.AxisY.Maximum = ;
//X轴的标题
mtxChartArea.AxisX.Title = "时间";
//X轴的标题颜色
mtxChartArea.AxisX.TitleForeColor = Color.Red;
//X轴的刻度颜色
mtxChartArea.AxisX.LabelStyle.ForeColor = Color.Blue;
//指定自动轴的模式
mtxChartArea.AxisX.IntervalAutoMode = IntervalAutoMode.VariableCount;
//设置轴的间隔
//chartArea.AxisX.Interval = 1;
mtxChartArea.AxisY.Title = "数值";
mtxChartArea.AxisY.TitleForeColor = Color.Red;
mtxChartArea.AxisY.LabelStyle.ForeColor = Color.Blue; #region X和Y轴的网格线 取消网格线
mtxChartArea.AxisX.MajorGrid = new Grid() { Enabled = false };
mtxChartArea.AxisY.MajorGrid = new Grid() { Enabled = false };
#endregion
//标题
Title mtTitle = new Title();
mtTitle.Name = "mtTitle";
mtTitle.Text = "飞行姿态"; //添加标题 MyIEqualityCompare为自定义的比较类,继承自IEqualityCompare接口
if (!MotorTestingChart.Titles.Contains<Title>(mtTitle, new MyIEqualityComparer<Title>()))
{
MotorTestingChart.Titles.Add(mtTitle);
} //设置滚动条
mtxChartArea.AxisX.ScrollBar.IsPositionedInside = false;
mtxChartArea.AxisX.ScrollBar.Enabled = false;
//Legend 图例
Legend mtLegend = new Legend("mtLegend");
//mtLegend.LegendStyle = LegendStyle.Table;
mtLegend.Title = "图例";
mtLegend.ForeColor = Color.Red;
mtLegend.BackColor = Color.HotPink;
if (!MotorTestingChart.Legends.Contains<Legend>(mtLegend, new MyIEqualityComparer<Legend>()))
{
MotorTestingChart.Legends.Add(mtLegend);
} //拖入Chart控件会自带一个Series
Series mtSeries = MotorTestingChart.Series[];//获取Series
mtSeries.Legend = "mtLegend";//绑定在那个图例中显示
mtSeries.LegendText = "mtxSeries";//在图例中显示的文字
mtSeries.Color = Color.Red;//线的颜色,同时也是所画图标的颜色,绑定在一起
mtSeries.ChartType=SeriesChartType.Spline;//设置Chart类型,就是以怎样的形式画图表 mtSerise.ChartArea=MotorTestingChart.ChartArea[0];//是通过Series来绑定ChartArea的
Timer定时器
这部分的代码的写在定时器注册的函数中。 Series series = GyroscoprChart.Series[0];//获取Series series.Points.AddY(r.Next(1,100));//向Series的Points添加值 if (num0 > )//num是用来统计Series.Points的个数的,因为在Chart的设置中设置了X轴显示的范围为:0到10,
{ //所以Series的点个数大于10个之后就改变X数值的显示范围,以此来达到实时显示的目的,同时因为Series的Point的添加也是跟随定时器的
//所以它们配合的非常好
gyrChartArea.AxisX.Minimum = gyrChartcount - ;
gyrChartArea.AxisX.Maximum = gyrChartcount; }
使用Chart控件进行实时监控的更多相关文章
- winform Chart控件 获取鼠标处坐标值方法
Chart控件本身功能强大,应用广泛,因此其属性.方法也很多.此处介绍在很多应用中需要查看鼠标位置处坐标值的一些方法 1,调用Chart事件 GetToolTip 利用ToolTipEventArg ...
- 用Chart控件绘制动态图表
进行程序设计时,选用一个合适的ActiveX控件,有时可大大减少编程工作量.ActiveX 控件(又称OCX)基于COM技术,作为独立的软件模块,它可以在任何程序设计语言中插入使用.本文仅以VC++为 ...
- C# chart控件运用
为了弄一个实时数据显示的窗口,最近一周时间都耗在这个控件上了,属性有点多(下面列的是一些常用的) 后来干脆写代码把他们封装起来,各个chart直接来调用它,省得到属性里面去设置. chart内的一些元 ...
- 常量,字段,构造方法 调试 ms 源代码 一个C#二维码图片识别的Demo 近期ASP.NET问题汇总及对应的解决办法 c# chart控件柱状图,改变柱子宽度 使用C#创建Windows服务 C#服务端判断客户端socket是否已断开的方法 线程 线程池 Task .NET 单元测试的利剑——模拟框架Moq
常量,字段,构造方法 常量 1.什么是常量 常量是值从不变化的符号,在编译之前值就必须确定.编译后,常量值会保存到程序集元数据中.所以,常量必须是编译器识别的基元类型的常量,如:Boolean ...
- ASP.NET中的chart控件绑定SQL Server数据库
网上很多的chart控件的实例都没有绑定数据库,经过一番摸索后,终于实现了chart控件绑定数据库. 首先,在Visual Studio中建立一个网站,新建一个WebForm项目,名称为ChartTe ...
- C# Chart控件,chart、Series、ChartArea曲线图绘制的重要属性
http://blog.sina.com.cn/s/blog_621e24e20101cp64.html 为避免耽误不喜欢这种曲线图效果的亲们的时间,先看一下小DEMO效果图: 先简单说一下,从图中可 ...
- javascript曲线图和面积图Line & Area chart控件功能及下载
Line & Area chart 控件是一款新型的.可用性极强的曲线图和面积图产品.一个您网站的访问者可以放大他感兴趣的一段区域,打开和关闭数值气球,并可显示和隐藏图表.您能创建简单.堆积. ...
- Chart控件,把Y轴设置成百分比
这次所有属性设置都用代码(就当整理便于以后查询). 在窗体放置一个Chart控件,未做任何设置:然后编写代码: //设置 chart2.Legends[ ].Enabled = false;//不显示 ...
- C# chart控件绘制曲线
在.NET中以前经常用GDI去绘制,虽然效果也不错,自从.NET 4.0开始,专门为绘制图表而生的Chart控件出现了,有了它,就可以轻松的绘制你所需要的曲线图.柱状图什么的了. using Syst ...
随机推荐
- HDU1074 Doing Home Work - 状压dp
传送门 题目大意: 有n(\(\le 15\))个作业,每个作业有个name, deadline(截止日期),cost(做作业花的时间),如果没有按时完成某个作业,惩罚分数为超出的时间,求一个合理的顺 ...
- NOIP模拟 wall - 最大生成树
题目大意: 给出n个点,第i个点坐标是(\(x_i, y_i\)),给出m条边,第i条边的权值是\(w_i\),求将图变成一颗树所需要删除边的最小权值和. 题目分析: 首先要看出坐标其实是出题人使出的 ...
- 电子商务系统的设计与实现(十三):分页组件,从前到后,从JS到Java
一.概述 学习实践Web开发5年多了,直到今天,我才算真正实现了最基本最常用的分页组件. 包括: a.前端JS异步加载并渲染: b.前端JSP.Freemarker.Struts标签渲 ...
- 【p094】道路游戏
Time Limit: 1 second Memory Limit: 128 MB [问题描述] 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有n个机器人工厂,两个相邻机器人工厂之间由 ...
- MIPS重返硅谷 放眼AI未来
MIPS最近以一家独立公司之姿重新回到了矽谷,在Tallwood的带领下积极投入原有的嵌入式业务,并放眼下一代人工智能(AI)领域. MIPS最近以一家独立公司之姿重新回到了矽谷——加州圣塔克拉拉 ...
- 单核、多线程与时间片,以Node.js为例
去年写了篇文章<线程与进程的理解>,当时认为线程和CPU的单核多核无关,操作系统可以有很多个线程.但今天看<深入浅出Node.js>一书时,多次提到单线程无法利用多核CPU一类 ...
- PAT 1041-1050 题解
浏览全部代码:请戳 本文谨代表个人思路,欢迎讨论;) 1041. Be Unique (20) 题意 给出 N (<=105)个数(数值范围为 [1, 104]),找到其中不重复的第一个数字.比 ...
- Android开发之 shape的使用
android shape的使用 shape用于设定形状,能够在selector,layout等里面使用,有6个子标签,各属性例如以下: <?xml version="1.0" ...
- 学习Hadoop和Spark的好的资源
1. 官网http://spark.apache.org 有各种资源链接: 2. 总结得很好的个人博客[从零开始学Hadoop系列]1)初识http://blog.csdn.net/u01016816 ...
- eclipes中配置javadoc文档