Rubrik: Oberfläche · Sonstiges | VB-Versionen: VB5, VB6 | 29.06.05 |
Windows XP Style nachträglich einfügen II Dieser Tipp verrät, wie man Manifest-Dateien komplett ohne Zusatzsoftware in eine bestehende Anwendung integrieren kann. | ||
Autor: Martin Walcher | Bewertung: | Views: 11.848 |
www.martinwalcher.de | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | kein Beispielprojekt |
In einem vorhergehende Tipp wurde gezeigt, wie es mittels des Resource-Hacker möglich ist, nachträglich Manifest-Dateien in eine Anwendung einzufügen und somit XP-Styles zu aktivieren.
Mit diesem Tipp kann man das komplett ohne Zusatzsoftware zu tun!
Als erstes füge man folgenden Code in eine Form (oder Modul, Klasse, etc.) ein:
' bentöigte API-Deklarationen Private Declare Function BeginUpdateResource Lib "kernel32.dll" _ Alias "BeginUpdateResourceA" ( _ ByVal pFileName As String, _ ByVal bDeleteExistingResources As Long) As Long Private Declare Function UpdateResource Lib "kernel32.dll" _ Alias "UpdateResourceA" ( _ ByVal hUpdate As Long, _ ByVal lpType As Any, _ ByVal lpName As Any, _ ByVal wLanguage As Long, _ ByRef lpData As Any, _ ByVal cbData As Long) As Long Private Declare Function EndUpdateResource Lib "kernel32.dll" _ Alias "EndUpdateResourceA" ( _ ByVal hUpdate As Long, _ ByVal fDiscard As Long) As Long Private Const manifest As String = _ "<?xml version=""1.0"" encoding=""UTF-8"" standalone=""yes""?>" & vbCrLf & _ "<assembly xmlns=""urn:schemas-microsoft-com:asm.v1"" " & _ "manifestVersion=""1.0"">" & vbCrLf & _ "<assemblyIdentity type=""win32"" processorArchitecture=""*"" " & _ "version=""6.0.0.0"" name=""Company"" />" & vbCrLf & _ "<dependency>" & vbCrLf & _ "<dependentAssembly>" & vbCrLf & _ "<assemblyIdentity type=""win32"" name=""Microsoft.Windows.Common-Controls"" " & _ "version=""6.0.0.0"" " & _ "language=""*"" processorArchitecture=""*"" publicKeyToken=""6595b64144ccf1df""/>" & vbCrLf & _ "</dependentAssembly>" & vbCrLf & _ "</dependency>" & vbCrLf & _ "</assembly>"
Private Function AddXPStyle(ByVal Filename As String) As Boolean Dim handle As Long handle = BeginUpdateResource(Filename, False) If handle = 0 Then Exit Function UpdateResource handle, 24&, 1&, 0&, ByVal manifest, Len(manifest) EndUpdateResource handle, False AddXPStyle = True End Function
Private Function DelXPStyle(ByVal Filename As String) As Boolean Dim handle As Long handle = BeginUpdateResource(Filename, False) If handle = 0 Then Exit Function UpdateResource handle, 24&, 1&, 0&, ByVal 0&, 0& EndUpdateResource handle, False DelXPStyle = True End Function
Um jetzt XP-Styles in einer EXE zu aktivieren, reicht lediglich der Aufruf:
AddXPStyle "X:\proramm.exe"
Sollen die Themes wieder deaktiviert werden muss folgende Zeile aufgerufen werden:
DelXPStyle "X:\programm.exe"
ACHTUNG! Bei VB-Anwendungen kann es vorkommen, dass die gepatchte Anwendung beim Start ihren Dienst mit der Fehlermeldung "Klasse ist nicht vorhanden" quittiert und sich beendet. In diesem Fall müssen die Controls in der betroffenen Anwendung vorher initiiert werden:
Private Declare Sub InitCommonControls Lib "comctl32.dll" () Private Sub Form_Initialize() Call InitCommonControls End Sub