ZedGraph是很好的.net下的统计图开源项目,在以前的一篇随笔中提到,与其他的一些统计图控件相比, ZedGraph 由于是直接在画布上作画,而不是生成图片显示,所以性能比较好,在诸如股市的实时走势图,显示 cpu 使用率等实时性较强的应用中有很好的表现,方法并不难,但是由于很少有人写这方面的文章,又正巧在其他论坛中看到有这方面的问题,所以写了下面的例子。
 
ZedGraph 在描画折线图的时候,将所有的坐标点都保存在 PointPairList 中,在画线的时候以这个为 X Y 坐标。要作动态的折线图,实际上就是不断在这个 PointPairList 中添加点坐标,然后刷新就可以了。
 
代码很简单:
Random ran = new Random();
PointPairList list = new PointPairList();
LineItem myCurve ;
Random 用来生成示例数据,也就是 Y 坐标, PointPairList 用来存放点集合。 myCarve 就是要画的线了。当然,不能忘了在窗体上添加 zedGraph 的控件。
 
为了突出效果,我们在 Form Load 事件中加上下面的代码:
this .zedGraphControl1.GraphPane.Title.Text = " 动态折线 " ;
this .zedGraphControl1.GraphPane.XAxis.Title.Text = " 时间 " ;
this .zedGraphControl1.GraphPane.YAxis.Title.Text = " 数量 " ;
this .zedGraphControl1.GraphPane.XAxis.Type = ZedGraph.AxisType.DateAsOrdinal;
                       
for (int i = 0; i <= 100; i++)
{
        double x = (double)new XDate(DateTime.Now.AddSeconds(-(100 - i)));
        double y = ran.NextDouble();
        list.Add(x, y);
}
DateTime dt = DateTime.Now;
                       
myCurve = zedGraphControl1.GraphPane.AddCurve("My Curve",
        list, Color.DarkGreen, SymbolType.None);
                       
this .zedGraphControl1.AxisChange();
this .zedGraphControl1.Refresh();
 
这样,窗体加载后就可以看到已经画出了一条折线图。可能象下面的样子:
 

但是现在,这条线现在还不会动,为了让它动起来就要定时给
PointPairList 中添加坐标。
添加一个 Timer 控件,设置 Interval 属性为 1000 ,然后在 Timer Tick 事件中添加代码:
zedGraphControl1.GraphPane.XAxis.Scale.MaxAuto = true;
double x = (double)new XDate(DateTime.Now);
double y = ran.NextDouble();
list.Add(x, y);
this .zedGraphControl1.AxisChange();
this .zedGraphControl1.Refresh();
运行,就会看到线条动起来了。
 
如果要在折线图内显示指定数量的点,只需要在添加坐标之前把第一个坐标点去掉:
if (list.Count >= 100)
{
        list.RemoveAt(0);
}
 
如果要象 windows 任务管理器中的 cpu 使用率那样,刚开始的时候是空的,随着时间的推移才逐渐画满,可以在初始化的时候填几个 Y 坐标为 0 的点:
for (int i = 0; i <= 100; i++)
{
        double x = (double)new XDate(DateTime.Now.AddSeconds(-(100 - i)));
        double y = 0 ;
        list.Add(x, y);
}
 
实际上,代码是比较简单的,关键就在于性能,在上面的代码中,在生成折线的时候使用的是 SymbolType.None ,如果使用其他几种,折点可以表示为方型,星形等图形,性能就要下降很多,例如,按照上面的代码,在我 windows2000 专业版,赛扬 1.7G 512 内存的条件下,可以显示 10000 个点,而且没有明显的停顿现象,但是如果将折点的图形设置为 SymbolType.Diamond ,例如下图这样:

在10000
个点的情况下停顿现象非常严重,实际上,不到 2000 个点就已经有明显的感觉了。同时在描线的时候没有使用抗锯齿,一样可以提高性能,不过,对性能的提升还是很有限的。
如果以股市实时走势图为例,每天 4 个小时,如果每 10 秒更新一次, 6 × 60 × 4 1440 ,可以看出 ZedGraph 完全可以适用。