-
vb.net 教程 5-12 绘图实例之统计图3
版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
继续上一期《绘图实例之统计图2》,继续讲解如何绘制饼图:
当按下“饼图”按钮时,调用三个函数,分别是绘制饼图、显示到窗口,由于不需要坐标轴,所以这里不再绘制坐标轴:
Private Sub btnPie_Click(sender As Object, e As EventArgs) Handles btnPie.Click
Call DrawPie()
Call DrawToForm()
End Sub
DrawToForm()在之前已经介绍,以下是DrawPie的代码:
'绘制饼图
Private Sub DrawPie()
'标注每个季度
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 = {"一季度", "二季度", "三季度", "四季度"}
'我们要获得4个季度总的盈利
Dim seasonSum As Integer = 0
For i As Integer = 0 To 3
seasonSum += seasonValue(i)
Next
'根据总赢利情况,来获得每个季度在饼图中所占的份额(角度)
'为了简化起见,这里直接取整数
Dim seasonAngle(4) As Integer
seasonAngle(0) = 0
seasonAngle(1) = seasonValue(0) * 360 \ seasonSum
seasonAngle(2) = seasonValue(1) * 360 \ seasonSum + seasonAngle(1)
seasonAngle(3) = seasonValue(2) * 360 \ seasonSum + seasonAngle(2)
seasonAngle(4) = 360
'分别用4种颜色表示不同季度的盈利--http://blog.csdn.net/uruseibest
Dim seasonColor() As Color = {Color.Red, Color.Blue, Color.Green, Color.GreenYellow}
For i As Integer = 0 To 3
g.FillPie(New SolidBrush(seasonColor(i)), New Rectangle(100, 100, 200, 200), seasonAngle(i), seasonAngle(i + 1) - seasonAngle(i))
'饼图中特别需要说明每个季度对应的颜色
g.FillRectangle(New SolidBrush(seasonColor(i)), New Rectangle(360, i * 50 + 80, 60, 40))
'标出每个季度
g.DrawString(seasonName(i), New Font("宋体", 12), New SolidBrush(Color.Black), New Point(450, i * 50 + 90))
Next
End Sub
按下“饼图”按钮时,如下图所示:
需要强调的是FillPie()最后两个关于角度的参数:
第1个角度参数(startAngle):扇形起始角度,是构成扇形的第一条边从x轴方向按照顺时针旋转的角度。
第2个角度参数(sweepAngle):扇形第二条边从第一条边按照顺时针方向旋转的角度
由于.net平台下C#和vb.NET很相似,本文也可以为C#爱好者提供参考。
学习更多vb.net知识,请参看 vb.net 教程 目录
————————————————
版权声明:本文为CSDN博主「VB.Net」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/uruseibest/article/details/68948667
最新更新
python爬虫及其可视化
使用python爬取豆瓣电影短评评论内容
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比