最近在用devexpress 第三方软件做项目。

devexpress 的控件使用简单、功能强大、类型丰富、界面优美、扩展性强。今天主要是动态生成了一条StepLine。生成后的效果(能力不强,所以做的比较简单。):

首先,建立一个form(普通的或ribbonform均可),然后拖拽一个chartControl到form中。右键run warzid。然后将预设的线条删除(因为我们要动态添加)。

然后查看form代码。在构造函数中添加方法调用InitCharControl();

然后新建InitCharControl方法,此方法主要功能是生成stepline.

代码如下:

//init ChartControl1

            //create dataTable
DataTable dt1 = new DataTable();
dt1.Columns.Add("count", typeof(long));
dt1.Columns.Add("step", typeof(string));
dt1.Columns.Add("pass", typeof(string));
for (int i = 1; i <= 4; i++)
{
DataRow dr = dt1.NewRow();
dr["count"] = i * 10;
dr["step"] = "step" + i;
dr["pass"] = "通过率:" + i * 10 + "%";
dt1.Rows.Add(dr);
} //create new series
Series series2 = new Series();
StepLineSeriesView stepLine = new StepLineSeriesView();
stepLine.LineMarkerOptions.Kind = MarkerKind.Square;
stepLine.LineMarkerOptions.Size = 50;
series2.View = stepLine; chartControl1.Series.Add(series2);

//datasource bind
chartControl1.Series[0].ArgumentDataMember = "step";
chartControl1.Series[0].ValueDataMembers.AddRange(new string[] { "count" });
chartControl1.DataSource = dt1;
int count=0;
foreach(SeriesPoint point in series2.Points )
{ SeriesPointAnchorPoint anchorPoint = new SeriesPointAnchorPoint();
anchorPoint.SeriesPoint = point; TextAnnotation txtAnnotation = new TextAnnotation();
txtAnnotation.RuntimeRotation = true;
txtAnnotation.RuntimeResizing = true;
txtAnnotation.RuntimeMoving = true;
txtAnnotation.RuntimeAnchoring = true; txtAnnotation.Text = dt1.Rows[count++]["pass"].ToString();
txtAnnotation.ShapePosition = new RelativePosition(319.97, -48);
txtAnnotation.AnchorPoint = anchorPoint; chartControl1.AnnotationRepository.Add(txtAnnotation);
}

2.添加多条stepline

对于chartControl 只有以条数据显然是没有用的。因此可能会生成多条线,供对比用。

下面我们就来看看如何生成多条setpline(本例以两条为例)

其实从上例中可以看到如何把数据源绑定到一条setpline上,当绑定两条时原理是相同的但是在绑定时就需要将数据源绑定到指定名称或索引值的setpline上。

只需要将绑定语句改写为:

chartControl1.Series[lineName].DataSource = dt1;

以下是完整代码:

     private void InitCharControl(string lineName)
{
//init ChartControl1 #region 手动添加节点、批注 #endregion
// get datatable
DataTable dt1 = InitDataTable(); //create new series
Series series2 = new Series(lineName,ViewType.StepLine);
StepLineSeriesView stepLine = new StepLineSeriesView();
stepLine.LineMarkerOptions.Kind = MarkerKind.Square;
stepLine.LineMarkerOptions.Size = 50;
series2.View = stepLine; chartControl1.Series.Add(series2); chartControl1.Series[lineName].ArgumentDataMember = "step";
chartControl1.Series[lineName].ValueDataMembers.AddRange(new string[] { "count" });
chartControl1.Series[lineName].DataSource = dt1;
int count = 0;
foreach (SeriesPoint point in chartControl1.Series[lineName].Points)
{ SeriesPointAnchorPoint anchorPoint = new SeriesPointAnchorPoint();
anchorPoint.SeriesPoint = point; TextAnnotation txtAnnotation = new TextAnnotation();
txtAnnotation.RuntimeRotation = true;
txtAnnotation.RuntimeResizing = true;
txtAnnotation.RuntimeMoving = true;
txtAnnotation.RuntimeAnchoring = true; txtAnnotation.Text = dt1.Rows[count++]["pass"].ToString();
txtAnnotation.ShapePosition = new RelativePosition(319.97, -48);
txtAnnotation.AnchorPoint = anchorPoint; chartControl1.AnnotationRepository.Add(txtAnnotation);
}
}

这样只需递归调用该方法并传递不同名字,就会生成不同的stepline啦,生成的线系统会自动用不同颜色进行区别,当然你也可以自己改造该函数在构造线时指定颜色,如果有隐藏数据需要绑定到节点上可以利用节点的tag属性进行绑定。

