用c#绘制曲线图

 在实际项目中我们经常需要绘制一些实时的数据图片,比如当前各公司的用水量、用电量还有播放声音视频时实时显示当前的声频等等,在我们最熟悉的任务管理器也有这么一个功能,用来表示当前CPU的使用频率,最近笔者刚刚给朋友完成了一个类似的功能图,用曲线图来实时表示一些实际数据,由于形象直观,很受客户欢迎。
不过由于某些原因,本人不能将实际项目中的代码拿出来给大家分享,只能模拟了一个简单的实现,代码没有过多优化,所以还存在很多可以优化的地方,希望有兴趣的朋友自己完善。

为了操作和应付变化,所以将绘制曲线图的功能单独封装成一个类,里面的数据完全是模拟的,在横向坐标上每个像素间隔用一个点来控制(实际中可能会加大这个距离),横向是个随机生成的数(实际开发中这应该来自我们的实时数据按比率计算得来的),显示窗体中用到了一个线程来定时绘制实时曲线。

实际代码如下:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Drawing;  
  5. using System.Drawing.Imaging;  
  6.   
  7. namespace RealtimeCurve  
  8. {  
  9.     /// <summary>  
  10.     /// 说明:实时图片生成类,在本例中横向坐标上每个像素都会有一个控制点  
  11.     /// 实际开发中可以减少控制点,比如每5个像素用一个控制点  
  12.     /// 这样的效果或许更加逼真  
  13.     /// 作者:周公  
  14.     /// 日期:2008-07-21  
  15.     /// 首发地址:<a href="http://blog.csdn.net/zhoufoxcn/archive/2008/07/21/2682027.aspx">http://blog.csdn.net/zhoufoxcn/archive/2008/07/21/2682027.aspx</a>  
  16.     /// </summary>  
  17.     public class RealTimeImageMaker  
  18.     {  
  19.         private int width;//要生成的曲线图的宽度  
  20.         private int height;//要生成的曲线图的高度  
  21.         private Point[] pointList;//用来绘制曲线图的关键点,依次将这些点连接起来即得到曲线图  
  22.         private Random random = new Random();//用于生成随机数  
  23.         private Bitmap currentImage;//当前要绘制的图片  
  24.         private Color backColor;//图片背景色  
  25.         private Color foreColor;//图片前景色  
  26.         /// <summary>  
  27.         /// 图片的高度  
  28.         /// </summary>  
  29.         public int Height  
  30.         {  
  31.             get { return height; }  
  32.             set { height = value; }  
  33.         }  
  34.       
  35.         /// <summary>  
  36.         /// 图片的宽度  
  37.         /// </summary>  
  38.         public int Width  
  39.         {  
  40.             get { return width; }  
  41.             set { width = value; }  
  42.         }  
  43.         /// <summary>  
  44.         /// 构造函数,指定生成的曲线图的宽度和高度  
  45.         /// </summary>  
  46.         /// <param name="width">要生成的曲线图的宽度  
  47.         /// <param name="height">要生成的曲线图的高度  
  48.         public RealTimeImageMaker(int width, int height):this(width,height,Color.Gray,Color.Blue)  
  49.         {  
  50.               
  51.         }  
  52.         /// <summary>  
  53.         /// 构造函数,指定生成的曲线图的宽度、高度及背景色和前景色  
  54.         /// </summary>  
  55.         /// <param name="width">要生成的曲线图的宽度  
  56.         /// <param name="height">要生成的曲线图的高度  
  57.         /// <param name="backColor">曲线图背景色  
  58.         /// <param name="foreColor">曲线图前景色  
  59.         public RealTimeImageMaker(int width, int height, Color backColor, Color foreColor)  
  60.         {  
  61.             this.width = width;  
  62.             this.height = height;  
  63.             this.backColor = backColor;  
  64.             this.foreColor = foreColor;  
  65.             pointList = new Point[width];  
  66.             Point tempPoint;  
  67.             //初始化曲线上的所有点坐标  
  68.             for (int i = 0; i < width; i++)  
  69.             {  
  70.   
  71.                 tempPoint = new Point();  
  72.                 //曲线的横坐标沿x轴依次递增,在横向位置上每个像素都有一个点  
  73.                 tempPoint.X = i;  
  74.                 //曲线上每个点的纵坐标随机生成,但保证在显示区域之内  
  75.                 tempPoint.Y = random.Next() % height;  
  76.                 pointList[i] = tempPoint;  
  77.             }  
  78.         }  
  79.         /// <summary>  
  80.         /// 获取当前依次连接曲线上每个点绘制成的曲线  
  81.         /// </summary>  
  82.         /// <returns></returns>  
  83.         public Image GetCurrentCurve()  
  84.         {  
  85.             //currentImage = historyImage.Clone(new Rectangle(1, 0, width - 1, height), PixelFormat.Format24bppRgb);  
  86.             currentImage = new Bitmap(width, height);  
  87.             Point p;  
  88.             //将当前定位曲线图的坐标点前移,并且将横坐标减1,  
  89.             //这样做的效果相当于移除当前第一个点  
  90.             for (int i = 0; i < width-1; i++)  
  91.             {  
  92.                 p = pointList[i + 1];  
  93.                 pointList[i] = new Point(p.X-1,p.Y);  
  94.             }  
  95.             Point tempPoint = new Point();  
  96.             //新生成曲线图定位点的最后一个点的坐标  
  97.             tempPoint.X = width;  
  98.             //曲线上每个点的纵坐标随机生成,但保证在显示区域之内  
  99.             tempPoint.Y = random.Next(DateTime.Now.Millisecond) % height;  
  100.             //在最后再添加一个新坐标点  
  101.             pointList[width-1]=tempPoint;  
  102.             Graphics g = Graphics.FromImage(currentImage);  
  103.             g.Clear(backColor);  
  104.             //绘制曲线图  
  105.             g.DrawLines(new Pen(foreColor), pointList);  
  106.             g.Dispose();  
  107.             return currentImage;  
  108.         }  
  109.     }  
  110. }  
