基本信息
源码名称:vb 仪表盘控件源码
源码大小:1.80M
文件格式:.zip
开发语言:ASP
更新时间:2019-07-02
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 10 元×
微信扫码支付:10 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
Public Class 仪表盘 Private _Bg As Bitmap Private _Max As Integer = 100 Private _Value As Integer = 25 Private _Rote As Single Private _Digit As Bitmap Public Property MaxValue As Integer Get Return _Max End Get Set(value As Integer) If value < _Value Then value = _Value _Max = value _Rote = 360 / _Max * _Value MakeBg() End Set End Property Public Property Value As Integer Get Return _Value End Get Set(value As Integer) If value > _Max Then value = _Max _Value = value _Rote = 360 / _Max * _Value MakeBg() End Set End Property Private Sub 仪表盘_Load(sender As Object, e As EventArgs) Handles MyBase.Load MakeBg() End Sub Private Sub MakeBg() If _Bg IsNot Nothing Then _Bg.Dispose() _Bg = New Bitmap(344, 344) Using G As Graphics = Graphics.FromImage(_Bg) G.SmoothingMode = Drawing2D.SmoothingMode.HighQuality G.DrawImage(My.Resources.表盘底, New Rectangle(0, 0, 344, 344), New Rectangle(0, 0, 344, 344), GraphicsUnit.Pixel) Try Dim Gs As Drawing2D.GraphicsState = G.Save Using Gp As New Drawing2D.GraphicsPath Gp.AddPie(New Rectangle(0, 0, 344, 344), -90, _Rote) Using Txbur As New TextureBrush(My.Resources.表盘底1) G.FillPath(Txbur, Gp) End Using End Using G.TranslateTransform(172, 172) G.RotateTransform(_Rote) G.DrawImage(My.Resources.表盘底指针, New Rectangle(-172, -172, 344, 344), New Rectangle(0, 0, 344, 344), GraphicsUnit.Pixel) G.Restore(Gs) G.DrawImage(My.Resources.表盘液晶数字底, New Rectangle(0, 0, 344, 344), New Rectangle(0, 0, 344, 344), GraphicsUnit.Pixel) MakeDigit() Dim XX, YY As Single XX = (344 - _Digit.Width) / 2 YY = (344 - _Digit.Height) / 2 G.DrawImage(_Digit, New Rectangle(XX, YY, _Digit.Width, _Digit.Height), New Rectangle(0, 0, _Digit.Width, _Digit.Height), GraphicsUnit.Pixel) Catch End Try End Using Me.BackgroundImage = _Bg Me.Invalidate() End Sub Private Sub MakeDigit() If _Digit IsNot Nothing Then _Digit.Dispose() Dim V As Integer = _Value / _Max * 100 Dim S As String = Format(V, "000") Dim W, H As Integer W = 30 * S.Length H = 30 _Digit = New Bitmap(W, H) Using G As Graphics = Graphics.FromImage(_Digit) For I As Integer = 0 To S.Length - 1 G.DrawImage(My.Resources.液晶数字, New Rectangle(I * 30, 0, 30, 30), New Rectangle(30 * S.Substring(I, 1), 0, 30, 30), GraphicsUnit.Pixel) Next End Using End Sub End Class