初识Devexpress ChartControl 之 动态添加stepline及TextAnnotation的更多相关文章

  1. DevExpress.XtraLayout.LayoutControl 动态添加控件

    // Create an item within a specified group,// bound to a specified data field with the specified edi ...

  2. 关于devexpress报表XtraReport,动态修改报表样式(.repx格式),动态添加数据并使用的理解

    一.基本概念: XtraReports 中的每个报表都由 XtraRepot 类的一个实例表示,或者由该类的子类来表示(这种情况更常见). 因此,每个报表都作为带区的容器使用,而每个带区中都包含报表控 ...

  3. DataGridview动态添加列

    1.获取数据源(select * from table名称) 2.动态绑定数据源 private void GetTableInfo(DataTable dt) { listBh = new List ...

  4. js动态添加事件-事件委托

    作者:白狼 出处:http://www.manks.top/javascript-dynamic-event.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给 ...

  5. 后台动态添加的button,如何触发button_click事件?

    后台动态添加的button,需要在Page_Load或者Page_Init重新动态生成才能执行button_click public Panel GetContrlType() { Panel pan ...

  6. jquery动态添加的html,第三方插件无法生效的情况

    今天一个问题纠结了半天,问题如下图  问题大致就是如上,新增的内容死活点不起,插件没有生效,在一个装逼前端群里面问,给我的答案是叫我去了解事件委托,了解一下事件冒泡!! 好吧,我一上午加半个下午的时间 ...

  7. 【Java EE 学习 75 下】【数据采集系统第七天】【二进制运算实现权限管理】【使用反射初始化权限表】【权限捕获拦截器动态添加权限】

    一.使用反射动态添加权限 在该系统中,我使用struts2的时候非常规范,访问的Action的形式都是"ActionClassName_MethodName.action?参数列表" ...

  8. Hadoop学习笔记—13.分布式集群中节点的动态添加与下架

    开篇:在本笔记系列的第一篇中,我们介绍了如何搭建伪分布与分布模式的Hadoop集群.现在,我们来了解一下在一个Hadoop分布式集群中,如何动态(不关机且正在运行的情况下)地添加一个Hadoop节点与 ...

  9. Net作业调度(五)—quartz.net动态添加job设计

    介绍 在实际项目使用中quartz.net中,都希望有一个管理界面可以动态添加job,而避免每次都要上线发布. 也看到有园子的同学问过.这里就介绍下实现动态添加job的几种方式, 也是二次开发的核心模 ...

随机推荐

  1. c++类模板中静态成员变量的声明定义

    我们知道,c++中,类的静态成员是要在.cpp文件中定义的,如果在.h中定义,会出现重复定义. 但是在写类模板时,一般所有的代码都是放在.h文件中的,如果要做分离是一件很麻烦的事.那如果出现了静态成员 ...

  2. c# 数据导出成excel 方法总结 见标红部分

    public void ServiceOrderExport(string data) { StringBuilder sb = new StringBuilder(); Type entityTyp ...

  3. HDOJ-1007 Quoit Design(最近点对问题)

    http://acm.hdu.edu.cn/showproblem.php?pid=1007 给出n个玩具(抽象为点)的坐标 求套圈的半径 要求最多只能套到一个玩具 实际就是要求最近的两个坐标的距离 ...

  4. C#泛型详解

    我们在编写程序时,经常遇到两个模块的功能非常相似,只是一个是处理int数据,另一个是处理string数据,或者其他自定义的数据类型,但我们没有办法,只能分别写多个方法处理每个数据类型,因为方法的参数类 ...

  5. CSS3重点总结

    CSS3重点总结(1)兄弟选择器:2种:+. ~ 1.相邻兄弟选择器(+):选择器1+选择器2 选择"选择器1"相邻的后一个兄弟"选择器2" 强调:选中的是自己 ...

  6. Android单元測试之JUnit

    随着近期几年測试方面的工作慢慢火热起来.常常看见有招聘測试project师的招聘信息.在Java中有单元測试这么一个JUnit 方式,Android眼下主要编写的语言是Java,所以在Android开 ...

  7. android卸载反馈实现

    博客原地址:http://blog.csdn.net/wang_shaner/article/details/41543787 实现原理 fork分叉函数 fork分叉(分裂)函数可以创建一个新进程, ...

  8. 引用枚举进行对比时 enum需强制转换

    枚举类 public enum MailRead { /// <summary> /// 未读 /// </summary> UNREAD=0, /// <summary ...

  9. SerialPort

    using System;   using System.Collections.Generic;   using System.ComponentModel;   using System.Data ...

  10. 使用UTL_SMTP发送中文电子邮件

    就是在原有TOM源码的基础上修改utl_smtp.write_data中,将输出内容进行一下数据转换,这样可以保证中文输出不会出现乱码 ----------------------------- cr ...