begin process at 2010 02 09 23:21:41
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

API

 > EDIT ET STATIC TRANSPARENTS SUR FOND BMP

EDIT ET STATIC TRANSPARENTS SUR FOND BMP


 Information sur la source

Note :
9,5 / 10 - par 2 personnes
9,50 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :API Classé sous :tranparence, edit, static, fond, bitmap Niveau :Débutant Date de création :23/08/2008 Vu / téléchargé :2 438 / 136

Auteur : racpp

Ecrire un message privé
Commentaire sur cette source (12)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Pour répondre à une question du forum, j'ai fait ce petit code source montrant comment rendre un Edit ou un Static transparent sur une fenêtre ayant comme fond une image bitmap.
La transparence est réalisée en copiant la portion du bitmap correspondant aux coordonnées du contrôle (Static ou Edit) sur le fond de ce dernier. Pour cela, on sous-classe le contrôle et traite le message WM_ERASEBKGND. Dans la procédure de la fenêtre mère, on traite les messages WM_CTLCOLOREDIT et WM_CTLCOLORSTATIC.
Ce petit projet est fait avec Visual C/C++ 2005 mais le code devrait aller avec tout autre compilateur sous Windows puisque c'est du WIN32 API.
J'espère que ce sera utile à certains.

Source

  • #include <windows.h>
  • // Déclarations globales:
  • WNDPROC oldstaticproc,oldeditproc;
  • HDC hdcmem;
  • // Procédure de sous-classement du Static:
  • LRESULT CALLBACK staticproc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
  • {
  • if(msg==WM_ERASEBKGND)
  • {
  • POINT pt;
  • RECT rect;
  • GetClientRect(hwnd,&rect);// Obtenir les coordonnées de la zone cliente
  • pt.x=rect.left; pt.y=rect.top;
  • ClientToScreen(hwnd,&pt);// Les traduire en coordonnées écran
  • ScreenToClient(GetParent(hwnd),&pt);// Les traduire en coordonnées fenêtre parente
  • // Dessiner la portion du fond correspondante:
  • BitBlt((HDC)wParam,0,0,rect.right,rect.bottom,hdcmem,pt.x,pt.y,SRCCOPY);
  • return 1;
  • }
  • return CallWindowProc(oldstaticproc, hwnd, msg, wParam, lParam);
  • }
  • // Procédure de sous-classement de l'Edit:
  • LRESULT CALLBACK editproc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
  • {
  • if(msg==WM_ERASEBKGND)
  • {
  • POINT pt;
  • RECT rect;
  • GetClientRect(hwnd,&rect);// Obtenir les coordonnées de la zone cliente
  • pt.x=rect.left; pt.y=rect.top;
  • ClientToScreen(hwnd,&pt);// Les traduire en coordonnées écran
  • ScreenToClient(GetParent(hwnd),&pt);// Les traduire en coordonnées fenêtre parente
  • // Dessiner la portion du fond correspondante:
  • BitBlt((HDC)wParam,0,0,rect.right,rect.bottom,hdcmem,pt.x,pt.y,SRCCOPY);
  • return 1;
  • }
  • return CallWindowProc(oldeditproc, hwnd, msg, wParam, lParam);
  • }
  • // Procédure de la fenêtre principale:
  • LRESULT CALLBACK WndProc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
  • {
  • static HBITMAP hbmp;
  • static HWND hedit,hstatic,hquitter;
  • static char buffer[100];
  • switch (msg)
  • {
  • case WM_CREATE:
  • // Création des contrôles:
  • hstatic=CreateWindowEx(0,"static",0,WS_VISIBLE | WS_CHILD | SS_CENTER,30,60,300,20,hwnd,0,0,0);
  • oldstaticproc=(WNDPROC)SetWindowLong(hstatic,GWL_WNDPROC,(long)staticproc);
  • hedit=CreateWindowEx(WS_EX_CLIENTEDGE,"edit",0,WS_VISIBLE | WS_CHILD ,30,130,300,20,hwnd,0,0,0);
  • oldeditproc=(WNDPROC)SetWindowLong(hedit,GWL_WNDPROC,(long)editproc);
  • hquitter=CreateWindowEx(0,"button","Quitter",WS_VISIBLE | WS_CHILD ,140,190,80,20,hwnd,0,0,0);
  • // Créer le Device Context en mémoire:
  • hdcmem = CreateCompatibleDC(0);
  • // Charger le bitmap de fond depuis les ressources de l'exécutable:
  • hbmp = LoadBitmap(GetModuleHandle(0), "IDB_BMP");
  • // Sélectionner ce bitmap pour le HDC en mémoire:
  • SelectObject(hdcmem, hbmp);
  • return 0;
  • case WM_CTLCOLORSTATIC:
  • case WM_CTLCOLOREDIT:
  • // Définir le mode comme transparent:
  • SetBkMode((HDC)wParam,TRANSPARENT);
  • // Définir la couleur de texte (jaune):
  • SetTextColor((HDC)wParam,RGB(255,255,0));
  • // Retourner le HBRUSH de transparence:
  • return (LRESULT)GetStockObject(NULL_BRUSH);
  • case WM_PAINT:
  • PAINTSTRUCT ps;
  • HDC hdc;
  • hdc=BeginPaint(hwnd,&ps);
  • // Afficher l'image de fond sur la surface de la fenêtre:
  • BitBlt(hdc,0,0,360,270,hdcmem,0,0,SRCCOPY);
  • EndPaint(hwnd,&ps);
  • return 0;
  • case WM_COMMAND:
  • if(HIWORD(wParam)==EN_CHANGE)
  • {
  • // Redessiner l'Edit après chaque modification:
  • InvalidateRect((HWND)lParam,0,1);
  • // Récupérer le texte de l'Edit:
  • GetWindowText((HWND)lParam,buffer,100);
  • // Le transmettre au Static:
  • SetWindowText(hstatic,buffer);
  • // Redessiner le Static:
  • InvalidateRect(hstatic,0,1);
  • return 0;
  • }
  • if((HWND)lParam==hquitter) SendMessage(hwnd,WM_CLOSE,0,0);
  • return 0;
  • case WM_CLOSE:
  • DeleteDC(hdcmem);
  • DeleteObject(hbmp);
  • DestroyWindow(hwnd);
  • break;
  • case WM_DESTROY:
  • PostQuitMessage(0);
  • break;
  • default:
  • break;
  • }
  • return DefWindowProc(hwnd,msg,wParam,lParam);
  • }
  • int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrev, LPSTR cmd,int show)
  • {
  • // Déclaration et initialisation de la strucrure WNDCLASSEX:
  • WNDCLASSEX wc;
  • memset(&wc,0,sizeof(wc));
  • wc.cbSize=sizeof(WNDCLASSEX);
  • wc.hInstance=hInst;
  • wc.lpfnWndProc=WndProc;
  • wc.hCursor=LoadCursor(0,IDC_ARROW);
  • wc.hbrBackground=0;
  • wc.lpszClassName=TEXT("mafenetre");
  • // Enregistrement de notre classe de fenêtre:
  • RegisterClassEx(&wc);
  • // Creéation et affichage de la fenêtre:
  • HWND hwnd=CreateWindowEx(0,"mafenetre","Edit et Static transparents sur fond BMP", WS_SYSMENU | WS_MINIMIZEBOX,0,0,366,296,0,0,0,0);
  • ShowWindow(hwnd,1);
  • UpdateWindow(hwnd);
  • MSG Msg;
  • // Boucle des messages:
  • while (GetMessage(&Msg, 0, 0, 0))
  • {
  • TranslateMessage(&Msg);
  • DispatchMessage(&Msg);
  • }
  • return 0;
  • }
