此项目源码下载地址:https://github.com/lizhiqiang0204/WpfLineChartV1.1

效果图如下:

此项目把折线图制作成了一个控件,在主界面设置好参数直接调用即可,下面是主程序片段

        public MainWindow()
{
InitializeComponent();
userControl1_Para.xGrap = ;//设置X轴相邻采集点的间隔
userControl1_Para.xGrapLable = ;//设置X轴时间标签的间隔
userControl1_Para.xGrapLablePoint = userControl1_Para.xGrapLable/ userControl1_Para.xGrap;//相邻两个时间标签内有多少个采集点
userControl1_Para.xWidth = userControl.Width - ;
userControl1_Para.yGrap = -;
userControl1_Para.yStartValue = ;
userControl1_Para.yGrapLable = ;
userControl1_Para.yLables = ((int)userControl.Height - ) / userControl1_Para.yGrapLable;
userControl.myCanvasInit(userControl1_Para); }
private void timer_Tick(object sender, EventArgs e)
{
y = y + 0.1; //随机生成Y坐标
//collectPoint.point = new Point(i, (new Random()).Next(0, 100));
collectPoint.point = new Point(x, Math.Sin(y)*+);
collectPoint.curTime = DateTime.Now;
userControl.AddPoint1(collectPoint);
}

类库添加点的函数

        public void AddPoint1(CollectPoint collectPoint)
{
x = x + userControl1_Para.xGrap;
collectPoint.point.X = x; //移动背景不移动点
double xMove = collectPoint.point.X * (-) + userControl1_Para.xWidth;
_myPolyline.Points.Add(collectPoint.point);//添加新的数据点
_myCanvas.Margin = new Thickness(xMove, , , );//设置外边距实现移动,放大缩小 //移动X轴标签背景
TextBlock xText = new TextBlock();
xText.Visibility = Visibility.Hidden;
xText.SetValue(Grid.RowProperty, ); //设置按钮所在Grid控件的行
xGrid.Children.Add(xText);//为每个点添加对应的时间值
xText.Text = collectPoint.curTime.ToString("HH:mm:ss");
xText.Margin = new Thickness(collectPoint.point.X, , , );
collectPoints.Add((new CollectPoint() { point = collectPoint.point, curTime = collectPoint.curTime }));
xLableCanvas.Margin = new Thickness(xMove, , , );//设置外边距实现移动,放大缩小 if (xMove % userControl1_Para.xGrapLable == )
xText.Visibility = Visibility.Visible; if (collectPoint.point.X > userControl1_Para.xWidth)
{
_myPolyline.Points.RemoveAt();
collectPoints.RemoveAt();
xGrid.Children.RemoveAt();
}
}

本人也是新手,代码规范写的不是很好,见谅!

WPF动态折线图的更多相关文章

  1. achartengine画出动态折线图

    achartengine画出动态折线图的效果最近有个项目需要用到实时曲线图,我也上网搜索了一下,最后还是选择使用achartengine这个现成的东西,毕竟自己再canvas一下实在是太麻烦,而且项目 ...

  2. 模拟Windows任务管理器CPU使用率的动态折线图-农夫山泉

    Delphi的TCanvas类可以实现各种复杂的图形输出功能,基于近期项目的需求,利用它实现了一个很炫的动态折线图(模拟了资源管理器中CPU使用率的折线图),可以直观地展现出数值的实时变化情况. 这段 ...

  3. 原生JS实现动态折线图

    原生JS实现动态折线图 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> & ...

  4. 开发成功-cpu-mem监控动态折线图--dom esayui js java

    jsp ------------------------------------------------------------------------------------------- ---- ...

  5. Echarts 动态折线图

    <script src="http://echarts.baidu.com/build/dist/echarts-all.js"></script>< ...

  6. WPF、Silverlight项目中使用柱状图、饼状图、折线图

    在开发的过程中,可能会遇到柱状图.饼状图.折线图来更好的显示数据,最近整理了一下,遂放出来望需要的朋友可以参考.本文仅仅是简单显示,如需复杂显示效果请参考官网代码示例.----本文代码使用WPF,Si ...

  7. PHP实现动态生成饼状图、柱状图和折线图(转载)

    PHP在图像操作方面的表现非常出色,我们只需借助可以免费得到的GD库便可以轻松实现图.表勾画.下面将分别介绍PHP实现的饼状图.折线图和柱状图以 及他们的使用方法,这几段代码的特点就是不需要再把它们复 ...

  8. ECharts使用—折线图动态加载

    最近需求中用到折线图,单线条,多线交错,之前是散点图,用的是另一个 amcharts.js,这个文档也能找的到,回归早本次重点:ECharts 一.首先引入echarts.common.min.js文 ...

  9. ECharts动态获取后台传过来的json数据进行多个折线图的显示,折线的数据由后台传过来

    ECharts 多个折线图动态获取json数据 效果图如下: 一.html部分 <p id="TwoLineChart" style="width:100%; he ...

随机推荐

  1. 清北学堂模拟赛d4t2 b

    分析:比较复杂的一题. 首先要求k个mod m互不相同且和为n的数ai,我们可以转化为求和为k个bi,并且(Σbi) % m = n % m 其中bi=ai % m,接下来可以用dp求出选了i个b,和 ...

  2. Xmemcached使用之与Spring整合

    转自:http://hi.baidu.com/tjbaso/item/22f3c32b062ebefb50fd87b8 1 简介Xmemcached是一个高性能的基于java nio的memcache ...

  3. 在centos7上安装DSPC

    感谢朋友支持本博客.欢迎共同探讨交流,因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  4. SpringMVC + hibernate 配置文件

    web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="htt ...

  5. linux 编译安装TRMPdump(libRTMP)

    需要编译libRTMP,首先需要安装配置编译环境.网上能够找到的资料多是在Windows环境编译.这里介绍一下在Linux系统中编译安装libRTMP,一来给后来者一个参考,二来也给自己做一个备忘录. ...

  6. md5的用处

    MD5保存摘要及指纹信息 md5的用处: 1.保存用户密码2.校验数据的完整性

  7. hihoCoder 简单计算器

    数据结构的入门题,理解倒是不复杂,用两个栈就行(一个存数字一个存符号).对于我这样的弱弱没事练练编码能力还是不错的. 注意运算优先级即可.(过两天回科大了,下次再做题也不知道何时,ACM生涯两铜收场o ...

  8. Django day24 cbv和APIView的源码分析 和 resful的规范

    一:cbv的源码分析 1.CBV和FBV的区别: - Class Base View   CBV(基于类的视图) - Function Base View   FBV(基于函数的视图) 2.as_vi ...

  9. C++中const用法

    1.const和指针: 如果const出现在星号左边,表示被指物是常量:如果出现在星号右边,表示指针自身是常量:如果出现在星号两边,表示被指物和指针两者都是常量. char greet[] = “He ...

  10. 基于CGAL的Delaunay三角网应用

    目录 1. 背景 1.1 CGAL 1.2 cgal-bindings(Python包) 1.3 vtk-python 1.4 PyQt5 2. 功能设计 2.1 基本目标 2.2 待实现目标 3. ...