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

Soyez le premier à donner votre avis sur cette source.

Vue 14 726 fois - Téléchargée 1 746 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
cs_NoFutur Messages postés 171 Date d'inscription mardi 17 décembre 2002 Statut Membre Dernière intervention 6 mai 2007
14 oct. 2004 à 19:43
10/10 pour moi.

J'ai cherché mais je n'ai jamais trouvé et en plus c'est idéal pour le composant Tabstrip de la version 5.0 associé au manifest.xp pour obtenir enfin une belle transparence sur les Frames sous XP !

Bonne prog !
titnamoureux Messages postés 5 Date d'inscription mardi 22 avril 2003 Statut Membre Dernière intervention 14 octobre 2004
14 oct. 2004 à 19:51
Je n'arrive pas le faire fonctionner.. ???
davidauche Messages postés 150 Date d'inscription jeudi 20 mars 2003 Statut Membre Dernière intervention 8 janvier 2008
14 oct. 2004 à 20:03
salut,
je suis content pour toi NoFutur et merci :).
titnamoureux, comment ça marche pas?!, essaie de télecharger le zip et tester la source (il y a un exemple), en fait t'ajoute une image (picture) au form1 pour l'effet transparence sera plus clair.
tu me tiens au courant si ça marche pas, c'est un peu étonnant quand meme!
a+
Zoneur Messages postés 6 Date d'inscription dimanche 31 août 2003 Statut Membre Dernière intervention 25 mars 2005
14 oct. 2004 à 20:48
Hum, salut bonne source juste un blém l'image du pinguin est touché aussi.
juvamine Messages postés 468 Date d'inscription vendredi 21 février 2003 Statut Membre Dernière intervention 30 août 2007 2
15 oct. 2004 à 09:31
moi qui pensais qu'un programmeur était du genre faignant...ou en tout cas, il cherchait toujours la solution la plus simple...ce n'est visiblement pas ton cas...encore une source que l'on devrait classer dans les catégorie "Pourquoi faire simple quand on peut faire compliquer"
6 API + une librairie VB pour rendre un bg transparent !

MS y'avait déjà pensé, c'est pourquoi il existe la librairie Ms Forms 2.0 Objects Library !! Donc tes 6 API+Library sont remplacer par une seule Library :/ et un .BackStyle à modifier.
Je te l'ai déjà dit tout ça sur le tchate ! mais ceci servira peut-être aux autres qui sait...

5/10 pour le mal que tu t'ai donné

Cordialement
juva

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.