#include <windows.h>

// Déclarations globales:
WNDPROC oldstaticproc,oldeditproc;
HDC hdcmem;

// Procédure de sous-classement du Static:
LRESULT CALLBACK staticproc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
{
	if(msg==WM_ERASEBKGND)
	{
		POINT pt;
		RECT rect;
		GetClientRect(hwnd,&rect);// Obtenir les coordonnées de la zone cliente
		pt.x=rect.left; pt.y=rect.top;
		ClientToScreen(hwnd,&pt);// Les traduire en coordonnées écran
		ScreenToClient(GetParent(hwnd),&pt);// Les traduire en coordonnées fenêtre parente
		// Dessiner la portion du fond correspondante:
		BitBlt((HDC)wParam,0,0,rect.right,rect.bottom,hdcmem,pt.x,pt.y,SRCCOPY);
		return 1;
	}
	return CallWindowProc(oldstaticproc, hwnd, msg, wParam, lParam);
}

// Procédure de sous-classement de l'Edit:
LRESULT CALLBACK editproc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
{
	if(msg==WM_ERASEBKGND)
	{
		POINT pt;
		RECT rect;
		GetClientRect(hwnd,&rect);// Obtenir les coordonnées de la zone cliente
		pt.x=rect.left; pt.y=rect.top;
		ClientToScreen(hwnd,&pt);// Les traduire en coordonnées écran
		ScreenToClient(GetParent(hwnd),&pt);// Les traduire en coordonnées fenêtre parente
		// Dessiner la portion du fond correspondante:
		BitBlt((HDC)wParam,0,0,rect.right,rect.bottom,hdcmem,pt.x,pt.y,SRCCOPY);
		return 1;
	}
	return CallWindowProc(oldeditproc, hwnd, msg, wParam, lParam);
}

// Procédure de la fenêtre principale:
LRESULT CALLBACK WndProc(HWND hwnd,UINT msg,WPARAM wParam, LPARAM lParam)
{
	static HBITMAP hbmp; 
	static HWND hedit,hstatic,hquitter;
	static char buffer[100];
	switch (msg)
	{
	case WM_CREATE:
		// Création des contrôles:
		hstatic=CreateWindowEx(0,"static",0,WS_VISIBLE | WS_CHILD | SS_CENTER,30,60,300,20,hwnd,0,0,0);
		oldstaticproc=(WNDPROC)SetWindowLong(hstatic,GWL_WNDPROC,(long)staticproc);
		hedit=CreateWindowEx(WS_EX_CLIENTEDGE,"edit",0,WS_VISIBLE | WS_CHILD ,30,130,300,20,hwnd,0,0,0);
		oldeditproc=(WNDPROC)SetWindowLong(hedit,GWL_WNDPROC,(long)editproc);
		hquitter=CreateWindowEx(0,"button","Quitter",WS_VISIBLE | WS_CHILD ,140,190,80,20,hwnd,0,0,0);
		// Créer le Device Context en mémoire:
		hdcmem = CreateCompatibleDC(0);
		// Charger le bitmap de fond depuis les ressources de l'exécutable:
		hbmp = LoadBitmap(GetModuleHandle(0), "IDB_BMP");
		// Sélectionner ce bitmap pour le HDC en mémoire:
		SelectObject(hdcmem, hbmp);
		return 0;

	case WM_CTLCOLORSTATIC:
	case WM_CTLCOLOREDIT:
		// Définir le mode comme transparent:
		SetBkMode((HDC)wParam,TRANSPARENT);
		// Définir la couleur de texte (jaune):
		SetTextColor((HDC)wParam,RGB(255,255,0));
		// Retourner le HBRUSH de transparence:
		return (LRESULT)GetStockObject(NULL_BRUSH);

	case WM_PAINT:
		PAINTSTRUCT ps;
		HDC hdc;
		hdc=BeginPaint(hwnd,&ps);
		// Afficher l'image de fond sur la surface de la fenêtre:
		BitBlt(hdc,0,0,360,270,hdcmem,0,0,SRCCOPY);
		EndPaint(hwnd,&ps);
		return 0;

	case WM_COMMAND:
		if(HIWORD(wParam)==EN_CHANGE) 
		{
			// Redessiner l'Edit après chaque modification:
			InvalidateRect((HWND)lParam,0,1);
			// Récupérer le texte de l'Edit:
			GetWindowText((HWND)lParam,buffer,100);
			// Le transmettre au Static:
			SetWindowText(hstatic,buffer);
			// Redessiner le Static:
			InvalidateRect(hstatic,0,1);
			return 0;
		}
		if((HWND)lParam==hquitter) SendMessage(hwnd,WM_CLOSE,0,0);
		return 0;

	case WM_CLOSE:
		DeleteDC(hdcmem);
		DeleteObject(hbmp);
		DestroyWindow(hwnd);
		break;

	case WM_DESTROY:
		PostQuitMessage(0);
		break;
	default:
		break;
	}
	return DefWindowProc(hwnd,msg,wParam,lParam);
}