窗体关键代码:
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.ComponentModel;  
  4. using System.Data;  
  5. using System.Drawing;  
  6. using System.Text;  
  7. using System.Windows.Forms;  
  8. using System.Threading;  
  9.   
  10. namespace RealtimeCurve  
  11. {  
  12.     /// <summary>  
  13.     /// 说明:显示实时曲线图的窗体  
  14.     /// 作者:周公  
  15.     /// 日期:2008-07-21  
  16.     /// 首发地址:<a href="http://blog.csdn.net/zhoufoxcn/archive/2008/07/21/2682027.aspx">http://blog.csdn.net/zhoufoxcn/archive/2008/07/21/2682027.aspx</a>  
  17.     /// </summary>  
  18.     public partial class FormRealTime : Form  
  19.     {  
  20.         Thread thread;  
  21.         RealTimeImageMaker rti;  
  22.         Color backColor = Color.Black;//指定绘制曲线图的背景色  
  23.         public FormRealTime()  
  24.         {  
  25.             InitializeComponent();  
  26.             rti = new RealTimeImageMaker(Width, Height, backColor, Color.Green);  
  27.             thread = new Thread(new ThreadStart(Run));  
  28.             thread.Start();  
  29.         }  
  30.   
  31.         private void Run()  
  32.         {  
  33.             while (true)  
  34.             {  
  35.                 Image image = rti.GetCurrentCurve();  
  36.                 Graphics g = CreateGraphics();  
  37.                 //用指定背景色清除当前窗体上的图象  
  38.                 g.Clear(backColor);  
  39.                 g.DrawImage(image, 0, 0);  
  40.                 g.Dispose();  
  41.                 //每秒钟刷新一次  
  42.                 Thread.Sleep(1000);  
  43.             }  
  44.         }  
  45.   
  46.         private void FormRealTime_FormClosing(object sender, FormClosingEventArgs e)  
  47.         {  
  48.             //在窗体即将关闭之前中止线程  
  49.             thread.Abort();  
  50.         }  
  51.     }  
  52. }  

程序最终的运行结果截图:

全部程序代码请到http://download.csdn.net/zhoufoxcn下载。

  • 8
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值