Background transparent pour checkbox, optionbox (optionbutton), picturebox : avec simple procedure.

Soyez le premier à donner votre avis sur cette source.

Vue 13 698 fois - Téléchargée 1 655 fois

Description

Ce style de code existe déjà pour les form et les pictureBox partout (sûrement aussi sur ce site). J?ai utilisé le même principe pour les CheckBox et les OptionBox. Voici une simple procedure pour rendre le background des CheckBox et des OptionBox transparent. Très simple et efficace (Voir photo).
Marche aussi avec les pictureBox, il reste à l?adapter un peu pour qu?elle marche avec tous les autres controls (form, button, list,?).
Je vous remercie, maintenant je peux terminer la programmation de mon créateur de menus styles XP ;).
A+

Source / Exemple :


Private Const RGN_DIFF = 4
Private Declare Function GetWindowDC Lib "user32" (ByVal hwnd As Long) As Long
Private Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal x As Long, ByVal y 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 CombineRgn Lib "gdi32" (ByVal hDestRgn As Long, ByVal hSrcRgn1 As Long, ByVal hSrcRgn2 As Long, ByVal nCombineMode As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Private Declare Function SetWindowRgn Lib "user32" (ByVal hwnd As Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) As Long

Public Sub BackgroundTransparent(Objet As Object)
    Dim CouleurBackground As Long
    Dim hdcObjet As Long, RectFinal As Long, NewRect As Long
    Dim x As Integer, y As Integer
    
On Error Resume Next
    hdcObjet = GetWindowDC(Objet.hwnd)
    CouleurBackground = GetPixel(hdcObjet, 0, 0)
    
If CouleurBackground = -1 Then Exit Sub
    Objet.BackColor = CouleurBackground
    RectFinal = CreateRectRgn(0, 0, Objet.Width, Objet.Height)

For y = 0 To Objet.Height
    For x = 0 To Objet.Width

        If GetPixel(hdcObjet, x, y) = CouleurBackground Then
            NewRect = CreateRectRgn(x, y, x + 1, y + 1)
            CombineRgn RectFinal, RectFinal, NewRect, RGN_DIFF
            DeleteObject (NewRect)
        End If
    
    Next x
x = 0
Next y

    SetWindowRgn Objet.hwnd, RectFinal, True
    DeleteObject (RectFinal)

End Sub

Private Sub CmdStart_Click()
    BackgroundTransparent Option2
    BackgroundTransparent Check2
    BackgroundTransparent Picture1
End Sub

Codes Sources

A voir également

Ajouter un commentaire

Commentaires

davidauche
Messages postés
150
Date d'inscription
jeudi 20 mars 2003
Statut
Membre
Dernière intervention
8 janvier 2008
-
bah super que ça marche en fin!, pour la transparente si tu trouve la solution avec un label et control utilisateur, je suis preneur ;).
a+
cs_olid
Messages postés
296
Date d'inscription
lundi 2 septembre 2002
Statut
Membre
Dernière intervention
28 janvier 2008
-
Bin, pour la transparence, la soluce la plus simple pour moà est de créer un control qui reproduit un label et/ou de réutiliser le tien :o|
Alucardkuun
Messages postés
1
Date d'inscription
lundi 18 juillet 2005
Statut
Membre
Dernière intervention
16 septembre 2005
-
oui mais comment est-ce que je peut mettre le script que quand le programe s'ouvre qu'il le fasse automatiquement?

merci
//Naruto
cs_surfman
Messages postés
47
Date d'inscription
samedi 1 mars 2003
Statut
Membre
Dernière intervention
16 septembre 2008
-
comment on fait pour que les checkbox soit transparent au démarrage de mon logiciel ? sans à avoir à crée un bouton :s
turie
Messages postés
6
Date d'inscription
mardi 6 avril 2004
Statut
Membre
Dernière intervention
17 février 2010
-
Très bon code, je le cherchai depuis un moment.
Commenter la réponse de cs_NoFutur

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.