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 22.116 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. |
sevAniGif (VB/VBA) ![]() Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. Tipp des Monats ![]() Manfred Bohn IndexOf für mehrdimensionale Arrays Die generische Funktion "IndexOf" ermittelt das erste Auftreten eines bestimmten Wertes in einem n-dimensionalen Array TOP Entwickler-Paket ![]() TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1866.50 EUR... |
||||||||||||||||
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. |