Web环境下统计图表的一种生成方法

来源:岁月联盟 作者:白金牛 苗玥 李慧萍 时间:2010-07-12

【摘要】    利用Windows的图形设备接口GDI+提供的图形工具库(即System.Drawing名称空间的GDI+),将程序代码分布在Web服务器端,用户通过浏览器访问相应的网页并运行服务器端代码,动态地生成图表,然后以GIF或JPG图形的形式发送给客户端提交给用户。最后给出一个生成直条图的例子及程序代码。

【关键词】  Web; ASP.NET; GDI+; 统计图表; B/S模式

  1  引言
   
  统计图表是医学统计学中常用的一种数据表示形式, 目前有很多生成统计图表的软件,例如Microsoft Graphic、DeltaGraph、Microsoft Excel 等软件都可以很方便的生成各种统计图表,但这些软件只能应用在单机Windows桌面应用程序中。WEB环境下,这个问题就变得要复杂一些了。

  2  系统运行模式
   
  由于在Web环境下,目前广泛流行的应用系统平台模式大体上分为两种:客户机/服务器模式(Client/Server,简称C/S)和浏览器/服务器模式(Browser/Server,简称B/S)。不管使用哪一种模式,数据一般都存储在服务器上,客户端或浏览器要从服务器中提取数据,然后进行加工处理,最后把分析处理的结果显示到屏幕上。
   
  对于C/S模式,应用程序逻辑通常分布在客户和服务器两端, 客户端发出数据资源访问请求,服务器端将结果返回客户端。但C/S结构存在着很多体系结构上的问题,一旦应用的需求发生变化,客户端和服务器端的应用程序都需要进行修改,给应用维护和升级带来了极大的不便,使客户端的设置复杂化。另外,非MS Windows/IE的客户端一般难以运行,不能跨平台。
   
  而B/S模式的客户端只需要一个标准的浏览器,可以在任何地方进行操作而不用安装任何专门的客户端软件,客户端零维护,具有更大的灵活性。无论是决策层还是操作层的人员都无需培训,就可以直接使用。其次当程序功能发生变化时,无需再为每个现有的客户应用程序升级,而只需对Web服务器上的服务处理程序进行修改。这样不但可以提高运作效率,还省去了维护时协调工作的不少麻烦。因此现在的WEB应用程序开发也以B/S模式较为流行。
   
  本研究采用B/S模式,利用Web服务器上运行的服务器端代码,动态地生成图表,然后以GIF或JPG图形的形式发送给客户端。许多网站大量地运用了这一技术。注意:利用这种技术生成的图形不是把图形保存在Web服务器上,而是用户发出一个http请求时动态从服务器端运行程序代码生成。

  3  图表生成方法
   
  在ASP.NET Web应用程序中,我们可以利用ASP.NET内建的图形库GDI+(Graphic Device Interface+)绘制图表。GDI+是 GDI(Windows XP之前版本提供的图形设备接口)的后续版本。它是一种应用程序编程接口(API),负责在屏幕和打印机上显示信息,GDI+在命名空间System.Drawing中,我们可以引入该命名空间然后调用相应的作图方法生成图形。这种方法是一种较底层的方法,在ASP.NET中,利用GDI+可以创建简单的直方图、饼图和线性图,不适于创建复杂的图形。
   
  在System.Drawing命名空间中包含了创建、编辑图像的所有类。创建图像时,主要使用Bitmap类和Graphics类。为了便于理解,可以把Bitmap类想象成画板,Graphics类想象成画笔。Bitmap类主要用于创建画板以及图象创建完成后图像的保存,Graphics类主要用来绘制图像、图形和线条等。

  4  一个例子
   
  下面就以画直条图为例来说明利用这种方法绘制统计图的方法,其他统计图的绘制方法类似。
   
  例:  将某市某区某年几种主要疾病死亡专率(资料见下表)绘制成直条图。

  主要死因死亡人数死亡专率(1/10万)脑血管病806200恶性肿瘤458114心脏病35889老慢支25563肺结核17744
   
  按照上面所提及的方法,在ASP.NET环境下可以通过如下步骤绘制直条图,这里的开发工具选用的是Visual Studio.Net2003版,采用的开发语言是C#。
   
  ① 启动Visual Studio.Net2003
   
  ② 选择菜单【文件】|【新建】|【项目】后,弹出【新建项目】对话框
   
  ③ 将【项目类型】设置为【Visual C#项目】
   
  ④ 将【模板】设置为【ASP.NET Web 应用程序】
   
  ⑤ 在【位置】的文本框中输入"",然后单击【确定】按钮,这样Visual Studio.Net就会在当前项目文件所在目录中建立一个名称为"tjt"文件夹,里面存放的是此项目的项目文件,项目中的其他文件存放的位置是机Internet信息服务的默认的Web站点所在的目录中新建的一个名称为"tjt"的文件夹中。具体过程如图1所示。

  图1  新建一个ASP.NET项目对话框(略)
       
  ⑥ 在项目中添加一个Web窗体chart1.aspx,在此窗体中拖入一个Web窗体控件命令按钮,然后切换到该窗体的程序代码编辑窗口,即chart1.aspx.cs文件的编辑窗口。
   
  ⑦ 在chart1.aspx.cs文件首部,用下列代码替换chart1.aspx.cs中导入命名空间的代码:
       
  //以下命令导入命名空间
   
  using System;
   
  using System.Collections;
   
  using System.ComponentModel;
   
  using System.Data;
   
  using System.Drawing;  //导入GDI+命名空间
   
  using System.Drawing.Imaging;
   
  using System.Web;
   
  using System.Web.SessionState;
   
  using System.Web.UI;
   
  using System.Web.UI.WebControls;
   
  using System.Web.UI.HtmlControls;
   
  namespace tjt
   
  {
        
  ///


        
  /// gdili1 的摘要说明。
        
  public class chart1 : System.Web.UI.Page
         
  {
            
  protected System.Web.UI.WebControls.Button Button1;
            
  private void Button1_Click(object sender, System.EventArgs e)
            
  {
              
  const int width = 600, height = 400;
              
  Bitmap myPalette = new Bitmap(width,height);//创建600*400的画板
                    
  //创建Graphics类的实例,以便在画板上绘制图像、图形和线条。


              
  Graphics myGraphics = Graphics.FromImage(myPalette);
              
  // 绘制白色背景
              
  myGraphics.FillRectangle(new  SolidBrush(Color.White), 0, 0, width, height);
              
  //设定X轴显示数据
              
  string[] DataName = {"NXGB","EXZL","XZB","LMZ","FJH"};//分别代表脑血管病、恶性肿瘤、心脏病、老慢支、肺结核
               
  int[] Data={200,114,89,63,44};
               
  //设定显示颜色
               
  Color [] myColors = {
                      
  Color.Blue,
                      
  Color.Red,
                      
  Color.Yellow,
                      
  Color.Purple,
                      
  Color.Orange,
                      
  Color.Brown
                    
  };
                  
  myGraphics.DrawLine(new Pen(Color.Black),0,305,400,305);//绘制X轴
                  
  myGraphics.DrawLine(new Pen(Color.Black),0,0,0,305);//绘制Y轴
      
  //绘制直条图
      
  for(int i = 0;i       
  {
        
  //填充直条图
       
  myGraphics.FillRectangle(new SolidBrush(myColors[i]),(i*40)+30,300 - Data[i],20,Data[i]+5);
       
  //绘制直条图边界
       
  myGraphics.DrawRectangle(new Pen(Color.Black),(i*40)+30,300 - Data[i],20,Data[i]+5);
       
  //绘制直条图上方数据
     
  myGraphics.DrawString(Data[i].ToString(), new Font("宋体", 9), Brushes.Black, new PointF((i*40)+30,300-Data[i]-20));
       
  //绘制直条图下标
       
  myGraphics.DrawString(DataName[i], new Font("宋体", 9), Brushes.Black, new PointF((i*40)+30,320));
       
  }
       
  //输出图像
       
  myPalette.Save(Response.OutputStream, ImageFormat.Jpeg);
       
  // 清除所用绘图对象
       
  myGraphics.Dispose();
       
  myPalette.Dispose();
          
  }
         
  }
      
  }
   
  上面的步骤完成之后,对程序进行编译打包,然后发布到网上,用户便可通过浏览器进行访问了,具体说就是在相应网址下打开上面我们设计的chart1.aspx页面,点击按钮即可生成我们的直条图。
   
  实际生活中,我们需要动态生成统计图。对于这种情况,统计图要表示的数据是存储在数据库服务器中的,并且会在网上动态更新,这时我们可以通过访问数据库服务器得到数据,然后利用上面的方法生成统计图,这样生成的统计图也是动态的,具体做法笔者不再赘述。
   
  以上程序在Visual Studio.net2003环境下调试通过,并发布到了网上经过测试。

【】
    1 杨树勤, 主编. 卫生统计学. 第3版. 人民卫生出版社, 1993.

  2 刘斌, 张军, 编著. ASP.NET+SQL Server动态网站开发案例精选. 清华大学出版社, 2005.