Vor kurzem haben wir Ihnen gezeigt, wie sich prüfen lässt, ob eine bestimmte DLL vorhanden ist und ob es sich bei der DLL um eine Standard-DLL oder eine ActiveX-DLL handelt. Siehe hierzu auch: Prüfen ob DLL vorhanden und DLL-Typ ermitteln Wenn Sie sich diesen Tipp einmal ganz genau ansehen, dann entdecken Sie, dass man hiermit ebenfalls prüfen kann, ob eine bestimmte Funktion in der DLL vorhanden ist oder nicht (siehe Prüfung, ob es sich um eine ActiveX-DLL handelt). Nachfolgende Funktion baut auf oben genannten Tipp auf und prüft die Verfügbarkeit einer DLL-Funktion. Option Explicit ' Benötrite API-Deklarationen Private Declare Function LoadLibrary Lib "kernel32" _ Alias "LoadLibraryA" ( _ ByVal lpLibFileName As String) As Long Private Declare Function FreeLibrary Lib "kernel32" ( _ ByVal hLibModule As Long) As Long Private Declare Function GetProcAddress Lib "kernel32" ( _ ByVal hModule As Long, _ ByVal lpProcName As String) As Long ' Funktion in DLL vorhanden? Public Function DLLFunctionAvail(ByVal sFile As String, _ ByVal sProcedure As String) As Boolean Dim nHandle As Long ' DLL laden nHandle = LoadLibrary(sFile) If nHandle <> 0 Then ' Versuch die Adresse der Funktion zu ermitteln If CBool(GetProcAddress(nHandle, sProcedure)) = True Then ' Jepp: Funktion vorhanden DLLFunctionAvail = True End If ' Speicher wieder freigeben Call FreeLibrary(nHandle) End If End Function Die Funktion DLLFunctionAvail erwartet als ersten Parameter den Namen der DLL-Datei. Wird kein Pfad angegeben, wird in den Systempfaden nach der DLL gesucht. Als zweiten Parameter wird der Name der Funktion/Prozedur erwartet. Existiert die Prozedur wird TRUE zurückgegeben, andernfalls FALSE. HINWEIS: Beispiel: Die Funktion SetLayeredWindowAttributes aus der User32.dll steht erst ab Windows 2000 oder höher zur Verfügung. Wenn Sie diese Funktion in Ihrer Anwendung verwenden können Sie entweder das Betriebssystem abfragen oder ab sofort auch direkt die Verfügbarkeit der Funktion prüfen.' Prüfen, ob die Funktion "SetLayeredWindowAttributes" ' zur Verfügung steht If DLLFunctionAvail("user32", "SetLayeredWindowAttributes") Then ... End If Dieser Tipp wurde bereits 15.849 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (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. |
sevOutBar 4.0 Vertikale Menüleisten á la Outlook Erstellen von Outlook ähnlichen Benutzer- interfaces - mit beliebig vielen Gruppen und Symboleinträgen. Moderner OfficeXP-Style mit Farbverläufen, Balloon-Tips, u.v.m. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.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. |