在ASP.NET页面中实现数据棒图

 
using  System;
using  System.Collections;
using  System.ComponentModel;
using  System.Data;
using  System.Drawing;
using  System.Web;
using  System.Web.SessionState;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.HtmlControls;
using  System.Data.SqlClient;
using  System.Drawing.Imaging;

namespace  Bar
{
    
/// <summary>
    
/// WebForm1 的摘要说明。
    
/// </summary>

    public class WebForm1 : System.Web.UI.Page
    
{

        
private void Page_Load(object sender, System.EventArgs e)
        
{
            
// 在此处放置用户代码以初始化页面
             string STR="server=.;uid=sa;pwd=sa;database=DBTest";
            
//获得当前Access数据库在服务器端的绝对路径
            SqlConnection conn=new SqlConnection(STR);
            conn.Open();
            SqlCommand cmd
=conn.CreateCommand();
            cmd.CommandText
="SELECT YF ,SL FROM Table01 ORDER BY YF" ;
            SqlDataReader reader
=cmd.ExecuteReader();
            
//创建OleDbDataReader实例,并以此实例来获取数据库中各条记录数据
            int[] iXiaoSH = new int[12];
            
//定义一个数组,用以存放从数据库中读取的销售数据
            string[] sMoth = new string[12];
            
//定义一个数组,用以存放从数据库中读取的销售月份
            int iIndex = 0;
            
while (reader.Read())
            
{
                iXiaoSH[iIndex] 
= reader.GetInt32(1);
                sMoth[iIndex] 
= reader.GetInt32(0).ToString() + "";
                iIndex
++;
            }

            
//读取Table01数据表中的各条数据,并存放在先前定义的二个数组中
            conn.Close();
            reader.Close();
            
//关闭各种资源
            Bitmap bm = new Bitmap(600250);
            
//创建一个长度为600,宽带为250的Bitmap实例
            Graphics g;
            g 
= Graphics.FromImage(bm);
            
//由此Bitmap实例创建Graphic实例
            g.Clear(Color.Snow);
            
//用Snow色彩为背景色填充此绘画图面
            g.DrawString(" 天天公司2008年度销售情况一览表"new Font("宋体"16), Brushes.Black, new Point(55));
            
//在绘画图面的指定位置,以指定的字体、指定的颜色绘制指定的字符串。即为图表标题
            
//以下代码是是实现图01中的右上部
            Point myRec = new Point(53530);
            Point myDec 
= new Point(56026);
            
//以上是在图01中为下面绘制定位
            g.DrawString("单位:万套"new Font("宋体"9), Brushes.Black, new Point(52512));
            
for (int i = 0; i < sMoth.Length; i++)
            
{
                g.DrawRectangle(Pens.Black, myRec.X, myRec.Y, 
2010);
                
//绘制小方块
                g.FillRectangle(new SolidBrush(GetColor(i)), myRec.X, myRec.Y, 2010);
                
//填充小方块
                g.DrawString(sMoth[i].ToString(), new Font("宋体"9), Brushes.Black, myDec);
                
//绘制小方块右边的文字
                myRec.Y += 15;
                myDec.Y 
+= 15;
            }

            
//以下代码是绘制图01中的Bar图,及其销售数量
            int iBarWidth = 40;
            
int scale = 10;
            
for (int i = 0; i < iXiaoSH.Length; i++)
            
{
                g.DrawRectangle(Pens.Black, (i 
* iBarWidth) + 15250 - (iXiaoSH[i] * scale), 20, (iXiaoSH[i] * scale) + 5);
                
//绘制Bar图
                g.FillRectangle(new SolidBrush(GetColor(i)), (i * iBarWidth) + 15250 - (iXiaoSH[i] * scale), 20, (iXiaoSH[i] * scale) + 5);
                
//以指定的色彩填充Bar图
                g.DrawString(iXiaoSH[i].ToString(), new Font("宋体"9), Brushes.Black, (i * iBarWidth) + 20235 - (iXiaoSH[i] * scale));
                
//显示Bar图代表的数据
            }

            
//以下代码是绘制图01中的边框,并形成Jpeg文件,供浏览器显示出来
            Pen p = new Pen(Color.Black, 2);
            g.DrawRectangle(p, 
11598248);
            Response.ContentType
="image/Jpeg";
            bm.Save(Response.OutputStream, ImageFormat.Jpeg);
        }



        
private Color GetColor ( int itemIndex ) 
        
{
         Color MyColor ;
         
int i = itemIndex ;
            
switch(i)
            
{
                
case 0:
                    MyColor
=Color.Coral;
                    
return MyColor;
                
case 1 :
                 MyColor 
= Color.Red ;
                  
return MyColor ;
                
case 2 :
                 MyColor 
= Color.Cornsilk ;
                  
return MyColor ;
                
case 3 :
                 MyColor 
= Color.DarkGreen ;
                  
return MyColor ;
                
case 4 :
                 MyColor 
= Color.Crimson ;
                  
return MyColor ;
         
                
case 5 :
                 MyColor 
= Color.Coral  ;
                  
return MyColor ;
         
                
case 6 :
                 MyColor 
= Color.Gray  ;
                  
return MyColor ;
         
                
case 7 :
                 MyColor 
= Color.BurlyWood ;
                  
return MyColor ;

                
case 8 :
                 MyColor 
= Color.Maroon  ;
                  
return MyColor ;

                
case 9 :
                 MyColor 
= Color.Azure  ;
                  
return MyColor ;

                
case 10 :
                 MyColor 
= Color.AliceBlue  ;
                  
return MyColor ;

                
case 11 :
                 MyColor 
= Color.Bisque  ;
                  
return MyColor ;

                
case 12 :
                 MyColor 
= Color.Chartreuse  ;
                  
return MyColor ;
                
default:
                 MyColor 
= Color.Green;
                 
return MyColor ;
            }

        }
 

        
Web 窗体设计器生成的代码
    }


    

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Career(IT)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值