begin process at 2012 05 27 15:34:25
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Graphique

 > DESSINER UNE IMAGE TRANSPARENTE (WIN32)

DESSINER UNE IMAGE TRANSPARENTE (WIN32)


 Information sur la source

Note :
10 / 10 - par 3 personnes
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Graphique Classé sous :updatelayeredwindow, png, image, transparente, alpha Niveau :Débutant Date de création :28/06/2006 Date de mise à jour :02/07/2006 12:15:43 Vu / téléchargé :13 475 / 1 125

Auteur : vecchio56

Ecrire un message privé
Ce membre participe au partage de revenus publicitaires
Commentaire sur cette source (9)
Ajouter un commentaire et/ou une note


 Description

Ce code montre comment dessiner une image avec de la transparence, mais de manière non uniforme (les régions de l'image sont plus ou moins transparentes). Ceci est fait grâce à l'API UpdateLayeredWindow. Le code n'est pas spécialement compliqué ni long, mais j'ai quand même cherché une bonne journée avant de réussir a avoir ce résultat.
L'image est a l'origine stockée dans une image png (format qui gère la transparence). J'utilise les librairies libpng et CxImage pour supporter ce format.

Source

  • #define _CRT_SECURE_NO_DEPRECATE
  • #define _WIN32_WINNT 0x0501
  • #define _WIN32_IE 0x0501
  • #include <windows.h>
  • #include "ximage.h"
  • #include "ximapng.h"
  • HWND g_hWnd;
  • char g_szAppName[] = "Transparence";
  • int alpha = 255;
  • void SetImage(LPCTSTR fileName, int alpha)
  • {
  • CxImage img;
  • img.Load(fileName, CXIMAGE_FORMAT_PNG);
  • RECT rcWnd;
  • GetWindowRect(g_hWnd, &rcWnd);
  • POINT ptWindowScreenPosition = {rcWnd.left, rcWnd.top}, ptSrc = {0, 0};
  • SIZE size = {img.GetWidth(), img.GetHeight()};
  • HDC dcScreen = GetDC(0);
  • // Création d'un dc mémoire de la taille de l'image, et dans lequel on dessine l'image
  • HDC hmemdc = CreateCompatibleDC(dcScreen);
  • HBITMAP hbmp = CreateCompatibleBitmap(dcScreen, size.cx, size.cy);
  • HGDIOBJ oldbmp = SelectObject(hmemdc, hbmp);
  • img.Draw(hmemdc);
  • BITMAP bmp;
  • GetObject(hbmp, sizeof bmp, &bmp);
  • BITMAPINFO bi;
  • memset(&bi, 0, sizeof bi);
  • bi.bmiHeader.biSize = sizeof bi.bmiHeader;
  • bi.bmiHeader.biWidth = bmp.bmWidth;
  • bi.bmiHeader.biHeight = bmp.bmHeight;
  • bi.bmiHeader.biBitCount= bmp.bmBitsPixel;
  • bi.bmiHeader.biPlanes = bmp.bmPlanes;
  • bi.bmiHeader.biCompression = BI_RGB;
  • int nbbytes = bmp.bmBitsPixel * bmp.bmWidth * bmp.bmHeight / 8;
  • LPBYTE lpBits = new BYTE[nbbytes];
  • // Récupération des bits de l'image
  • GetDIBits(hmemdc, hbmp, 0, bmp.bmHeight, lpBits, &bi, DIB_RGB_COLORS);
  • // C'est ca que j'ai eu du mal à trouver:
  • // ici on gère la transparence des pixels un par un
  • LPBYTE pAlpha = img.AlphaGetPointer();
  • for(int i = 0; i < nbbytes; i += 4) lpBits[i + 3] = *pAlpha++;
  • SetDIBits(hmemdc, hbmp, 0, bmp.bmHeight, lpBits, &bi, DIB_RGB_COLORS);
  • delete[] lpBits;
  • BLENDFUNCTION bf = {AC_SRC_OVER, 0, alpha, AC_SRC_ALPHA};
  • UpdateLayeredWindow(g_hWnd, dcScreen, &ptWindowScreenPosition, &size, hmemdc, &ptSrc, 0, &bf, ULW_ALPHA);
  • SelectObject(hmemdc, oldbmp);
  • DeleteObject(hbmp);
  • DeleteDC(hmemdc);
  • ReleaseDC(0, dcScreen);
  • }
  • LRESULT CALLBACK AppWndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
  • {
  • switch(uMsg)
  • {
  • case WM_KEYDOWN:
  • switch(wParam)
  • {
  • case VK_ESCAPE:
  • case VK_RETURN:
  • DestroyWindow(hWnd);
  • break;
  • case VK_UP:
  • if(alpha > 0) alpha--;
  • SetImage("image.png", alpha);
  • break;
  • case VK_DOWN:
  • if(alpha != 255) alpha++;
  • SetImage("image.png", alpha);
  • break;
  • }
  • break;
  • case WM_NCHITTEST:
  • return HTCAPTION;
  • case WM_DESTROY:
  • PostQuitMessage(0);
  • return 0;
  • }
  • return DefWindowProc(hWnd, uMsg, wParam, lParam);
  • }
  • #ifdef _DEBUG
  • int main()
  • #else
  • int APIENTRY WinMain(HINSTANCE, HINSTANCE, LPTSTR, int)
  • #endif
  • {
  • MSG msg;
  • HINSTANCE g_hInst = GetModuleHandle(0);
  • WNDCLASSEX wcex;
  • memset(&wcex, 0, sizeof wcex);
  • wcex.cbSize = sizeof wcex;
  • wcex.lpfnWndProc = AppWndProc;
  • wcex.style = CS_HREDRAW | CS_VREDRAW;
  • wcex.hInstance = g_hInst;
  • wcex.lpszClassName = g_szAppName;
  • wcex.hbrBackground = GetSysColorBrush(COLOR_WINDOW);
  • wcex.hCursor = LoadCursor(0, IDC_ARROW);
  • RegisterClassEx(&wcex);
  • g_hWnd = CreateWindowEx(WS_EX_LAYERED, g_szAppName, g_szAppName, WS_OVERLAPPED | WS_SYSMENU,
  • 0, 0, CW_USEDEFAULT, CW_USEDEFAULT, 0, 0, g_hInst, 0);
  • SetImage("image.png", alpha);
  • ShowWindow(g_hWnd, SW_SHOW);
  • while(GetMessage(&msg, NULL, 0, 0))
  • {
  • TranslateMessage(&msg);
  • DispatchMessage(&msg);
  • }
  • return (int)msg.wParam;
  • }
#define _CRT_SECURE_NO_DEPRECATE
#define _WIN32_WINNT 0x0501
#define _WIN32_IE 0x0501
#include <windows.h>

#include "ximage.h"
#include "ximapng.h"

HWND g_hWnd;
char g_szAppName[] = "Transparence";
int alpha = 255;

void SetImage(LPCTSTR fileName, int alpha)
{
  CxImage img;
  img.Load(fileName, CXIMAGE_FORMAT_PNG);
  RECT rcWnd;
  GetWindowRect(g_hWnd, &rcWnd);
  POINT ptWindowScreenPosition = {rcWnd.left, rcWnd.top}, ptSrc = {0, 0};
  SIZE size = {img.GetWidth(), img.GetHeight()};

  HDC dcScreen = GetDC(0);

  // Création d'un dc mémoire de la taille de l'image, et dans lequel on dessine l'image
  HDC hmemdc = CreateCompatibleDC(dcScreen);
  HBITMAP hbmp = CreateCompatibleBitmap(dcScreen, size.cx, size.cy);
  HGDIOBJ oldbmp = SelectObject(hmemdc, hbmp);
  img.Draw(hmemdc);

  BITMAP bmp;
  GetObject(hbmp, sizeof bmp, &bmp);

  BITMAPINFO bi;
  memset(&bi, 0, sizeof bi);
  bi.bmiHeader.biSize = sizeof bi.bmiHeader;
  bi.bmiHeader.biWidth = bmp.bmWidth;
  bi.bmiHeader.biHeight = bmp.bmHeight;
  bi.bmiHeader.biBitCount= bmp.bmBitsPixel;
  bi.bmiHeader.biPlanes = bmp.bmPlanes;
  bi.bmiHeader.biCompression = BI_RGB;

  int nbbytes = bmp.bmBitsPixel * bmp.bmWidth * bmp.bmHeight / 8;
  LPBYTE lpBits = new BYTE[nbbytes];
  // Récupération des bits de l'image
  GetDIBits(hmemdc, hbmp, 0, bmp.bmHeight, lpBits, &bi, DIB_RGB_COLORS);
  // C'est ca que j'ai eu du mal à trouver:
  // ici on gère la transparence des pixels un par un
  LPBYTE pAlpha = img.AlphaGetPointer();
  for(int i = 0; i < nbbytes; i += 4) lpBits[i + 3] = *pAlpha++;

  SetDIBits(hmemdc, hbmp, 0, bmp.bmHeight, lpBits, &bi, DIB_RGB_COLORS);
  delete[] lpBits;
  

  BLENDFUNCTION bf = {AC_SRC_OVER, 0, alpha, AC_SRC_ALPHA};
  UpdateLayeredWindow(g_hWnd, dcScreen, &ptWindowScreenPosition, &size, hmemdc, &ptSrc, 0, &bf, ULW_ALPHA);

  SelectObject(hmemdc, oldbmp);
  DeleteObject(hbmp);
  DeleteDC(hmemdc);
  ReleaseDC(0, dcScreen);
}

LRESULT CALLBACK AppWndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
  switch(uMsg)
  {
  case WM_KEYDOWN:
    switch(wParam)
    {
    case VK_ESCAPE:
    case VK_RETURN:
      DestroyWindow(hWnd);
      break;
    case VK_UP:
      if(alpha > 0) alpha--;
      SetImage("image.png", alpha);
      break;
    case VK_DOWN:
      if(alpha != 255) alpha++;
      SetImage("image.png", alpha);
      break;
    }
    break;
  case WM_NCHITTEST:
    return HTCAPTION;
  case WM_DESTROY:
    PostQuitMessage(0);
    return 0;
  }
  return DefWindowProc(hWnd, uMsg, wParam, lParam);
}


