vb.net 教程 5-12 绘图实例之统计图 1 柱状图

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
前面几篇介绍了如何使用graphics绘制图像,这几篇准备介绍如何使用graphics提供的方法绘制统计图。

包括:柱状图、折线图、饼图。

假设知道某个公司1-4季度的盈利情况,我们来看看如何完成统计图

新建一个窗体,

添加4个标签,分别是“一季度”、“二季度”、“三季度”、“四季度”

添加4个numericupdown,名称从 nudsesson1 至 nudsesson4

添加4个按钮,名称为btnBarGraph、btnLineChart、btnPie、btnSave,对应Text属性为 柱状图、折线图、饼图、保存

图示如下:

以柱状图为例,目前考虑的步骤:

1、创建graphics对象

2、绘制坐标轴

3、绘制立柱

4、显示出来

新建窗体级变量:

    Dim g As Graphics
    Dim bmp As Bitmap

在窗体载入的时候将bmp、g实例化,bmp的大小根据实际需要建立:

    Private Sub Form7_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        bmp = New Bitmap(600, 350)
        g = Graphics.FromImage(bmp)
    End Sub

当按下“柱状图”按钮的时候调用三个函数,分别是绘制坐标轴、绘制立柱、显示到窗口:

    Private Sub btnDraw_Click(sender As Object, e As EventArgs) Handles btnBarGraph.Click
        Call DrawAxis()
        Call DrawBarGraph()
        Call DrawToForm()
    End Sub


以下分别介绍上面所说的三个函数,详细说明标注在源代码中了:

    '绘制坐标轴
    Private Sub DrawAxis()
        '使用红色绘制坐标轴
        Dim p As New Pen(Color.Red, 1)
        '坐标轴末尾箭头
        p.EndCap = Drawing2D.LineCap.ArrowAnchor
        '坐标原点
        Dim originX As Integer = 40
        Dim originY As Integer = 320
        Dim originPoint As Point = New Point(originX, originY)
        '绘制横坐标
        g.DrawLine(p, originPoint, New Point(540, 320))
        '绘制纵坐标--http://blog.csdn.net/uruseibest
        g.DrawLine(p, originPoint, New Point(40, 20))

        '红色绘制坐标轴刻度
        Dim pAxisY As New Pen(Color.Red, 1)
        Dim AxisYPos As Point
        Dim AxisYValue As String

        '在纵轴上标明刻度线,从0-90,每10个刻度标注一下
        '注意的是,我们使用了1:3的比例
        For i As Integer = 0 To 9
            '刻度值
            AxisYValue = (i * 10).ToString
            '刻度位置
            AxisYPos = New Point(20, originY - i * 30 - 5)
            '标明刻度值
            g.DrawString(AxisYValue, New Font("宋体", 10), New SolidBrush(Color.Blue), AxisYPos)
            '画刻度,实际0刻度线是和横坐标轴重合
            g.DrawLine(pAxisY, New Point(40, originY - i * 30), New Point(50, originY - i * 30))
        Next
    End Sub

 

    '绘制立柱
    Private Sub DrawBarGraph()
        '标注每个季度
        Dim seasonValue(3) As Integer
        seasonValue(0) = nudSeason1.Value
        seasonValue(1) = nudSeason2.Value
        seasonValue(2) = nudSeason3.Value
        seasonValue(3) = nudSeason4.Value
        Dim seasonName() As String = {"一季度", "二季度", "三季度", "四季度"}

        '立柱(矩形)的左上角坐标点
        Dim recX, recY As Integer
        '循环画四个矩形--http://blog.csdn.net/uruseibest
        For i As Integer = 0 To 3
            recX = (i + 1) * 80
            '注意:我们的坐标轴是按照1:3绘制,所有这里需要*3
            recY = 320 - seasonValue(i) * 3
            g.FillRectangle(New SolidBrush(Color.Blue), New Rectangle(recX, recY, 40, seasonValue(i) * 3))
        Next
        '标出每个季度
        Dim strX, strY As Integer
        For i As Integer = 0 To 3
            strX = (i + 1) * 80 - 5
            strY = 325
            g.DrawString(seasonName(i), New Font("黑体", 10), New SolidBrush(Color.Blue), New Point(strX, strY))
        Next
    End Sub

 

    '将bmp绘制到窗体表面
    Private Sub DrawToForm()
        Dim g1 As Graphics = Me.CreateGraphics
        g1.DrawImage(bmp, New Point(0, 0))
    End Sub

当按下“柱状图”按钮时,如下图所示:

 

由于.net平台下C#和vb.NET很相似,本文也可以为C#爱好者提供参考。

学习更多vb.net知识,请参看 vb.net 教程 目录

 

  • 4
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值