int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrev, LPSTR cmd,int show)
{
	// Déclaration et initialisation de la strucrure WNDCLASSEX:
	WNDCLASSEX wc;
	memset(&wc,0,sizeof(wc));
	wc.cbSize=sizeof(WNDCLASSEX);
	wc.hInstance=hInst;
	wc.lpfnWndProc=WndProc;
	wc.hCursor=LoadCursor(0,IDC_ARROW);
	wc.hbrBackground=0;
	wc.lpszClassName=TEXT("mafenetre");
	// Enregistrement de notre classe de fenêtre:
	RegisterClassEx(&wc);
	// Creéation et affichage de la fenêtre:
	HWND hwnd=CreateWindowEx(0,"mafenetre","Edit et Static transparents sur fond BMP", WS_SYSMENU | WS_MINIMIZEBOX,0,0,366,296,0,0,0,0);
	ShowWindow(hwnd,1);
	UpdateWindow(hwnd);
	MSG Msg;
	// Boucle des messages:
	while (GetMessage(&Msg, 0, 0, 0)) 
	{
		TranslateMessage(&Msg);
		DispatchMessage(&Msg);
	}
	return 0;
}


 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip Source avec une capture IMPRESSION EN WIN32 API AVEC OPTIONS
Source avec Zip Source avec une capture INFOTIP SHELL EXTENSION (BULLE DE L'EXPLORATEUR WINDOWS) (WI...
Source avec Zip Source avec une capture APPLICATION MULTILINGUE UTILISANT UNICODE (WIN32)
Source avec Zip Source avec une capture CHRONOMÈTRE OSD (WIN32)
Source avec Zip Source avec une capture EXTENSION DU SHELL: MENU CONTEXTUEL EN C (WIN32 API)

 Sources de la même categorie

Source avec Zip Source avec une capture CALENDRIER (WIN64) par BruNews
Source avec Zip Source avec une capture IMPRESSION EN WIN32 API AVEC OPTIONS par racpp
Source avec Zip Source avec une capture INFOTIP SHELL EXTENSION (BULLE DE L'EXPLORATEUR WINDOWS) (WI... par racpp
Source avec Zip Source avec une capture BROUILLAGE DES FICHIERS JAVASCRIPT ET CSS(WIN32) par gagah1
Source avec Zip Source avec une capture CHANGE CURSEUR par ganjarasta

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture DRAG AND DROP SUR EDITS (WIN32 + OLE) par racpp
Source avec Zip Source avec une capture GÉNÉRATION D'UNE PALETTE OPTIMALE POUR LA RÉDUCTION DE COULE... par cali70
Source avec Zip Source avec une capture BIBLIOTHÈQUE D'ACCORDS DE GUITARE par Spinnaker
Source avec Zip INVASION 5 SMILIE par f_l_a_s_h_b_a_c_k
Source avec Zip APPLICATION WIN32 SANS FENÊTRE ET AVEC BOUCLE DES MESSAGES par racpp

Commentaires et avis

Commentaire de NeoUmbrella le 24/08/2008 18:46:01 9/10

Hello, merci pour ce code source.
J'aimerais savoir si tu sais faire la meme chose mais pour une richeditbox.
J'ai bien tenté d'ajouter le style WS_EX_TRANSPARENT ou de sous-classer la RichEdit et de dessiner mon bitmap sur le DC lorsque j'intercepte le message WM_ERASEBKGND mais pour les deux solutions, lorsque j'ajoute du texte a la rich ou que je fait défiler le texte avec la scrollbar, c'est saccadé.
Merci

Commentaire de whyspee le 25/08/2008 10:41:45

Ouais super code ! Je cherchais ça depuis longtemps mais perso je cherchais ça pour une RichTextBox puis j'y connais rien en C.  :S
Mais  j'vais essayer d'me débrouiller avec ça. :D

Commentaire de whyspee le 25/08/2008 10:45:36

Par contre j'ai une question : vous croyez que ça (exactement le même code), c'est faisable en C# ???

Commentaire de racpp le 25/08/2008 23:04:28 administrateur CS

Merci pour la note et les commentaires.
NeoUmbrella >> Je n'ai jamais essayé avec un RichEdit. Je pense effectivement que les choses peuvent se compliquer à cause des défilements. Il faudra bien comprendre le fonctionnement interne des RichEdits, surtout comment ils sont dessinés, pour pouvoir envisager une solution.
Whyspee >> Je pense que tous les langages pour Windows sont capables d'utiliser les APIs de la GDI. Ceci s'appliquerait donc au C#. Tu peux suivre la démarche de mon code pour l'appliquer dans ton code C#.

Commentaire de whyspee le 26/08/2008 09:33:22

OK merci :)
J'vais déjà voir si j'peux faire ça en VB.Net sinon en C#.
:)

Commentaire de Miquel75 le 11/09/2008 18:48:11

Quel code horrible (débutant manifestement...)
Et surtout mauvaise méthode.
Voir la méthode officielle dans MSDN, notamment pour RichEdit control.

