vb.net GDI窗体

在窗体中添加一个ContextMenu1控件

 

Imports System.Drawing.Drawing2D



Public Class Form1

    Inherits System.Windows.Forms.Form



#Region " Windows 窗体设计器生成的代码 "



    Public Sub New()

        MyBase.New()



        '该调用是 Windows 窗体设计器所必需的。

        InitializeComponent()



        '在 InitializeComponent() 调用之后添加任何初始化



    End Sub



    '窗体重写处置以清理组件列表。

    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)

        If disposing Then

            If Not (components Is Nothing) Then

                components.Dispose()

            End If

        End If

        MyBase.Dispose(disposing)

    End Sub



    'Windows 窗体设计器所必需的

    Private components As System.ComponentModel.IContainer



    '注意:以下过程是 Windows 窗体设计器所必需的

    '可以使用 Windows 窗体设计器修改此过程。

    '不要使用代码编辑器修改它。

    Friend WithEvents ContextMenu1 As System.Windows.Forms.ContextMenu

    Friend WithEvents MenuItem1 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem2 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem3 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem4 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem5 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem6 As System.Windows.Forms.MenuItem

    Friend WithEvents MenuItem7 As System.Windows.Forms.MenuItem

    <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()

        Dim resources As System.ComponentModel.ComponentResourceManager = New System.ComponentModel.ComponentResourceManager(GetType(Form1))

        Me.ContextMenu1 = New System.Windows.Forms.ContextMenu

        Me.MenuItem1 = New System.Windows.Forms.MenuItem

        Me.MenuItem2 = New System.Windows.Forms.MenuItem

        Me.MenuItem3 = New System.Windows.Forms.MenuItem

        Me.MenuItem4 = New System.Windows.Forms.MenuItem

        Me.MenuItem5 = New System.Windows.Forms.MenuItem

        Me.MenuItem6 = New System.Windows.Forms.MenuItem

        Me.MenuItem7 = New System.Windows.Forms.MenuItem

        Me.SuspendLayout()

        '

        'ContextMenu1

        '

        Me.ContextMenu1.MenuItems.AddRange(New System.Windows.Forms.MenuItem() {Me.MenuItem1, Me.MenuItem2, Me.MenuItem3, Me.MenuItem4, Me.MenuItem5, Me.MenuItem6, Me.MenuItem7})

        '

        'MenuItem1

        '

        Me.MenuItem1.Index = 0

        Me.MenuItem1.Text = "椭圆"

        '

        'MenuItem2

        '

        Me.MenuItem2.Index = 1

        Me.MenuItem2.Text = "扇形"

        '

        'MenuItem3

        '

        Me.MenuItem3.Index = 2

        Me.MenuItem3.Text = "圆形"

        '

        'MenuItem4

        '

        Me.MenuItem4.Index = 3

        Me.MenuItem4.Text = "环形"

        '

        'MenuItem5

        '

        Me.MenuItem5.Index = 4

        Me.MenuItem5.Text = "三角"

        '

        'MenuItem6

        '

        Me.MenuItem6.Index = 5

        Me.MenuItem6.Text = "恢复矩形"

        '

        'MenuItem7

        '

        Me.MenuItem7.Index = 6

        Me.MenuItem7.Text = "退出"

        '

        'Form1

        '

        Me.AutoScaleBaseSize = New System.Drawing.Size(14, 37)

        Me.BackgroundImage = CType(resources.GetObject("$this.BackgroundImage"), System.Drawing.Image)

        Me.ClientSize = New System.Drawing.Size(344, 304)

        Me.ContextMenu = Me.ContextMenu1

        Me.Font = New System.Drawing.Font("Arial Narrow", 24.0!, System.Drawing.FontStyle.Bold, System.Drawing.GraphicsUnit.Point, CType(0, Byte))

        Me.FormBorderStyle = System.Windows.Forms.FormBorderStyle.Fixed3D

        Me.Name = "Form1"

        Me.Text = "Form1"

        Me.ResumeLayout(False)



    End Sub



#End Region



    Private Sub MenuItem1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MenuItem1.Click, MenuItem2.Click, MenuItem3.Click, MenuItem4.Click, MenuItem5.Click, MenuItem6.Click, MenuItem7.Click



        Dim p As GraphicsPath = New GraphicsPath()



        Select Case CType(sender, MenuItem).Text

            Case "椭圆"



                Dim Width As Integer = Me.ClientSize.Width

                Dim Height As Integer = Me.ClientSize.Height

                p.AddEllipse(0, 20, Width - 50, Height - 100)

                

                '根据要绘制椭圆的形状来填写AddEllipse方法中椭圆对应的相应参数



            Case "扇形"

                p.AddPie(10, 10, 250, 250, 5, 150)

                '根据要实现的扇形形状来填写AddPie方法中的相应参数



            Case "圆形"

                Dim Width As Integer = Me.ClientSize.Width

                Dim Height As Integer = Me.ClientSize.Height

                p.AddEllipse(0, 0, Height, Height)

                '圆形即是椭圆的一种特例,



            Case "环形"

                Dim Height As Integer = Me.ClientSize.Height

                Dim width As Integer = 100

                p.AddEllipse(0, 0, Height, Height)

                'p.AddRectangle(New Rectangle(width, width, width, width))

                p.AddEllipse(width, width, Height - (width * 2), Height - (width * 2))

                '根据环形的形状来分别填写AddEllipse方法中相应的参数



            Case "三角"

                p.AddLine(0, 0, 250, 150)

                p.AddLine(250, 150, 0, 300)

                p.AddLine(0, 0, 0, 300)

                '根据三角形的形状特征来分别填写AddLine方法中相应的参数





            Case "恢复矩形"

                p.AddRectangle(New Rectangle(0, 0, Me.Width, Me.Height))

                '用窗体尺寸矩形填充addrectangle()方法



            Case "退出"

                Close()

        End Select

        '设置窗体的外形

        Me.Region = New Region(p)



    End Sub



    Private Sub ContextMenu1_Popup(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ContextMenu1.Popup



    End Sub



    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load



    End Sub

End Class


 

 

 

 

你可能感兴趣的:(VB.NET)