自己写的一个asp.net的生成曲线图的过程

效果如下:
imginfo.jpg
这里是从Dataset里的数据生成曲线图.
我的Dataset是从表Sendrec里读取的数据,分别有Id,Sendid(订单号),Sendtime(记录时间),Sendnum(单位时间发送量/我这里是五分钟)几个字段

过程如下:
public void draw(Page page,DataSet ds,int Tnum){}
其中page是用来传递引用这个过程的页面,这样让页面是JPG方式直接向客户端输出生成的曲线图.
ds就是取出来的数据集了
Tnum只是我这里要用到的一个参数,不想让这个类去接触读取过程,所以把订单的总量直接取出后传递给它的.
None.gif using  System;
None.gif
using  System.Data;
None.gif
using  System.Configuration;
None.gif
using  System.Web;
None.gif
using  System.Web.Security;
None.gif
using  System.Web.UI;
None.gif
using  System.Web.UI.WebControls;
None.gif
None.gif
using  System.Web.UI.HtmlControls;
None.gif
using  System.Drawing.Drawing2D;
None.gif
using  System.Drawing.Imaging;
None.gif
using  System.Drawing;
None.gif
using  System.IO;
None.gif
None.gif
None.gif
public   class  imgdraw
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
public imgdraw()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public void draw(Page page,DataSet ds,int Tnum)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
//取得记录数量
InBlock.gif
        int count = ds.Tables[0].Rows.Count;
InBlock.gif        
//记算图表宽度
InBlock.gif
        int wd = 80 + 20 * (count - 1);
InBlock.gif        
//设置最小宽度为800
InBlock.gif
        if (wd < 800) wd = 800;
InBlock.gif        
//生成Bitmap对像
InBlock.gif
        Bitmap img=new Bitmap(wd,400);
InBlock.gif        
//生成绘图对像
InBlock.gif
        Graphics g = Graphics.FromImage(img);
InBlock.gif        
//定义黑色画笔
InBlock.gif
        Pen Bp = new Pen(Color.Black);
InBlock.gif        
//定义红色画笔
InBlock.gif
        Pen Rp = new Pen(Color.Red);
InBlock.gif        
//定义银灰色画笔
InBlock.gif
        Pen Sp = new Pen(Color.Silver);
InBlock.gif        
//定义大标题字体
InBlock.gif
        Font Bfont = new Font("Arial"12, FontStyle.Bold);
InBlock.gif        
//定义一般字体
InBlock.gif
        Font font = new Font("Arial"6);
InBlock.gif        
//定义大点的字体
InBlock.gif
        Font Tfont = new Font("Arial"9);
InBlock.gif        
//绘制底色
InBlock.gif
        g.DrawRectangle(new Pen(Color.White, 400), 00, img.Width, img.Height);
InBlock.gif        
//定义黑色过渡型笔刷
InBlock.gif
        LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(00, img.Width, img.Height), Color.Black, Color.Black, 1.2Ftrue);
InBlock.gif        
//定义蓝色过渡型笔刷
InBlock.gif
        LinearGradientBrush Bluebrush = new LinearGradientBrush(new Rectangle(00, img.Width, img.Height), Color.Blue, Color.Blue, 1.2Ftrue);
InBlock.gif        
//绘制大标题
InBlock.gif
        g.DrawString(ds.Tables[0].Rows[0]["sendid"].ToString() + "号订单发送情况曲线图", Bfont, brush, 405);
InBlock.gif        
//取得当前发送量
InBlock.gif
        int nums=0;
InBlock.gif        
for (int i = 0; i < count; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            nums
+=Convert.ToInt32(ds.Tables[0].Rows[i]["sendnum"]);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//绘制信息简报
InBlock.gif
        string info="订单发送时间:"+ds.Tables[0].Rows[0]["sendtime"].ToString()+"  曲线图生成时间:"+DateTime.Now.ToString()+"  订单总量:"+Tnum.ToString()+"  当前发送总量:"+nums.ToString();
InBlock.gif        g.DrawString(info, Tfont, Bluebrush, 
4025);
InBlock.gif        
//绘制图片边框
InBlock.gif
        g.DrawRectangle(Bp, 00, img.Width - 1, img.Height - 1);
InBlock.gif
InBlock.gif        
//绘制竖坐标线       
InBlock.gif
        for (int i = 0; i < count; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            g.DrawLine(Sp, 
40+20 * i, 6040+20 * i, 360);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//绘制时间轴坐标标签
InBlock.gif
        for (int i = 0; i < count; i+=2)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
string st = Convert.ToDateTime(ds.Tables[0].Rows[i]["sendtime"]).ToString("hh:mm");
InBlock.gif            g.DrawString(st, font, brush, 
30 + 20 * i, 370);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//绘制横坐标线
InBlock.gif
        for (int i = 0; i < 10; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            g.DrawLine(Sp, 
4060+30*i, 40+20*(count-1), 60+30*i);
InBlock.gif            
int s = 2500 - 50 * i * 5;
InBlock.gif            
//绘制发送量轴坐标标签
InBlock.gif
            g.DrawString(s.ToString(), font, brush, 1060 + 30 * i);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
InBlock.gif        
//绘制竖坐标轴
InBlock.gif
        g.DrawLine(Bp, 405540360);
InBlock.gif        
//绘制横坐标轴
InBlock.gif
        g.DrawLine(Bp, 4036045 + 20 * (count - 1), 360);
InBlock.gif
InBlock.gif        
//定义曲线转折点
InBlock.gif
        Point[] p = new Point[count];
InBlock.gif        
for (int i = 0; i < count; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            p[i].X 
= 40 + 20 * i;
InBlock.gif            p[i].Y 
= 360- Convert.ToInt32(ds.Tables[0].Rows[i]["sendnum"]) / 5*3/5;
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//绘制发送曲线
InBlock.gif
        g.DrawLines(Rp, p);
InBlock.gif
InBlock.gif        
for (int i = 0; i < count; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
//绘制发送记录点的发送量
InBlock.gif
            g.DrawString(ds.Tables[0].Rows[i]["sendnum"].ToString(), font, Bluebrush, p[i].X, p[i].Y - 10);
InBlock.gif            
//绘制发送记录点
InBlock.gif
            g.DrawRectangle(Rp, p[i].X - 1, p[i].Y - 122);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//绘制竖坐标标题
InBlock.gif
        g.DrawString("发送量", Tfont, brush, 540);
InBlock.gif        
//绘制横坐标标题
InBlock.gif
        g.DrawString("发送时间", Tfont, brush, 40385);
InBlock.gif
InBlock.gif
InBlock.gif        
//保存绘制的图片
InBlock.gif
        MemoryStream stream = new MemoryStream();
InBlock.gif        img.Save(stream, ImageFormat.Jpeg);
InBlock.gif        
//图片输出
InBlock.gif
        page.Response.Clear();
InBlock.gif        page.Response.ContentType 
= "image/jpeg";
InBlock.gif        page.Response.BinaryWrite(stream.ToArray());
InBlock.gif
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif
嘿嘿!发表这个,就是一个图片的绘制方法的记录了.这里面还有很多不当之久,望指教.

转载于:https://www.cnblogs.com/aowind/archive/2006/11/23/569536.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值