当前位置: 首页 > 编程笔记 >

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

冯星阑
2023-03-14
本文向大家介绍C#实现绘制面形图表的方法详解,包括了C#实现绘制面形图表的方法详解的使用技巧和注意事项,需要的朋友参考一下

本例详细讲述了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)
    {

    }
  }
}

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

 类似资料:
  • 本文向大家介绍C#正方形图片的绘制方法,包括了C#正方形图片的绘制方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了C#绘制正方形图片的的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍extjs图表绘制之条形图实现方法分析,包括了extjs图表绘制之条形图实现方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了extjs图表绘制之条形图实现方法。分享给大家供大家参考,具体如下: 这篇文章将介绍extjs图表中条形图。 将实现以下的功能: 1.从后端请求数据并运用到图表中,形成动态数据。 2.查询出每年各个月中人数。 3.改变条形柱的颜色,改变默认的颜色

  • 本文向大家介绍asp.net实现C#绘制太极图的方法,包括了asp.net实现C#绘制太极图的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了asp.net实现C#绘制太极图的方法。分享给大家供大家参考。具体如下: 成品图如下所示: html页面: 注意设置: 后台代码: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍extjs图形绘制之饼图实现方法分析,包括了extjs图形绘制之饼图实现方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了extjs图形绘制之饼图实现方法。分享给大家供大家参考,具体如下: 这篇文章将介绍extjs中自带的饼图。 代码如下: 注: 1.上面中的createStore是创建饼图所需要的数据的--store。 2.上面中的legend 显示的右边的图例(表明

  • 本文向大家介绍js+html5实现canvas绘制圆形图案的方法,包括了js+html5实现canvas绘制圆形图案的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js+html5实现canvas绘制圆形图案的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的web程序设计有所帮助。

  • 本文向大家介绍C# 绘制实时折线图,波形图,包括了C# 绘制实时折线图,波形图的使用技巧和注意事项,需要的朋友参考一下 此Demo是采用VS自带的Chart图表控件,制作实时动态显示的折线图,和波形图。本文仅供学习分享使用,如有不足之处,还请指正。 涉及知识点: Chart 控件,功能强大,可以绘制柱状图,折线图,波形图,饼状图,大大简化了对图的开发与定制。     Chart控件的相关概念: C