透明的Form上顯示背景透通圖

來源:cww

這是一個很奇特的功能,首先要讓Form變透明,接著,放一張背景透明的.gif圖進來,
如此,這變成一個透明的form,上面有許多Button,且圖不會是一個方形,而會讓圖
的背景透通。
但有一點要注意,這種透明的Form不可以移動,否則一移就會發現它似乎不是透明的,
這個很不好解釋,建議您一開始設定Form的BorderStyle = 2 大小可變可移動,而去移
動與更動小大,便可以知道。因此,在設計階段時,一定要設BorderStyle = 0 沒有框
線,這樣子您的Form才不會有問題。
首先我使用以下的程式碼令Form變透明

註:有適當的軟體(如 MS PhotEditor)可以將圖變成背景透通(引用 老怪之言)

Me.AutoRedraw = True
hBitmap = CreateCompatibleBitmap(Me.hdc, 0, 0)
SelectObject Me.hdc, hBitmap
Me.Refresh
而透明的圖形呢,那需要那一種背景透通性的.GIF檔,在Form上放一個Image Control,將
圖放到Image Control,那就OK了
'需一個Image Control , 一個Command1
Option Explicit
Private Declare Function SelectObject Lib "gdi32" (ByVal hdc As Long, ByVal hObject As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Private Declare Function CreateCompatibleBitmap Lib "gdi32" (ByVal hdc As Long, ByVal nWidth As Long, ByVal nHeight As Long) As Long
Private hBitmap As Long

Private Sub Command1_Click()
Unload Me
End Sub

Private Sub Form_Load()
'事先請設form的BorderStyle = 0 沒有框線
Me.AutoRedraw = True
Set Image1.Picture = LoadPicture("e:\bubbles.gif") '請自行找一個背景透明的圖
hBitmap = CreateCompatibleBitmap(Me.hdc, 0, 0)
SelectObject Me.hdc, hBitmap
Me.Refresh
End Sub

Private Sub Form_Unload(Cancel As Integer)
DeleteObject hBitmap
End Sub