| |

Fortgeschrittene ProgrammierungRe: dll erstellen | |  | Autor: VB_User | Datum: 03.11.05 19:23 |
| Hallo, ich habe hier eine Funktion im Internet gefunden, mit der man die Ansicht des Desktops ändern kann.
Diese Funktion wollte ich in eine DLL Datei auslagern. Dies sieht bei mir so aus:
cDA.dll
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" ( _
ByVal hWnd As Long, ByVal nIndex As Long) As Long
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal _
hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal _
lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function GetWindow Lib "user32" (ByVal hWnd As Long, ByVal wCmd _
As Long) As Long
Private Const VM_ICON = &H0
Private Const VM_REPORT = &H1
Private Const VM_SMALLICON = &H2
Private Const VM_LIST = &H3
Private Const GW_CHILD = 5
Private Const GWL_STYLE = (-16)
Private Const LVS_TYPEMASK = &H3
Private Const WM_STYLECHANGED = &H7D
Private Type strukt
Alt As Long
Neu As Long
End Type
Function DLLMain(ByVal ansicht As Long) As Boolean
DLLMain = 1
End Function
Sub Main()
'Leer
End Sub
Function Style(ByVal ansicht As Long) As Boolean
Dim hWnd As Long
Dim st As strukt
On Error GoTo fehler
hWnd = FindWindow("Progman", "Program Manager")
hWnd = GetWindow(hWnd, GW_CHILD)
hWnd = GetWindow(hWnd, GW_CHILD)
With st
.Alt = GetWindowLong(hWnd, GWL_STYLE)
.Neu = .Alt
.Neu = .Neu And Not LVS_TYPEMASK
.Neu = .Neu Or ansicht
End With
SendMessage hWnd, WM_STYLECHANGED, GWL_STYLE, st
Style = True
Exit Function
fehler:
Style = False
End Function Und der Aufruf der Funktion sieht so aus:
Private Declare Function Style Lib "cDA.dll" (ByVal ansicht As Long) As Boolean
Private Sub Command1_Click(Index As Integer)
Dim result As Boolean
Select Case Index
Case 0: result = Style(VM_ICON)
Case 1: result = Style(VM_SMALLICON)
Case 2: result = Style(VM_LIST)
Case 3: result = Style(VM_REPORT)
End Select
If result = True Then
MsgBox "Style wurde geändert.", vbInformation
Else
MsgBox "Style wurde NICHT geändert.", vbCritical
End If
End Sub Jetzt habe ich jedoch das Problem, dass immer False zurückgegeben wird.
Habt Ihr eine Idee warum und was ich evtl. falsch mache?!
Ich habe genau die PDF-Anleitung befolgt, nur es kommt immer das gleiche raus. |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
Neu! sevEingabe 3.0 
Einfach stark!
Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. Weitere InfosTipp des Monats Oktober 2025 Matthias KozlowskiUmlaute konvertierenErsetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) Access-Tools Vol.1 
Über 400 MByte Inhalt
Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB
Nur 24,95 EURWeitere Infos
|
|
|
Copyright ©2000-2025 vb@rchiv Dieter Otter Alle Rechte vorbehalten.
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.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|