#ifdef _DEBUG
int main()
#else
int APIENTRY WinMain(HINSTANCE, HINSTANCE, LPTSTR, int)
#endif
{
  MSG msg;
  HINSTANCE g_hInst = GetModuleHandle(0);
  WNDCLASSEX wcex;

  memset(&wcex, 0, sizeof wcex);
  wcex.cbSize         = sizeof wcex;
  wcex.lpfnWndProc    = AppWndProc;
  wcex.style          = CS_HREDRAW | CS_VREDRAW;
  wcex.hInstance      = g_hInst;
  wcex.lpszClassName  = g_szAppName;
  wcex.hbrBackground  = GetSysColorBrush(COLOR_WINDOW);
  wcex.hCursor        = LoadCursor(0, IDC_ARROW);
  RegisterClassEx(&wcex);

  g_hWnd = CreateWindowEx(WS_EX_LAYERED, g_szAppName, g_szAppName, WS_OVERLAPPED | WS_SYSMENU,
    0, 0, CW_USEDEFAULT, CW_USEDEFAULT, 0, 0, g_hInst, 0);

  SetImage("image.png", alpha);
  ShowWindow(g_hWnd, SW_SHOW);

  while(GetMessage(&msg, NULL, 0, 0))
  {
    TranslateMessage(&msg);
    DispatchMessage(&msg);
  }
  return (int)msg.wParam;
}


 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


 Historique

