在做项目时要对数据进行统计分析,所以必须生成一些报表统计图(如柱形图、饼图、曲线图等),网上强烈推荐了使用DotNetCharting控件来实现,于是自己对DotNetCharting控件进行了简单的学习,下面先简单介绍一下DotNetCharting控件及其使用。

DotNetCharting是一个非常棒的.NET图表控件,对中文支持非常好,而且操作方便,开发快速,既有for webform 也有for winform的,而且.net1.1和2.0都有支持。它的官方地址是http://www.dotnetcharting.com/

本站也提供了DotNetCharting破解版本下载: http://files.cnblogs.com/dreamof/dotnetcharting.rar
    强烈推荐一下DotNetCharting的demo地址:
    这个是所有的 DEMO 演示  http://www.dotnetcharting.com/demo.aspx
    这个是 Online Documentation http://www.dotnetcharting.com/documentation/v4_4/webframe.html 里面会有详细的说明和用法。

DotNetCharting的简单使用方法:
    1.把/bin/dotnetCHARTING.dll添加到工具箱,并且添加引用;

2.把控件拖到你的网页上,然后添加引用using dotnetCHARTING;就可以用了;

3.接下来是自己写的对DotNetCharting操作的封装类,以便于在程序里调用。

  1. ShowData.cs
  2. using System;
  3. using System.Data;
  4. using System.Text;
  5. using dotnetCHARTING;
  6. namespace FLX.ComplexQuery
  7. {
  8. /**//// <summary>
  9. /// 彭建军
  10. /// 根据数据动态生成图形(柱形图、饼图、曲线图)
  11. /// 2008-06-19
  12. /// </summary>
  13. public class ShowData
  14. {
  15. 属性#region 属性
  16. private string _phaysicalimagepath;//图片存放路径
  17. private string _title; //图片标题
  18. private string _xtitle;//图片x座标名称
  19. private string _ytitle;//图片y座标名称
  20. private string _seriesname;//图例名称
  21. private int _picwidth;//图片宽度
  22. private int _pichight;//图片高度
  23. private DataTable _dt;//图片数据源
  24. /**//// <summary>
  25. /// 图片存放路径
  26. /// </summary>
  27. public string PhaysicalImagePath
  28. {
  29. set{_phaysicalimagepath=value;}
  30. get{return _phaysicalimagepath;}
  31. }
  32. /**//// <summary>
  33. /// 图片标题
  34. /// </summary>
  35. public string Title
  36. {
  37. set{_title=value;}
  38. get{return _title;}
  39. }
  40. /**//// <summary>
  41. /// 图片标题
  42. /// </summary>
  43. public string XTitle
  44. {
  45. set{_xtitle=value;}
  46. get{return _xtitle;}
  47. }
  48. /**//// <summary>
  49. /// 图片标题
  50. /// </summary>
  51. public string YTitle
  52. {
  53. set{_ytitle=value;}
  54. get{return _ytitle;}
  55. }
  56. /**//// <summary>
  57. /// 图例名称
  58. /// </summary>
  59. public string SeriesName
  60. {
  61. set{_seriesname=value;}
  62. get{return _seriesname;}
  63. }
  64. /**//// <summary>
  65. /// 图片宽度
  66. /// </summary>
  67. public int PicWidth
  68. {
  69. set{_picwidth=value;}
  70. get{return _picwidth;}
  71. }
  72. /**//// <summary>
  73. /// 图片高度
  74. /// </summary>
  75. public int PicHight
  76. {
  77. set{_pichight=value;}
  78. get{return _pichight;}
  79. }
  80. /**//// <summary>
  81. /// 图片数据源
  82. /// </summary>
  83. public DataTable DataSource
  84. {
  85. set{_dt=value; }
  86. get{return _dt;}
  87. }
  88. #endregion
  89. 构造函数#region 构造函数
  90. public ShowData()
  91. {
  92. //
  93. // TODO: 在此处添加构造函数逻辑
  94. //
  95. }
  96. public ShowData(string PhaysicalImagePath,string Title,string XTitle,string YTitle,string SeriesName)
  97. {
  98. _phaysicalimagepath=PhaysicalImagePath;
  99. _title=Title;
  100. _xtitle=XTitle;
  101. _ytitle=YTitle;
  102. _seriesname=SeriesName;
  103. }
  104. #endregion
  105. 输出柱形图#region 输出柱形图
  106. /**//// <summary>
  107. /// 柱形图
  108. /// </summary>
  109. /// <returns></returns>
  110. public void CreateColumn(dotnetCHARTING.Chart chart)
  111. {
  112. chart.Title=this._title;
  113. chart.XAxis.Label.Text=this._xtitle;
  114. chart.YAxis.Label.Text=this._ytitle;
  115. chart.TempDirectory =this._phaysicalimagepath;
  116. chart.Width = this._picwidth;
  117. chart.Height = this._pichight;
  118. chart.Type = ChartType.Combo ;
  119. chart.Series.Type =SeriesType.Cylinder;
  120. chart.Series.Name = this._seriesname;
  121. chart.Series.Data = this._dt;
  122. chart.SeriesCollection.Add();
  123. chart.DefaultSeries.DefaultElement.ShowValue = true;
  124. chart.ShadingEffect = true;
  125. chart.Use3D = false;
  126. chart.Series.DefaultElement.ShowValue =true;
  127. }
  128. #endregion
  129. 输出饼图#region 输出饼图
  130. /**//// <summary>
  131. /// 饼图
  132. /// </summary>
  133. /// <returns></returns>
  134. public void CreatePie(dotnetCHARTING.Chart chart)
  135. {
  136. chart.Title=this._title;
  137. chart.TempDirectory =this._phaysicalimagepath;
  138. chart.Width = this._picwidth;
  139. chart.Height = this._pichight;
  140. chart.Type = ChartType.Pie;
  141. chart.Series.Type =SeriesType.Cylinder;
  142. chart.Series.Name = this._seriesname;
  143. chart.ShadingEffect = true;
  144. chart.Use3D = false;
  145. chart.DefaultSeries.DefaultElement.Transparency = 20;
  146. chart.DefaultSeries.DefaultElement.ShowValue = true;
  147. chart.PieLabelMode = PieLabelMode.Outside;
  148. chart.SeriesCollection.Add(getArrayData());
  149. chart.Series.DefaultElement.ShowValue = true; 
  150. }
  151. private SeriesCollection getArrayData()        
  152. {
  153. SeriesCollection SC = new SeriesCollection();
  154. DataTable dt = this._dt;
  155. for(int i=0; i < dt.Rows.Count; i++)
  156. {
  157. Series s = new Series();
  158. s.Name = dt.Rows[i][0].ToString();
  159. Element e = new Element();
  160. // 每元素的名称
  161. e.Name = dt.Rows[i][0].ToString();
  162. // 每元素的大小数值
  163. e.YValue=Convert.ToInt32(dt.Rows[i][1].ToString());
  164.           
  165. s.Elements.Add(e);
  166. SC.Add(s);
  167. }
  168. return SC;
  169. }
  170. #endregion
  171. 输出曲线图#region 输出曲线图
  172. /**//// <summary>
  173. /// 曲线图
  174. /// </summary>
  175. /// <returns></returns>
  176. public void CreateLine(dotnetCHARTING.Chart chart)
  177. {
  178. chart.Title=this._title;
  179. chart.XAxis.Label.Text=this._xtitle;
  180. chart.YAxis.Label.Text=this._ytitle;
  181. chart.TempDirectory =this._phaysicalimagepath;
  182. chart.Width = this._picwidth;
  183. chart.Height = this._pichight;
  184. chart.Type = ChartType.Combo ;
  185. chart.Series.Type =SeriesType.Line;
  186. chart.Series.Name = this._seriesname;
  187. chart.Series.Data = this._dt;
  188. chart.SeriesCollection.Add();
  189. chart.DefaultSeries.DefaultElement.ShowValue = true;
  190. chart.ShadingEffect = true;
  191. chart.Use3D = false;
  192. chart.Series.DefaultElement.ShowValue =true;
  193. }
  194. #endregion
  195. 调用说明及范例#region 调用说明及范例
  196. //        在要显示统计图的页面代码直接调用,方法类似如下:
  197. //
  198. //        ShowData show=new ShowData();
  199. //        show.Title ="2008年各月消费情况统计";
  200. //        show.XTitle ="月份";
  201. //        show.YTitle ="金额(万元)";
  202. //        show.PicHight =300;
  203. //        show.PicWidth =600;
  204. //        show.SeriesName ="具体详情";
  205. //        show.PhaysicalImagePath ="ChartImages";
  206. //        show.DataSource =this.GetDataSource();
  207. //        show.CreateColumn(this.Chart1);
  208. #endregion
  209. }
  210. }

