| huwlnew |
2010-05-06 13:24 |
基本的数据绑定 一.数据源
说到绘制图表,可能很多人的第一反应除了是图表呈现的方式外,更关心的便是数据如何添加,记得在很多年前,哪时要绘制一个数据曲线图,一直找不到好的呈现方式,后来使用了SVG的绘图模式,不过在添加数据的时候可谓吃尽了苦头,毕竟,SVG只是一种描述语言,要动态的实现一个图表的绘制,是非常困难的.对于微软的图表控件,数据添加是一件很简单的方式,它支持多种数据添加方式,如:
- 可以在图表的设计界面,在属性设置窗口中的Series属性下的Points中添加需要的数据.
- 可以在图表的设计界面中,在属性中绑定一个数据源.
- 可以在后台代码中,动态添加数据.
- 可以在后台代码中设置一个或多个数据源,直接绑定到图表中.
在此处,我只着重讲解一下第3,4两点.对于第3点,相对来说比较简单,在后台代码中,找到要添加代码的Series,通过它下面Points的Add、AddXY、AddY等方法,即可以实现数据的添加.例如: [pre]![微软图形控件安装使用[转] 微软图形控件安装使用[转]](/default/index/img?u=L2RlZmF1bHQvaW5kZXgvaW1nP3U9YUhSMGNITTZMeTkzZDNjdVkyNWliRzluY3k1amIyMHZTVzFoWjJWekwwOTFkR3hwYm1sdVowbHVaR2xqWVhSdmNuTXZRMjl1ZEhKaFkzUmxaRUpzYjJOckxtZHBaZz09) Code
Code highlighting produced by Actipro CodeHighlighter (freeware)
图表控件支持多数据源的绑定,例如:X轴绑定一个数据集ds1,Y轴可以绑定另一个数据集ds2,当然也可以是X轴绑定到一个List数据对象,Y轴绑定到一个DataView对象等等。
图表控件的绑定方式一般有两种,常规绑定及交差表的绑定。
图表控件的Y轴数据,支持一次绑定多个值,以绘制时间、区域、使用量等之类的图形。
绑定数据的流程如下:
![微软图形控件安装使用[转] 微软图形控件安装使用[转]](/default/index/img?u=L2RlZmF1bHQvaW5kZXgvaW1nP3U9YUhSMGNITTZMeTl3YVdNd01ESXVZMjVpYkc5bmN5NWpiMjB2YVcxbkwzTm9kVzVqZVM4eU1EQTRNVEV2TWpBd09ERXhNVEF4TlRFME1qUTNPQzV3Ym1jPQ==) 大意是,绑定数据里面是否有分组数据需要绑定,如果有,则调用交叉表绑定的方法。否则判断是否时绑定X轴和Y轴(包括标签、超链接、图例文字等自定义属性),如果是,则调用Points.DataBind方法进行绑定操作。再判断是否有不同的X轴或Y轴数据,如果有,则分别调用X,Y轴的绑定方法Points.DataBindX,Points.DataBindY进行数据绑定。最后,再判断是否需要进行多个Y轴值的绑定。 下面分别对几种数据绑定的方法进行一下说明: 1.绑定一张数据表 绑定一张数据表,例如绑定一张普通的数据表,表数据如下: REPS
绑定方法的代码: [pre]![微软图形控件安装使用[转] 微软图形控件安装使用[转]](/default/index/img?u=L2RlZmF1bHQvaW5kZXgvaW1nP3U9YUhSMGNITTZMeTkzZDNjdVkyNWliRzluY3k1amIyMHZTVzFoWjJWekwwOTFkR3hwYm1sdVowbHVaR2xqWVhSdmNuTXZRMjl1ZEhKaFkzUmxaRUpzYjJOckxtZHBaZz09) Code
Code highlighting produced by Actipro CodeHighlighter (freeware) REPSALES
我们先看看DataBindCrossTable的参数,它有两个重载方法,分别是: public void DataBindCrossTable ( IEnumerable dataSource, string seriesGroupByField, string xField, string yFields, string otherFields, PointSortOrder sortingOrder ) 以及 public void DataBindCrossTable ( IEnumerable dataSource, string seriesGroupByField, string xField, string yFields, string otherFields ) 每个参数的含义如下: dataSource 要绑定的数据源. seriesGroupByField 要分组统计的数据字段名称,例如按姓名、日期等. xField X轴绑定的字段名称. yFields Y轴绑定的字段名称,如果需要绑定多个字段,则用逗号将字段名分开. otherFields 其它数据字段属性,就是上面刚讲的,标签、提示、Url等属性. sortingOrder 设置数据是正确还是逆序排列. 此时要以统计每个用户的年销售曲线,那么分组统计的字段名应该设置为Name,如下: [pre]![微软图形控件安装使用[转] 微软图形控件安装使用[转]](/default/index/img?u=L2RlZmF1bHQvaW5kZXgvaW1nP3U9YUhSMGNITTZMeTkzZDNjdVkyNWliRzluY3k1amIyMHZTVzFoWjJWekwwOTFkR3hwYm1sdVowbHVaR2xqWVhSdmNuTXZRMjl1ZEhKaFkzUmxaRUpzYjJOckxtZHBaZz09) Code
Code highlighting produced by Actipro CodeHighlighter (freeware)
在进行Y轴数据绑定的时候,如果要绑定多个字段,默认情况会出错,那是因为需要设置Y轴的可保存值数量,设置为你需要保存的数量即可,设置的地点在:Series-》YValuesPrePoint,设置为你需要显示的个数即可。
在进行DataTable绑定的时候,Label、ToolTip等属性的字段格式化比较困难(otherFields 属性),我试了半天,也就试出了一次只能绑定一个字段,因为是和数据集绑定,如果要在标签上增加文字的话,可以使用:Field{xxxx#xxxx},其中#会替换为相应的文字,例如:Field的值为45,那么最后的呈现的结果就是:xxxx45XXXX.
|
|