02 juillet 2006 12:15:43 :
-Quitter le programme quand on appuie sur echap ou entrée -Modication de la transparence avec les touches haut/bas

 Sources du même auteur

Source avec Zip COLORATION DE CODE C/C++ POUR LE FORUM DE CPPFRANCE
Source avec Zip SUPPRIMER LES # AJOUTÉS LORS D'UN COPIER/COLLER
Source avec Zip Source avec une capture CRÉER UN FICHIER ISO À PARTIR D'UN RÉPERTOIRE (WIN32)
Source avec Zip Source avec une capture EXPLORATEUR DE FICHIERS ISO
Source avec Zip Source avec une capture CHARGER UNE POLICE DEPUIS UN FICHIER OU UNE RESSOURCE (WIN32...

 Sources de la même categorie

Source avec Zip Source avec une capture PLANNING D'EQUIPE par grephit
Source avec Zip APPLICATION DE DESSIN DE QUELQUES FIGURES par laguchori
Source avec Zip Source avec une capture HDR EXPOSURE FUSION par mecrosoft
Source avec Zip Source avec une capture IRC CLIENT MULTISERVEUR EN MFC (TXIRC) par TeniX
Source avec Zip ENTETE DU FICHIER BMP (BIPMAP) par k.Lutchi

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture GENERE BMP par lajouad
Source avec Zip Source avec une capture HDR EXPOSURE FUSION par mecrosoft
Source avec Zip Source avec une capture VISUALISATION DES IMAGES EN 3D SANS OPENGL par Pistol_Pete
Source avec Zip Source avec une capture ANALYSE DE LA TEXTURE D'UNE IMAGE : FILTRE DE GABOR par Pistol_Pete
Source avec Zip Source avec une capture ID3 TAG COVER ALBUM IMAGE par nanonavich

Commentaires et avis

Commentaire de wxccxw le 28/06/2006 19:36:49

si elle est transparent, alors on la vois pas ^^ !! non desoler blague a part. sinon interressant, j'ai pas encore tout compris

Commentaire de vecchio56 le 28/06/2006 20:08:43 administrateur CS

Transparent: se dit d'un corps à travers lequel les objets sont nettements distingués
Mais une fenêtre est-elle un corps?

Commentaire de algori le 30/06/2006 21:44:35

Ca fonctionne très bien.
Merci pour les libpng et CxImage.
Juste un détail : faudrait juste rajouter une commande ECHAP pour quitter et éviter ainsi de passer par le gestionnaire de tâches...
Bonne continuation.
@++

Commentaire de vecchio56 le 02/07/2006 12:17:09 administrateur CS

Voila qui est fait
Mais tu pouvais faire un clic droit sur la barre des taches pour fermer le prog, ou en core Alt+F4

Commentaire de algori le 02/07/2006 13:35:08

lol. Quelle idiot ! J'avais complètement oublié. :-p

Commentaire de AprilCpp le 14/09/2006 21:11:21

Désolé de poster un commentaire 3 mois après la parution de cette source.

Bravo à Vecchio56 qui a réalisé un chouette travail :p

Pour mon information, croyez-vous possible l'utilisation de la fonction UpdateLayeredWindow sur un fichier vidéo ou le canal alpha serait défini ?

Commentaire de Lutinore le 24/09/2007 22:52:21 administrateur CS

Le but, est-ce bien d'avoir le texte de l'image totalement opaque et le reste de l'image transparente ?

Je pense que la partie qui t'as posé un problème, là où tu récupères les pixels un par un est inutile.. j'obtiens le même résultat sans manipuler les pixels. C'est peut être la méthode Draw de librairie CxImage qui te joue des tours. Tu devrais essayer avec Bitmap::GetHBITMAP de GDI+.

Commentaire de Laurent1313 le 15/12/2008 01:14:55 10/10

Merci, merci, merci ! Super code qui marche du premier coup sans le moindre changement à faire. Depuis une semaine, j'ai cherché partout un exemple pour dessiner une PNG par dessus l'écran et il n'y a que le tien qui fonctionne. Et sans MFC en plus - chapeau !

Commentaire de supergrey le 26/07/2010 08:45:03

Salut, je viens d'essayer ta source, elle semble fonctionner mais après quelques secondes (variable) l'image disparait pour laisser place à une fenetre standard. Quelqu'un aurait une idée ?
(pour info je suis sous windows 7)

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

conversion d'un format png en image bmp [ par REk2002 ] bonjour je cherche un programme simple permettant de convertir une image png en bmp. merci d'avance au revoir OpenGL : Couleur Transparente (composante alpha) [ par smoove5198 ] Bonjour, Je fait de l'affichage 3D avec opengl et je souhaite utiliser le principe de couleur transparente. Apres m'etre un peu renseign&#233; j'ai Rotation image (matrice) ? [ par albert0 ] Bonjour, voil&#224;, je suis sur un petit projet. Il consite a charger une image en .RAW (binaire) et de l'afficher sous di&#233;frente forme. D Comment convertir une image png en bmp? [ par REk2002 ] Je cherche un programme pas trop compliqué à comprendre pour convertir une images png en format bmp. Importation d'un .png dans un tabeau [ par Davy8x ] Je voudrais importer une image au foramt .png dans un tableau en C.Si quelqu'un peu m'aider...Exemple :{Rouge,Vert,Bleu,Alpha,Rouge,Vert,Bleu,Alpha,Ro Modifier la résolution d'un PNG [ par Inxday2005 ] Bonjour &#224; tous, Je voudrais faire un prog qui modifie la r&#233;solution d'une image PNG : Disons que j'ai une image 800*600 en 72 dpi je voud [wxWIDGETS] -- PNG en resources [ par satellite34 ] bonjour,je cherche a&nbsp;charger une image de type png a partir d'un fichier rc avec wxWIDGETS;Je souhaite charger cette image a partir du fichier .r Lire une image PNG libpng [ par shub85 ] Bonjour, je voulais savoir si quelqu'un utilise libpng ou si il l'as utilisé. Je cherche à récupérer mes valeurs pixels d'une image 1280*960 , 16 bits [C] Impossible de lire le contenu d'une image png [ par JMGR ] Bonjour &#224; tous,j'ai un petit probl&#232;me :Je veut transf&#233;rer une image png d'un client vers un serveur.Seulement lorsque je tente de lire traitement d'image à l'aide de Cximage [ par yoben ] Bonjour,L'objectif de mon programme est de r&#233;cup&#233;rer un tableau de pixels d'un fichier contenant une image &#224; partir d'un emplacement qu


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
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,061 sec (3)

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