当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 关于如何换肤、子类化的解决方案
| 关于如何换肤、子类化的解决方案 对于应用程序的换肤及子类化。下面是我尝试过一些方法,以在CAboutDlg中子类化其中的Button为例: DDX_Control(pDX, IDB_BUTTON1, m_edit); 或者在 InitDialog() 中加上 m_btn.SubclassDlgItem(IDB_BUTTON1, this); 这两种效果差不多的。 g_hWndProcHook = ::SetWindowsHookEx(WH_CALLWNDPROC,WndProcHook,NULL,::GetCurrentThreadId()); 3、在 WndProcHook 中处理窗口创建和销毁的消息: LRESULT CALLBACK WndProcHook(int code, WPARAM wParam, LPARAM lParam){ if (code == HC_ACTION) { switch (((CWPSTRUCT*) lParam)->message) { case WM_CREATE: BeginSubclassing(((CWPSTRUCT*) lParam)->hwnd); break; case WM_NCDESTROY: // TODO: clear subclass info. EndSubclassing(((CWPSTRUCT*) lParam)->hwnd); break; default: break; } } return CallNextHookEx(g_hWndProcHook, code, wParam, lParam);} 4、在 BeginSubclassing 中用 GetClassName 得到类名,例如 "Button",然后用 CButtonXP 类进行子类化。CButtonXP pButton = new CButtonXP;VERIFY(pButton ->SubclassWindow(hWnd)); 第三种 在Hook中使用窗口过程 WNDPROC oldProc;LRESULT CALLBACK ProcButton(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam){ ASSERT(oldProc != 0); if (oldProc == 0) return TRUE; switch (uMsg) { case WM_ERASEBKGND: break; //...... default: break; } return CallWindowProc(oldProc, hWnd, uMsg, wParam, lParam);} 2、同第二种3、同第二种 4、在 BeginSubclassing 中得到类名后,用 SetWindowLong 的方式子类化: oldProc = (WNDPROC) GetWindowLong(hWnd, GWL_WNDPROC);SetWindowLong(hWnd, GWL_WNDPROC, (LONG) ProcButton);第四种:不用 Hook 在一个对话框的 OnInitDialog 中枚举它的所有子窗体,例如用下面两句来实现: hWnd=GetWindow(hDlg,GW_CHILD); hWnd=GetWindow(hWnd,GW_HWNDNEXT); 对每个子窗体进行子类化处理,处理过程同第二种与第三种。 第五种:如果是在XP下运行,可以使用manifest,也就是如下的一个XML文件<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0"> <assemblyIdentity name="Microsoft.Windows.XXXX" processorArchitecture="x86" version="5.1.0.0" type="win32"/> <description>Windows Shell</description> <dependency> <dependentAssembly> <assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0" processorArchitecture="x86" publicKeyToken="6595b64144ccf1df" language="*"/> </dependentAssembly> </dependency> </assembly>把它存为应用程序名 .manifest,放到和应用程序对应的目录下,或者把它作为资源类型为24的资源编译进应用程序中。这样程序在XP下就自动拥有了XP的风格。 第六种:使用第三方的库Skin++(www.uipower.com)实现换肤 第七种:用第三方应用程序给整个windows换肤(windowblinds) 以上七种方式各有优缺点。我在使用过程中也遇到不少问题,现在一一道来,希望和大家共同解决问题。先排除几种不准备深入探讨的方式: |