C#实现绘制面形图表的方法详解

时间:2021-05-20

本例详细讲述了C#实现的面形图绘制例子,这是其中一个核心绘制文件的代码,代码中的里面的注释很多,也比较详细,相信对于初学者学习及理解C#图形绘制方面的技术要点、难点有所帮助。

C#绘制面形图的主要功能代码如下:

using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.IO;namespace 绘制面形图{ public partial class Form1 : Form { public Form1() { InitializeComponent(); } Graphics g;//创建Graphics对象 private void button1_Click(object sender, EventArgs e) { Bitmap bt = new Bitmap(panel1.Width, panel1.Height);//实例化一个Bitmap对象 int flag = (panel1.Width-4 )/ 6;//X轴的增值 g = Graphics.FromImage(bt);//实例化Graphics对象 Pen p = new Pen(Color.Black, 1);//设置Pen对象 g.DrawLine(p, new Point(0, 0), new Point(0, panel1.Height-20));//绘制Y轴 g.DrawLine(p, new Point(0, panel1.Height - 20), new Point(panel1.Width - 4, panel1.Height - 20));//绘制X轴 //声明一个用于绘制颜色的数组 Color[] cl = new Color[] { Color.Red, Color.Blue, Color.YellowGreen, Color.Yellow, Color.RoyalBlue, Color.Violet, Color .Tomato}; int[] points = { 20,70,80,60,40,100,10};//声明一个计算走势峰值的数组 Point pt1 = new Point(0, panel1.Height - 20 - points[0]);//记录绘制四边形的第一个点 Point pt2 = new Point(0, panel1.Height - 20);//记录绘制四边形的第二个点 for (int i = 0; i <= 6; i++)//通过for循环绘制月份和面形图 { PointF p1 = new PointF(flag * i, panel1.Height - 20);//计算每个月份数字的坐标 //绘制显示月份的数字 g.DrawString(i.ToString(), new Font("宋体", 9), new SolidBrush(Color.Black), new PointF(p1.X - 2, p1.Y)); //记录绘制四边形的第三个点 Point pt3 = new Point(flag * i, panel1.Height - 20); //记录绘制四边形的第四个点 Point pt4 = new Point(flag * i, panel1.Height - 20 - points[i]); Point[] pt={pt1,pt2,pt3,pt4};//声明一个Point数组 g.FillPolygon(new SolidBrush(cl[i]), pt);//填充四边形的颜色 //当继续绘制下一个四边形时,前一个四边形的最后两个点作为下一个四边形的起始点 pt1 = pt4; pt2 = pt3; } panel1.BackgroundImage = bt;//显示绘制的面形图 } private void Form1_Load(object sender, EventArgs e) { } }}

面形图是平时很普及的一种图表风格,用来显示数据挺方便的。合理的加以应用相信会对程序数据展现的视觉效果有很大的提高!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章