VB1010实例(4)圆形窗体

前台

VB1010实例(4)圆形窗体

代码

Imports System.Runtime.InteropServices
'我的操作系统是win7,64位,long类型是64位
'需要设置为:编译--高级编译--目标CPU--x64
'单击变椭圆,双击还原
Public Class Form1
    <DllImport("gdi32.dll", EntryPoint:="CreateEllipticRgn", CallingConvention:=CallingConvention.Cdecl, ExactSpelling:=True)> _
    Public Shared Function CreateEllipticRgn(ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long
    End Function

    <DllImport("gdi32.dll", EntryPoint:="CreateRectRgn", CallingConvention:=CallingConvention.Cdecl, ExactSpelling:=True)> _
    Private Shared Function CreateRectRgn(ByVal nLeftRect As Long, ByVal nTopRect As Long, ByVal nRightRect As Long, ByVal nBottomRect As Long) As IntPtr
    End Function

    <DllImport("user32.dll", EntryPoint:="SetWindowRgn", CallingConvention:=CallingConvention.Cdecl, ExactSpelling:=True)> _
    Public Shared Function SetWindowRgn(ByVal hWnd As Long, ByVal hRgn As IntPtr, ByVal bRedraw As Boolean) As Long
    End Function

    <DllImport("gdi32.dll", EntryPoint:="DeleteObject", CallingConvention:=CallingConvention.Cdecl, ExactSpelling:=True)> _
    Private Shared Function DeleteObject(ByVal hObject As IntPtr) As <MarshalAs(UnmanagedType.Bool)> Boolean
    End Function


    Dim hRgnC As Long
    Dim hRgnR As Long
    Private Sub Form1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Click
        hRgnC = CreateEllipticRgn(25, 25, 220, 220)
        SetWindowRgn(Me.Handle, hRgnC, True)
    End Sub


    Private Sub Form1_DoubleClick(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.DoubleClick
        hRgnR = CreateRectRgn(0, 0, Me.Width, Me.Height)
        SetWindowRgn(Me.Handle.ToInt64, hRgnR, True)
    End Sub

    Private Sub Form1_Leave(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Leave
        If hRgnR <> 0 Then DeleteObject(hRgnR)
        If hRgnC <> 0 Then DeleteObject(hRgnC)
    End Sub
End Class