ASP.NET画图全攻略(上) |
本文标签:.net ASP ASP.NET 本文代码是基于Beta2开发 传统的ASP技术是不支持画图表的,那么就不得不利用Active X或者Java applets来实现这个功能 。新近出现的ASP.NET解决了这个问题,只要利用ASP.NET中关于图形显示的类,就可以画出丰富,动态的图表 。本文将要讲述如何利用ASP.NET技术结合ADO.NET技术画条形图和饼图 。 首先建立一个c#的类库 。 curAngle = Convert.ToSingle(dt.Rows[i][1]) / sumData * 360; g.FillPie(new SolidBrush(ChartUtil.GetChartItemColor(i)),100,65,PIE_DIAMETER,PIE_DIAMETER,totalAngle,curAngle); g.DrawPie(Pens.Black,100,65,PIE_DIAMETER,PIE_DIAMETER,totalAngle,curAngle); totalAngle += curAngle; } //画图例框及其文字 g.DrawRectangle(Pens.Black,200,300,199,99); g.DrawString("Legend",new Font("Tahoma",12,FontStyle.Bold),Brushes.Black,new PointF(200,300)); //画图例各项 PointF boxOrigin = new PointF(210,330); PointF textOrigin = new PointF(235,326); float percent = 0; for(int i=0;i g.FillRectangle(new SolidBrush(ChartUtil.GetChartItemColor(i)),boxOrigin.X,boxOrigin.Y,20,10); g.DrawRectangle(Pens.Black,boxOrigin.X,boxOrigin.Y,20,10); percent = Convert.ToSingle(dt.Rows[i][1]) / sumData * 100; g.DrawString(dt.Rows[i][0].ToString() + " - " + dt.Rows[i][1].ToString() + " (" + percent.ToString("0") + "%)",new Font("Tahoma",10),Brushes.Black,textOrigin); boxOrigin.Y += 15; textOrigin.Y += 15; } //通过Response.OutputStream,将图形的内容发送到浏览器 bm.Save(target, ImageFormat.Gif); //回收资源 bm.Dispose(); g.Dispose(); } } //画条形图 public class BarChart { public BarChart() { } public void Render(string title, string subTitle, int width, int height, DataSet chartData, Stream target) { const int SIDE_LENGTH = 400; const int CHART_TOP = 75; const int CHART_HEIGHT = 200; const int CHART_LEFT = 50; const int CHART_WIDTH = 300; DataTable dt = chartData.Tables[0]; //计算最高的点 float highPoint = 0; foreach(DataRow dr in dt.Rows) { if(highPoint highPoint = Convert.ToSingle(dr[1]); } } //建立一个Graphics对象实例 Bitmap bm = new Bitmap(width,height); Graphics g = Graphics.FromImage(bm); //设置条图图形和文字属性 g.ScaleTransform((Convert.ToSingle(width))/SIDE_LENGTH,(Convert.ToSingle(height))/SIDE_LENGTH); g.SmoothingMode = SmoothingMode.Default; g.TextRenderingHint = TextRenderingHint.AntiAlias; //设定画布和边 g.Clear(Color.White); g.DrawRectangle(Pens.Black,0,0,SIDE_LENGTH-1,SIDE_LENGTH-1); //画大标题 g.DrawString(title,new Font("Tahoma",24),Brushes.Black,new PointF(5,5)); //画小标题 g.DrawString(subTitle,new Font("Tahoma",14),Brushes.Black,new PointF(7,35)); //画条形图 float barWidth = CHART_WIDTH / (dt.Rows.Count * 2); PointF barOrigin = new PointF(CHART_LEFT + (barWidth / 2),0); float barHeight = dt.Rows.Count; for(int i=0;i barHeight = Convert.ToSingle(dt.Rows[i][1]) * 200 / highPoint; barOrigin.Y = CHART_TOP + CHART_HEIGHT - barHeight; g.FillRectangle(new SolidBrush(ChartUtil.GetChartItemColor(i)),barOrigin.X,barOrigin.Y,barWidth,barHeight); barOrigin.X = barOrigin.X + (barWidth * 2); } //设置边 g.DrawLine(new Pen(Color.Black,2),new Point(CHART_LEFT,CHART_TOP),new Point(CHART_LEFT,CHART_TOP + CHART_HEIGHT)); g.DrawLine(new Pen(Color.Black,2),new Point(CHART_LEFT,CHART_TOP + CHART_HEIGHT),new Point(CHART_LEFT + CHART_WIDTH,CHART_TOP + CHART_HEIGHT)); //画图例框和文字 g.DrawRectangle(new Pen(Color.Black,1),200,300,199,99); g.DrawString("Legend",new Font("Tahoma",12,FontStyle.Bold),Brushes.Black,new PointF(200,300)); //画图例 PointF boxOrigin = new PointF(210,330); PointF textOrigin = new PointF(235,326); for(int i=0;i g.FillRectangle(new SolidBrush(ChartUtil.GetChartItemColor(i)),boxOrigin.X,boxOrigin.Y,20,10); g.DrawRectangle(Pens.Black,boxOrigin.X,boxOrigin.Y,20,10); g.DrawString(dt.Rows[i][0].ToString() + " - " + dt.Rows[i][1].ToString(),new Font("Tahoma",10),Brushes.Black,textOrigin); boxOrigin.Y += 15; textOrigin.Y += 15; } //输出图形 bm.Save(target, ImageFormat.Gif); //资源回收 bm.Dispose(); g.Dispose(); } } public class ChartUtil { public ChartUtil() { } public static Color GetChartItemColor(int itemIndex) { Color selectedColor; switch(itemIndex) { case 0: selectedColor = Color.Blue; break; case 1: selectedColor = Color.Red; break; case 2: selectedColor = Color.Yellow; break; case 3: selectedColor = Color.Purple; break; default: selectedColor = Color.Green; break; } return selectedColor; } } } 代码分析: 1.引入一些namespace 2.自定义一个namespace为Insight_cs.WebCharts,其中包括了两个类PieChart和BarChart,很清楚,class PieChart是为画饼图而建,class BarChart是为画条形图而建 。由于class PieChart和class BarChar差不多,所以下面我们以饼图为例,进行代码分析 。 3.类PieChart建立一个方法Render,此方法可以含一些参数 。简单说明如下: 4.为了增加可读性,定义一些常量: 5.定义一个DataTable,它是DataSet中的一个数据表 。其中存放了饼图的各个数据 。 6.通过计算,得出饼图中的总基数sumData 。 7.建立了一个BitMap对象,它为要创建的图形提供了内存空间 。并由此产生一个Graphics对象,它封装了GDI+画图接口 。 8.调用Graphics对象的方法ScaleTransform(),它是用来设定图形比例的 。 9.调用方法SmoothingMode(),TextRenderingHint()等来设置文字和图形的相关属性 。 10.设置画布和边 。 11.设置文字标题,图例,画饼图自身 。 12.通过Stream,将图形的内容发送到浏览器 。 |