Cara Membuat sebuah Lubang yang Transfaran di tengah Form Visual Basic 6.0

Pada trik kali ini saya akan menulis sebuah judul yang agak menggelitik buat saya, yaitu bagaimana cara membuat sebuah lubang yang transfaran di tengah form di vb6. Kenapa hal ini cukup menggelitik buat saya,karena kenapa form seperti ini harus dilubangi dan saya kira fungsinya untuk apa ya bagi seorang programmer? Bagi siapa yang tau silahkan tulis dalam komentar.

Bukankah seorang programmer di tuntut untuk mendesain form yang bagus terutama dari segi penampilan form agar menjadi bagian daya tarik user.

Walaupun saya tidak tau fungsi form berlubang ini entah untuk program apa yang penting saya bisa tau code ini, siapa tau saya bisa membutuhkannya nanti dan dapat menambah wawasan saya di dunia pemograman.

Oh ya tanpa basa-basi langsung saja kita praktekan Cara Melubangi Form dengan Transfaran alias bolong tembus pandang, kira-kira bagaimana hasinya nanti yu ikuti langkah-langkah dibawah ini :

Cara Membuat sebuah Lubang yang Transfaran di tengah Form Visual Basic 6.0

Buka Form VB6 Anda

Tanpa menambahkan komponen apapun di form langsung aja ketik kode dibawah ini di bagian

 (General) (Declaration)

Private Declare Function CreateRoundRectRgn Lib "gdi32" (ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long, ByVal X3 As Long, ByVal Y3 As Long) As Long


Private Declare Function CreateRectRgn Lib "gdi32" (ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long


Private Declare Function CreateEllipticRgn Lib "gdi32" (ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long


Private Declare Function CombineRgn Lib "gdi32" (ByVal hDestRgn As Long, ByVal hSrcRgn1 As Long, ByVal hSrcRgn2 As Long, ByVal nCombineMode As Long) As Long


Private Declare Function SetWindowRgn Lib "user32" (ByVal hWnd As Long, ByVal hRgn As Long, ByVal bRedraw As Long) As Long


Kemudian dilanjutkan copas coding Visual Basic 6.0 berikut sebagai function untuk membuat area transparan pada form


Private Function fMakeATranspArea(AreaType As String, pCordinate() As Long) As Boolean

Const RGN_DIFF = 4

Dim lOriginalForm As Long

Dim ltheHole As Long

Dim lNewForm As Long

Dim lFwidth As Single

Dim lFHeight As Single

Dim lborder_width As Single

Dim ltitle_height As Single


On Error GoTo Trap

lFwidth = ScaleX(Width, vbTwips, vbPixels)

lFHeight = ScaleY(Height, vbTwips, vbPixels)

lOriginalForm = CreateRectRgn(0, 0, lFwidth, lFHeight)


lborder_width = (lFHeight - ScaleWidth) / 2

ltitle_height = lFHeight - lborder_width - ScaleHeight

Select Case AreaType

Case "Elliptic"

ltheHole = CreateEllipticRgn(pCordinate(1), pCordinate(2), _

pCordinate(3), pCordinate(4))


Case "RectAngle"

ltheHole = CreateRectRgn(pCordinate(1), _

pCordinate(2), pCordinate(3), pCordinate(4))


Case "RoundRect"

ltheHole = CreateRoundRectRgn(pCordinate(1), _

pCordinate(2), pCordinate(3), pCordinate(4), _

pCordinate(5), pCordinate(6))


Case "Circle"

ltheHole = CreateRoundRectRgn(pCordinate(1), _

pCordinate(2), pCordinate(3), pCordinate(4), _

pCordinate(3), pCordinate(4))


Case Else

MsgBox "Unknown Shape!!"

Exit Function

End Select


lNewForm = CreateRectRgn(0, 0, 0, 0)

CombineRgn lNewForm, lOriginalForm, _

ltheHole, RGN_DIFF


SetWindowRgn hWnd, lNewForm, True

Me.Refresh

fMakeATranspArea = True

Exit Function

Trap:

MsgBox "error Occurred. Error # " & Err.Number & ", " & Err.Description

End Function 


Jangan lupa pula letakan kode di bawah ini di bagian

Private Sub Form_Load()

Dim lParam(1 To 6) As Long
lParam(1) = 100
lParam(2) = 100
lParam(3) = 250
lParam(4) = 250
lParam(5) = 50
lParam(6) = 50
Call fMakeATranspArea("RoundRect", lParam())


Sesudah kode di tambahkan sekarang jalankan vb Anda, dan perhatikan apa yang terjadi.


Bagaimana cukup mudah bukan?

 

No comments: