以下代码允许您使用鼠标(单击并拖动)绘制一个矩形。将 a 添加PictureBox
到表单中。
Public Class Form1
Private mpntMouseDown As Point
Private Sub Form1_Load(sender As Object, e As System.EventArgs) Handles Me.Load
Dim w As Integer = PictureBox1.Width
Dim h As Integer = PictureBox1.Height
Dim bmp As New Bitmap(w, h, System.Drawing.Imaging.PixelFormat.Format32bppArgb)
Using g As Graphics = Graphics.FromImage(bmp)
Dim rct As New RectangleF(0, 0, w, h)
Dim b As Brush = New System.Drawing.Drawing2D.LinearGradientBrush(rct, Color.White, Color.Blue, 0)
g.FillRectangle(b, rct)
g.DrawEllipse(Pens.Blue, New RectangleF(CInt(0.1 * w), CInt(0.2 * h), CInt(0.8 * w), CInt(0.6 * h)))
g.FillEllipse(Brushes.Yellow, New RectangleF(CInt(0.1 * w) + 1, CInt(0.2 * h) + 1, CInt(0.8 * w) - 2, CInt(0.6 * h) - 2))
Dim sft As New StringFormat
sft.Alignment = StringAlignment.Center
sft.LineAlignment = StringAlignment.Center
g.DrawString("Sample Image", New Font(System.Drawing.FontFamily.GenericSerif, 14, FontStyle.Italic, GraphicsUnit.Point), Brushes.Red, rct, sft)
End Using
PictureBox1.Image = bmp
End Sub
Private Sub PictureBox1_MouseDown(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles PictureBox1.MouseDown
If e.Button = Windows.Forms.MouseButtons.Left Then
mpntMouseDown = e.Location
End If
End Sub
Private Sub PictureBox1_MouseUp(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles PictureBox1.MouseUp
If mpntMouseDown = Nothing Then Exit Sub
Using g As Graphics = Graphics.FromImage(PictureBox1.Image, Bitmap)
Dim rct As New Rectangle
If mpntMouseDown.X < e.X Then
rct.X = mpntMouseDown.X
rct.Width = e.X - mpntMouseDown.X + 1
Else
rct.X = e.X
rct.Width = mpntMouseDown.X - e.X + 1
End If
If mpntMouseDown.Y < e.Y Then
rct.Y = mpntMouseDown.Y
rct.Height = e.Y - mpntMouseDown.Y + 1
Else
rct.Y = e.Y
rct.Height = mpntMouseDown.Y - e.Y + 1
End If
g.DrawRectangle(Pens.Black, rct)
End Using
mpntMouseDown = Nothing
PictureBox1.Invalidate()
End Sub
End Class