Définit ou efface les matrices d'ajustement des couleurs - et de niveaux de gris - pour une catégorie déterminée
#include <GDIPlus.au3>
_GDIPlus_ImageAttributesSetColorMatrix ( $hImageAttributes [, $iColorAdjustType = 0 [, $bEnable = False [, $tClrMatrix = 0 [, $tGrayMatrix = 0 [, $iColorMatrixFlags = 0]]]]] )
$hImageAttributes | Handle de l'objet ImageAttribute |
$iColorAdjustType | [optionnel] La catégorie pour laquelle les matrices d'ajustement des couleurs - et de niveaux de gris - sont définies ou effacés: 0 - L'ajustement couleur ou niveaux de gris s'applique à toutes les catégories qui n'ont pas leurs propres paramètres de réglage 1 - L'ajustement couleur ou niveaux de gris s'applique à des images bitmap 2 - L'ajustement couleur ou niveaux de gris s'applique aux opérations de pinceau dans les métafichiers 3 - L'ajustement couleur ou niveaux de gris s'applique aux opérations de crayon dans les métafichiers 4 - L'ajustement couleur ou niveaux de gris s'applique au texte dessiné dans les métafichiers |
$bEnable | [optionnel] If True, the specified matrices (color, grayscale or both) adjustments for the specified |
$tClrMatrix | [optionnel] Structure $tagGDIPCOLORMATRIX qui spécifie une matrice d'ajustement des couleurs |
$tGrayMatrix | [optionnel] Structure $tagGDIPCOLORMATRIX qui spécifie une matrice d'ajustement en niveaux de gris |
$iColorMatrixFlags | [optionnel] Type d'image et de couleur qui seront concernée par les matrices d'ajustement: 0 - Toutes les valeurs de couleur (y compris les gris) sont ajustées par la même matrice couleur d'ajustement 1 - Les couleurs sont ajustées mais les nuances de gris ne sont pas ajustées. 2 - Les couleurs sont ajustées par une matrice et les nuances de gris sont ajustées par une autre matrice |
Succès: | Retourne True. |
Échec: | Retourne False et définit @error <> 0, @extended contient le code erreur ($GPID_ERR*). |
$tagGDIPCOLORMATRIX, _GDIPlus_ColorMatrixCreate, _GDIPlus_ColorMatrixCreateGrayScale
Consultez GdipSetImageAttributesColorMatrix dans la Librairie MSDN.
#include <GDIPlus.au3> #include <GUIConstantsEx.au3> #include <ScreenCapture.au3> #include <WinAPIHObj.au3> Example() Func Example() _GDIPlus_Startup() ; Initialise GDI+ Local Const $iWidth = 600, $iHeight = 600 Local $hGUI = GUICreate("GDI+ example", $iWidth, $iHeight) ; Crée une fenêtre de test GUISetState(@SW_SHOW) Local $hGraphics = _GDIPlus_GraphicsCreateFromHWND($hGUI) ; Crée un objet Graphics à partir du handle de la fenêtre Local $hIA = _GDIPlus_ImageAttributesCreate() ; Crée un objet ImageAttribute Local $tColorMatrix = _GDIPlus_ColorMatrixCreateTranslate(0.5, 0.5, 0.5) ; Crée la matrice de luminosité des couleurs _GDIPlus_ImageAttributesSetColorMatrix($hIA, 0, True, $tColorMatrix) ; Ajuste la luminosité de l'image à 50 % plus lumineux Local $hHBmp = _ScreenCapture_Capture("", 0, 0, $iWidth, $iHeight) ; Crée un bitmap GDI en capturant une région du bureau Local $hBitmap = _GDIPlus_BitmapCreateFromHBITMAP($hHBmp) ; Convertit le bitmap GDI en GDI+ _WinAPI_DeleteObject($hHBmp) ; Libère la ressource du bitmap GDI car elle n'est plus utile _GDIPlus_GraphicsDrawImageRectRect($hGraphics, $hBitmap, 0, 0, $iWidth, $iHeight, 0, 0, $iWidth, $iHeight, $hIA) ; Dessine le bitmap tout en appliquant le réglage de la couleur Do Until GUIGetMsg() = $GUI_EVENT_CLOSE ; Nettoie les ressources GDI+ _GDIPlus_ImageAttributesDispose($hIA) _GDIPlus_GraphicsDispose($hGraphics) _GDIPlus_BitmapDispose($hBitmap) _GDIPlus_Shutdown() GUIDelete($hGUI) EndFunc ;==>Example