Commentaire de NeoUmbrella le 11/09/2008 19:00:58

Hello Miquel75, j'ai cherché dans msdn mais pas trouvé, peux tu m'aiguiller ?
Sinon j'ai pas compris pourquoi le code de racpp était horrible.

Commentaire de racpp le 11/09/2008 22:13:31 administrateur CS

Miquel75 >> Pourquoi est-tu toujours si arrogant? Il parait que c'est pour cacher ton ignorance. Toutes tes interventions sur le site sont totalement inutiles. Pas la moindre argumentation, tu parles toujours de USENET ou MSDN mais sans donner le moindre lien. Tu donnes même l'impression de quelqu'un qui se croit au dessus des autres mais qui, en réalité, comprend les choses à l'envers. Cela fait des mois qu'on attend ton premier code source sur le site pour nous apprendre à programmer. Alors qu'est-ce que tu attends? Tu as peur de t'exposer? Es-tu complexé par ce que font les autres?

Commentaire de victorcoasne le 15/03/2009 13:44:56 10/10

Très bonne source, j'ai juste un problème :
J'ai essayé de mettre un checkbox à la place de ton static mais il apparaît comme noir.
As-tu une idée, pourquoi ?

Commentaire de racpp le 30/03/2009 19:43:09 administrateur CS

Bonjour Victorcoasne et merci pour la note. Désolé de répondre tard car j'étais très occupé tout ce mois de mars.
Pour ta question j'aimerais juste rappeler qu'un CheckBox est un bouton. Or, dans mon code je sous-classe un Static et un Edit. Il est donc possible d'avoir des anomalies. Si j'ai un peu de temps je ferai des test et je verrai comment y remédier.

Commentaire de victorcoasne le 30/03/2009 21:24:11

J'ai trouvé, il faut utiliser DrawThemeParentBackground() et détecter les thèmes XP pour les statics.
En revance pour les edits il faut remplacer par des richedit avec WS_EX_TRANSPARENT

Commentaire de racpp le 31/03/2009 00:18:33 administrateur CS

Je ne connaissais pas cette fonction car je n'aime pas utiliser les thèmes. Je viens de voir que c'est une fonction assez récente car disponiple depuis XP. Merci de l'avoir mentionnée ça pourrait toujours servir.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

mettre le fond du static en blanc [ par ggoufa ] Salut a tous,est ce que quelqu'un sait comment on met le fond d'un static en blanc (ou d'une autre couleur) car j'ai mis le fond de ma boite de dialog Bitmap et static [ par DjGonk ] Slt!J'arriver a mettre une bitmap dans un static mais le probleme c'est que je voudrais que l'image et la taille du static. c a d quelle soit redimans Static text fond transparant mais text plein au secours [ par youpiyoyo ] Je sais po si mon titre est explicite mais j'aurai besoin d'ajouter sur une picture control un static text.le probleme c k'il garde la couleur de la b couleur de fond d'une editbox [ par melkiorlenecrarque ] salut kan je coche la case read-only d'une edit box, L devi1 griée!pe ton chanG la couleur de fon d'une edit box?G essayé SetColor() mé lé parametre m [MFC] Image BITMAP en fond avec Edit et Combo Box visibles dessus [ par tom911 ] Bonjour, je me prends la tête depuis plusieurs jours à essayer de mettre en arrière-plan une image bitmap qui se trouve dans un cStatic avec les MFC.E poser un bitmap bouton sur un fond [ par keyaz ] Bonjour, je suis actuellement en train d'essayer de faire apparaitre un bouton ac un bitmap sur un fond ayant lui meme un bitmap.Est ce que quelqu'un CStatic fond transparent MFC [ par PACAL7585 ] Bonjour,Je cherche a faire un CStatic avec un fondtransparent... j'ai trouver plein de code sur cppfrance, mais ca ne fonctionne pas avec mon appli, o Mask Edit sous fond transparent [ par toxjamescook ] Bonjour,j'aimerais savoir si il est possible de rendre le fond transparent d'un Mask Edit ou d'un Edit. j'ai pu voir pas mal de code permettant de cha mettre un bitmap sur un fond qui a deja un bitmap, pb [ par gege1024 ] voila: j'ai un dialogue avec une image en fond (bacground),par dessus je veux afficher un autre bitmap, mais le pb est que celui-ci s'affiche avec une bitmap sur fond [ par yoshyman ] est t il possible d' afficher un bit map sur un fond "colori&#233;"?si oui comment?


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,186 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales