Viele Anwendungen oder DLLs beinhalten nicht nur ein einziges ICON (Bildsymbol), sondern meist eines in der Größe 16x16 (small) und eines in der Größe 32x32 (large). Oftmals sindfür eine Anendung noch weitere zusätzliche Icons gespeichert. Möchten Sie z.B. ein Programm erstellen, welches alle Icons einer Anwendung oder DLL extrahiert, so ist der nachfolgende Tipp genau der richtige für Sie. ' zunächst die benötigten API-Deklarationen Private Declare Function DestroyIcon Lib "user32.dll" ( _ ByVal hIcon As Long) As Long Private Declare Function ExtractIconEx Lib "shell32.dll" _ Alias "ExtractIconExA" ( _ ByVal lpszFile As String, _ ByVal nIconIndex As Long, _ phiconLarge As Long, _ phiconSmall As Long, _ ByVal nIcons As Long) As Long Private Declare Function DrawIconEx Lib "user32.dll" ( _ ByVal hdc As Long, _ ByVal xLeft As Long, _ ByVal yTop As Long, _ ByVal hIcon As Long, _ ByVal cxWidth As Long, _ ByVal cyWidth As Long, _ ByVal istepIfAniCur As Long, _ ByVal hbrFlickerFreeDraw As Long, _ ByVal diFlags As Long) As Long Const DI_COMPAT = &H4 Const DI_DEFAULTSIZE = &H8 Const DI_IMAGE = &H2 Const DI_MASK = &H1 Const DI_NORMAL = &H3 Die Funktion ExtractIconEx liefert einerseits die Handles der Icons (large und small) zurück, zum anderen läßt sich über die Funktion aber auch die Anzahl vorhandenener Icons ermitteln. ' Liefert die Anzahl der vorhandenen Icons einer ' EXE- oder DLL-Datei Public Function GetIconCount(ByVal Filename As String) _ As Integer GetIconCount = ExtractIconEx(Filename, -1, 0&, 0&, 0&) End Function Der nachfolgende Code ermittelt die Handles für das normale Icon (large, 32x32) und des kleinen Icons (small, 16x16). ' Handle der Icons (large und small) Dim LargeIconArray(0) As Long Dim SmallIconArray(0) As Long ExtractIconEx Filename, IconIndex, LargeIconArray(0), _ SmallIconArray(0), 1 Anzeigen der Icons ' Zeichnet das "Große Icon" With LargeIconPic .Width = Screen.TwipsPerPixelX * 32 .Height = Screen.TwipsPerPixelY * 32 .Cls DrawIconEx .hdc, 0, 0, LargeIconArray(0), _ 32, 32, 0&, 0&, DI_NORMAL .Refresh End With ' Zeichnet das "Kleine Icon" With SmallIconPic .Width = Screen.TwipsPerPixelX * 16 .Height = Screen.TwipsPerPixelY * 16 .Cls DrawIconEx .hdc, 0, 0, SmallIconArray(0), _ 16, 16, 0&, 0&, DI_NORMAL .Refresh End With Nach getaner Arbeit sollten die Handles wieder freigegeben werden. ' Handle wieder freigeben DestroyIcon LargeIconArray(0) DestroyIcon SmallIconArray(0) Ermitteln ALLER Icons einer Datei ' Anzahl Icons Dim nCount As Long nCount = GetIconCount(Filename) ' Handles der Icons Dim LargeIconArray(nCount) As Long Dim SmallIconArray(nCount) As Long ExtractIconEx Filename, 0, LargeIconArray(0), _ SmallIconArray(0), nCount ... ' Handles wieder freigeben For i = 0 To nCount DestroyIcon LargeIconArray(i) DestroyIcon SmallIconArray(i) Next i Nur large Icon ' nur "großes Icon" Dim LargeIconArray(0) As Long ExtractIconEx Filename, IconIndex, LargeIconArray(0), 0, 1 ... ' Handle wieder freigeben DestroyIcon LargeIconArray(0) Dieser Tipp wurde bereits 21.468 mal aufgerufen.
Anzeige
![]() ![]() ![]() (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
Neu! sevCommand 4.0 ![]() Professionelle Schaltflächen im modernen Design! Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. Tipp des Monats ![]() Dietrich Herrmann Zwei spezielle Array-Funktionen (VB6, VBA, Word2007) Der Tipp zeigt 2 spezielle Funktionen zur Verwendung mit Arrays. vb@rchiv CD Vol.6 ![]() ![]() Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |