ImageVerifierCode 换一换
格式:DOCX , 页数:12 ,大小:127.61KB ,
资源ID:2475684      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/2475684.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(vsmschart 使用说明.docx)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

vsmschart 使用说明.docx

1、vsmschart 使用说明本来在考虑是否继续写图表 控件 的使用文章,毕竟,微软自带的例子已经非常详细了,花点时间参考一下基本上可以了解用法和使用特性,不过后来想想,还是写一下咯,抽出其中大家关心的内容,写出其中常用的使用方法,可以省去大家的时间,在需要深入的时候再去详细查看例子,也当是学习笔记 吧:)(BTW:我也是边学习边写的,因此,写的文章中难免有不足或失误的地方,希望各位朋友指正出来咯,大家一起提高本文中基本上只会写出最简单常用的功能,复杂的数据操作请参考微软详细的例程)一.数据源 说到绘制图表,可能很多人的第一反应除了是图表呈现的方式外,更关心的便是数据如何添加,记得在很多年前,哪

2、时要绘制一个数据曲线图,一直找不到好的呈现方式,后来使用了SVG的绘图模式,不过在添加数据的时候可谓吃尽了苦头,毕竟,SVG只是一种描述语言 ,要动态的实现一个图表的绘制,是非常困难的.对于微软的图表控件,数据添加是一件很简单的方式,它支持多种数据添加方式,如: 可以在图表的设计界面,在属性设置窗口中的Series属性下的Points中添加需要的数据. 可以在图表的设计界面中,在属性中绑定一个数据源. 可以在后台代码中,动态添加数据. 可以在后台代码中设置一个或多个数据源,直接绑定到图表中. 在此处,我只着重讲解一下第3,4两点.对于第3点,相对来说比较简单,在后台代码中,找到要添加代码的Se

3、ries,通过它下面Points的Add、AddXY、AddY等方法,即可以实现数据的添加.例如:1. double t; 2. for(t = 0; t = (2.5 * Math.PI); t += Math.PI/6) 3. 4. double ch1 = Math.Sin(t); 5. double ch2 = Math.Sin(t-Math.PI/2); 6. Chart1.SeriesChannel 1.Points.AddXY(t, ch1); 7. Chart1.SeriesChannel 2.Points.AddXY(t, ch2); 8. 复制代码 注:代码摘自微软的例子,

4、上例中,Chart1为图表的名字,Channel 1、Channel 2分别表示两个Series数据序列)二.绑定数据 先来看看图表控件都支持什么类型的数据绑定,根据官方文档的说法,只要是实现了IEnumerable接口 的数据类型,都可以绑定到图表控件中,例如:DataView, DataReader, DataSet, DataRow, DataColumn, Array, List, SqlCommand, OleDbCommand, SqlDataAdapter, 及OleDbDataAdapter对象。 对于开发来说,最常用的还是DataView、DataReader、DataSet

5、、DataRow、Array、List这几种类型了,有几点需要注意一下: 图表控件支持多数据源的绑定,例如:X轴绑定一个数据集ds1,Y轴可以绑定另一个数据集ds2,当然也可以是X轴绑定到一个List数据对象,Y轴绑定到一个DataView对象等等。 图表控件的绑定方式一般有两种,常规绑定及交差表的绑定。 图表控件的Y轴数据,支持一次绑定多个值,以绘制时间、区域、使用量等之类的图形。 绑定数据的流程如下:2008111015142478.png (44.03 K)2008-11-10 22:19:03 大意是,绑定数据里面是否有分组数据需要绑定,如果有,则调用交叉表绑定的方法。否则判断是否时绑

6、定X轴和Y轴(包括标签、超链接、图例文字等自定义属性),如果是,则调用Points.DataBind方法进行绑定操作。再判断是否有不同的X轴或Y轴数据,如果有,则分别调用X,Y轴的绑定方法 Points.DataBindX,Points.DataBindY进行数据绑定。最后,再判断是否需要进行多个Y轴值的绑定。 下面分别对几种数据绑定的方法进行一下说明:1.绑定一张数据表 绑定一张数据表,例如绑定一张普通的数据表,表数据如下:2008-11-10_214947.gif (3.24 K)2008-11-10 22:19:03绑定方法的代码:1. string mySelectQuery=SELE

7、CT Name, Sales FROM REPS; 2. OleDbConnection myConnection = new OleDbConnection(myConnectionString); 3. OleDbCommand myCommand = new OleDbCommand(mySelectQuery, myConnection); 4. myCommand.Connection.Open(); 5. OleDbDataReader myReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection); 6. C

8、hart1.DataBindTable(myReader, Name); 7. myReader.Close(); 8. myConnection.Close(); 复制代码 因为数据源中只有两列Name和Sales,因此在调用Chart1.DataBindTable方法的时候,告诉了图表X轴的名称为Name,因此自动将Sales设置为Y轴的数据了.生成的图形如下:2008111015495258.png (17.71 K)2008-11-10 22:19:03如果修改一下Sql语句为:SELECT Name,ID,RegionID FROM REPS;其它都不变化,再看看图表是如何处理另外两

9、个字段的,生成的图表如下:2008111015513437.png (16.09 K)2008-11-10 22:19:03此时,图表自动将ID,RegionID字段当成了Y值,生成了两个Series,因此每个用户都有两个值,生成的图形也有两个柱状图.上面是一种动态绑定的方式,有人可能会问了,如果我想确定我要绑定的列,比如:X轴绑定某个字段,Y轴绑定某个字段如何操作呢?对于这种绑定,有几种方法可以实现.第一种:这种方法可能是很常见的,在原来的.NET编程中出现的机率非常之高,方法如下:1. / 设置数据源,myDv是一个取出数据集的DataView 2. chart1.DataSource =

10、 myDv; 3. 4. / 分别设置图表的X值和Y值 5. chart1.SeriesSeries1.XValueMember = Name; 6. chart1.SeriesSeries1.YValueMembers = Sales; 7. 8. / 绑定设置的数据 9. chart1.DataBind(); 复制代码 第二种:即直接调用点的绑定方法1. /myReader为取得的DataReader对象 2. Chart1.SeriesSeries1.Points.DataBindXY(myReader, Name, myReader, Sales); 复制代码 第三种:调用DataBi

11、nd的方法实现1. Chart1.SeriesSeries1.Points.DataBind(myReader, Name, Sales, ); 上面几种方法得到的效果都是一样的.当然了,上面三种方法需要自己建立Series,要显示两个柱状图,像上面的例子中的图形,那么得手动建立两个Series,然后分别进行上面的绑定操作。此处说一下Label和Tooltip的绑定方式,要在绑定的图表中显示标签(Label)及提示(Tooltip),可以在绑定的时候,设置绑定的属性. 对于上面的第一、二种方法,可以调用如下的方法来设置Label和Tooltip;例如,两个数据序列名称分别为Series1和Se

12、ries2,设置代码如下:1. Chart1.SeriesSeries1.Label = #VAL; 2. Chart1.SeriesSeries1.Points.DataBind(myDs.Tables0.DefaultView, Name, ID, ); 3. Chart1.SeriesSeries2.Label = #VAL; 4. Chart1.SeriesSeries2.Points.DataBind(myDs.Tables0.DefaultView, Name, RegionID, ); 其中的#VAL是Label和Tooltip的通配符,表示取默认Y轴变量的意思。具体的详细操作可

13、以参考例程:Chart Features/Labels下面的内容。以后有空我也写一篇Label的和其它变量的设置吧。对于第三种调用的绑定则稍微不同,如下:1. Chart1.SeriesSeries1.Points.DataBind(myDs.Tables0.DefaultView, Name, ID, Label=ID,ToolTip=RegionID); 2. Chart1.SeriesSeries2.Points.DataBind(myDs.Tables0.DefaultView, Name, RegionID, Label=RegionID,ToolTip=ID); 其实就是利用第三个

14、属性,通过格式化的字符串来设置绑定属性,Label表示标签,ToolTip表示提示信息,Url表示超链接等等。最后生成的图片如下:2.绑定一个交叉表 微软的图表控件提供了一个交叉表数据的绑定方法DataBindCrossTable,它可以根据数据动态的生成数据序列(Series),借用官方的例子,数据库的表数据如下:我们先看看DataBindCrossTable的参数,它有两个重载方法,分别是:1. public void DataBindCrossTable ( 2. IEnumerable dataSource, 3. string seriesGroupByField, 4. string xField, 5. string yFields, 6. string otherFields, 7. PointSortOrder sortingOrder 8. ) 以及1. public void DataBindCrossTable ( 2. IEnumerable dataSource, 3. string seriesGroupByField, 4. string xField, 5. string yFields, 6. string otherFields 7. ) 每个参数的含义如下:dataS

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1