Şeffaf UserForm Oluşturma Kodu

26 Aralık 2020 27 Aralık 2020 1221

Şeffaf UserForm Oluşturma Kodu isimli makro kodlarını kullanarak, bir UserForm nesnesinin şeffaf olarak açılamasını sağlayabilirsiniz.

Option Explicit
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" ( _
        ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" ( _
        ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _
        lParam As Any) 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 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 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 Boolean) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Private Declare Function ReleaseCapture Lib "user32" () As Long

Private frmRegion As Long, hWnd As Long, msg1 As String, msg2 As String

Private Sub CommandButton1_Click()
  Unload Me
End Sub

Private Sub UserForm_Initialize()
  seffaf
End Sub

Private Sub seffaf()
  Dim W As Single, H As Single, cl As Long
  Dim ct As Long, cw As Long, ch As Long
  Dim i As Integer, R As Long, Outer As Long, Inner As Long
  ' 1 pixel = 0.75 point / 1 point = 1.33 pixel
  hWnd = FindWindow(vbNullString, Me.Caption)
  W = Me.Width * 1.33: H = Me.Height * 1.33
  frmRegion = CreateRectRgn(0, 0, 0, 0)
  ' X = (W - ScaleWidth) / 2 -> Genelde 3
  ' Y = H - X - ScaleHeight  -> Genelde 22
  Const X As Single = 3: Const Y As Single = 22
  Const RGN_OR = 2
  Const RGN_DIFF = 4
  Outer = CreateRectRgn(0, 0, W, H)
  Inner = CreateRectRgn(X, Y, W - X, H - X)
  CombineRgn frmRegion, Outer, Inner, RGN_DIFF
  For i = 0 To Me.Controls.Count - 1
    If Me.Controls(i).Visible Then
      ct = Y + (1.33 * Me.Controls(i).Top)
      ch = ct + (1.33 * Me.Controls(i).Height)
      cl = X + (1.33 * Me.Controls(i).Left)
      cw = cl + (1.33 * Me.Controls(i).Width)
      R = CreateRectRgn(cl, ct, cw, ch)
      CombineRgn frmRegion, R, frmRegion, RGN_OR
    End If
  Next
  SetWindowRgn hWnd, frmRegion, True
End Sub

Private Sub UserForm_QueryClose(Cancel As Integer, CloseMode As Integer)
  SetWindowRgn hWnd, 0, False
  DeleteObject frmRegion
End Sub

Gerekli Adımlar

Kodu çalıştırmanız için aşağıdaki adımları yerine getirmeniz gerekir.

  1. Microsoft Visual Basic for Applications penceresini (Alt + F11) açın.
  2. Project - VBAProject alanının, ekranın sol tarafında görüldüğünden emin olun. Görünmüyorsa, Ctrl + R kısayolu ile hızlıca açın.
  3. Araç çubuklarından Insert -> UserForm yazısına tıklayın.
  4. Solunda klasör simgesi olan Forms yazısının başındaki + simgesine tıklayın.
  5. Alt kısma eklenecek olan UserForm(1) yazısına çift tıklayın.
  6. Üstteki kodu yapıştırın.

Kod Açıklaması

Kodlar sadece UserForm'un şeffa olarak açılmasını sağlayıp, üzerine eklenmiş diğer nesneleri şeffaflaştırmaz. 64 bit sürümlerde hata verebilir.

50 Farklı Hazır Makro (VBA) Kodu
Tarih ve Saatten Tarihi Kaldırma
Açık Excel Kitaplarını Yerleştirme
Dar Kenar Boşluğu Yazdırma
Excel Makroları ile İşlemci Bilgilerini Bulma
Excel Makroları ile Dosya Silme
Sayfadaki Kelime ve Sayı Adetlerini Bulma
Her Bir Sütundaki Maksimum Değeri Bulma
Sayıları Yeni Bir Sayıyla Çarpma
Tüm Çalışma Sayfalarını Tek Adımda Koruma
Bir Hücreye Çift Tıklayınca UserForm Açılsın
Çalışma Sayfaları için Yakınlaştırma Yüzdesini Ayarlama
Başka Dosyada Şifreli Userform Oluşturmak
56 Koşula Kadar Biçimlendirme Yapma
Api ile Bilgisayar Adını Bulmak
Toplu Satır Silme
Birden Çok Sütun Ekleme
Formüllü Hücreleri Renklendir
Satırı Kes Kopyala ve Yapıştır
Excel Sayfalarındaki Resimleri Silmek
A Sütunundaki Verileri C Sütununda Sıralama
Dördüncü Sütunda İşlem Yapılınca Çalışan Makro
Kilitlenmemiş Hücreleri Seçme İşlemi
Sürücü Adı Kontrolü Yapma
Makrolar İşlem Yaparken Ekranın Kilitlenmesi
Kopyala ve Biçimleri Yapıştır
Kopyala ve Değer Olarak Yapıştır
Excel Makroları ile Hücreye Saat Ekleme
X Sayı Atlayarak Satır Gizleme
Excel Makroları ile Dosya Taşıma
Sendkey Yöntemi ile F Q Klavye Dönüşümü
Tarih ve Saatten Saati Kaldırma
Excel Satır Seçme Kodu
Hücrenin Rengini Değiştirme
Program Başlangıcı Kodları
Google Üzerinde Arama Yapma
Seçili Hücrelerden Boşlukları Kaldırma
Kaydedilmemiş Açık Çalışma Kitaplarını Sayma
Kare Kökünü Hesaplama
Excel Sayfalarında Çarpım Tablosu Oluşturma
Her Kapatma İşleminde Otomatik Olarak Kaydetme
Satır Yüksekliklerini Otomatik Ayarlama
Aktif Hücreye Açıklama Ekleme
Dizinde Klasör Araması Yapma
Negatif Sayıları Vurgulama
Makrolar ile Txt Dosya Silme
Seri Numaralarını Ekleme
Aktif Satırı ve Sütunu Vurgulama
Toplu Sütun Silme
Bilgisayardaki Sürücü İsimlerini Listeleme
Makro Çalışırken İmlecin Hareket Etmemesini Sağlama

Daha önce yorum yapılmamış!

YARARLI KISAYOLLAR
Tablo Seçimi Yapma Ctrl *
Stil Penceresini Açma Alt Shift 2
Bir önceki sonucu bulma Ctrl Shift F4
Ekranı Küçültme Ctrl F5
Baskı Önizleme Ctrl F2
Backlink Reklam Bu alanda 50 karakterlik açıklama ile web sitenize ait Backlink Reklam yayınlayabilirsiniz.
Yükleniyor...