效果图展示:

补充:
    帖子发了一天,没人回答我多维统计图的实现方式,只好自己去dotnetcharting的官方网站下载了最新的dotnetcharting控件,在 dotnetcharting控件的使用说明文档中详细地介绍了各种多维统计图的实现方式。现把说明文档贴出来供大家下载
    dotnetcharting使用说明文档

追加补充新内容:
     1、解决“每运行一次DotNetCharting页面,就会生成一个图片,这样图片不是越来越多吗?请问怎样自动删除DotNetCharting生成的图片呢”的问题,参照asp.net删除文件夹里的所有文件 。

2、解决“(1)生成的图片带超链接导向官网,如何处理呀?(2)我使用这个控件后,图形可以显示出来。但是发现一个小问题。就是在图形的左上方和图形的下面都隐含了超链接,鼠标移动到这两个区域后,点击都会链接到http://www.dotnetcharting.com/。很奇怪,这是和破解有管吗?”等类似的问题,参照DotnetCharting控件各版本破解方法 。

C#.net使用DotNetCharting控件生成报表统计图的更多相关文章

  1. .net使用DotNetCharting控件生成报表统计图总结

    最近在做项目时要对数据进行统计分析,所以必须生成一些报表统计图(如柱形图.饼图.曲线图等),网上强烈推荐了使用DotNetCharting控件来实现,于是自己对DotNetCharting控件进行了简 ...

  2. 双缓冲绘图和窗口控件的绘制——ATL ActiveX 窗口控件生成向导绘制代码OnDraw的一个错误 .

    双缓冲绘图和窗口控件的绘制 ---ATL ActiveX 窗口控件生成向导绘制代码OnDraw的一个错误 cheungmine 我们通常使用ATL COM组件,生成一个带窗口的ActiveX控件,然后 ...

  3. 由Asp.Net客户端控件生成的服务器端控件

    由Asp.Net客户端控件生成的服务器端控件(也就是给客户端控件添加 runnat="server"),这样的控件既能在js中通过id命.类名获取到,也能在服务器端根据id获取到

  4. 告别.NET生成报表统计图的烦恼

    告别.NET生成报表统计图的烦恼 标签: 报表.netstatistics图形数据库文档 2009-10-09 12:00 635人阅读 评论(0) 收藏 举报  分类: .net程序设计(C#)(2 ...

  5. SSRS报表服务随笔(rdl报表服务)-报表数据:使用第三方控件生成条形码

    因为工作需要,需要将订单号显示成条形码,比如数据库存储的20190106A,我需要把这个转换为Code128来显示出来 在国内我没有找到这方面的教程,最后还是一个人自己摸索出来的 在这里我是使用的是B ...

  6. UniGui中使用Grid++Report报表控件子报表获取数据的方法

    Grid++Report是为优秀的报表控件,子报表是其重要功能之一,但Grid++Report提供的网页报表示范主要是以页面为主的,UniGui在Delphi中以快速编写web管理软件著称,但由于资料 ...

  7. ActiveReports 9 新功能:借助目录(TOC)控件为报表添加目录功能

    在最新发布的ActiveReports 9报表控件中添加了多项新功能,以帮助你在更短的时间里创建外观绚丽.功能强大的报表系统,本文将重点介绍新增文档目录控件(TOC),通过拖拽操作便可添加报表目录. ...

  8. ZedGraph控件生成饼图、拆线图和柱状图例程

    这几天做了个自己觉得还蛮NB的功能,在GRID中选中一块数据,然后右键菜单即可生成三种图形,还可以互相切换,对了,饼图还添加了鼠标点击分离的处理,大致如图: 用的控件就是ZedGraph,我把它继承封 ...

  9. 葡萄城公布新版ActiveReports 9报表控件和报表server

    2014年11月10日---葡萄城宣布正式公布ActiveReports9,包含了三种报表模型:RDL报表.页面报表.区域报表.对于ActiveReports中的这个最新版本号中,我们专注于提高产品的 ...

随机推荐

  1. 小白的CTF学习之路1——程序与CPU

    刚刚注册了这个博客园,尽量保持每日一更(*/ω\*) 今天看了po学院的教学视频,了解了程序是什么,如何在CPU当中工作的等各种之前未曾想过的问题,特此记录,以防忘记 首先我们学习程序与CPU之前需要 ...

  2. 项目部署到服务器上之后request.getRemoteAddr()为什么获取的都是本地地址

    获取客户端的IP地址的方法是:request.getRemoteAddr(),这种方法在大部分情况下都是有效的.但是在通过了Apache,Squid等反向代理软件就不能获取到客户端的真实IP地址了.如 ...

  3. ActiveMQ_2安装

    Linux安装 环境JDK7以上 gz文件拷贝到 /usr/local/目录下 解压 后缀为 .tar.gz的压缩包 进入解压后的文件夹 cd apache-activemq-x.xx.x/ cd b ...

  4. Oracle数据库查询基本数据

    ------------------------------------------------------------------找出EMP表select * from EMP;--选择在部门30中 ...

  5. RunC容器逃逸漏洞席卷业界,网易云如何做到实力修复?

    近日,业界爆出的runC容器越权逃逸漏洞CVE-2019-5736,席卷了整个基于runC的容器云领域,大量云计算厂商和采用容器云的企业受到影响.网易云方面透露,经过技术团队的紧急应对,网易云上的容器 ...

  6. PHP中url相关函数

    1,string urlencode(string $str)/string urldecode(string $str) urlencode将中文以及特殊字符转化为16进制,然后在每个字符前面加%: ...

  7. 微信开发-PC调试-JS-SDK功能之分享功能调试

    一般涉及和第三方的开发调试,都会比较麻烦些.不过,像微信这样的大公司呢,产品技术是过硬的,所以,基本上只要自己把文档看仔细了,弄好了,基本就没有问题了. 对于后端接口一类的调试,主要就是通过打印访问日 ...

  8. keepalived-1

    keepalived所执行的外部脚本命令建议使用绝对路径 vrrp 广播 keepalived的主要功能 1,管理LVS负载均衡软件 2,对LVS集群节点健康检查功能.Healthcheck 3,

  9. Jmeter HTTP请求后响应数据显示乱码解决方法

    Jmeter请求后结果树里无论是text还是html响应数据显示乱码,这是因为jmeter 编码格式配置文件默认不开启导致的,解决方法如下: 1)进入jmeter-***\bin目录下,找到jmete ...

  10. 机器学习技法笔记:15 Matrix Factorization

    Roadmap Linear Network Hypothesis Basic Matrix Factorization Stochastic Gradient Descent Summary of ...