在項目開發過程中,需要對UI進行美化處理的,可以使用Xtreme ToolkitPro,我在網上找的Xtreme ToolkitPro13.4 VS2015版本。
第一步:新建MFC 對話框應用程序 TestXT
第二步:配置Xtreme ToolkitPro
工程屬性--》C/C++ --》常規 --》 附加包含目錄
鏈接庫--》常規--》附件庫目錄
第三步:在stdafx.h中包含頭文件和加載 lib庫
#include <XTToolKitPro.h>
#pragma comment(lib, "ToolkitPro1340vc140D.lib")
第四步:初始化Xtreme ToolkitPro
在 InitInstance() 函數裏面初始化
BOOL CTestXTApp::InitInstance() { // 如果一個運行在 Windows XP 上的應用程序清單指定要 // 使用 ComCtl32.dll 版本 6 或更高版本來啓用可視化方式, //則需要 InitCommonControlsEx()。 否則,將無法創建窗口。 INITCOMMONCONTROLSEX InitCtrls; InitCtrls.dwSize = sizeof(InitCtrls); // 將它設置爲包括所有要在應用程序中使用的 // 公共控件類。 InitCtrls.dwICC = ICC_WIN95_CLASSES; InitCommonControlsEx(&InitCtrls); CWinApp::InitInstance(); XTPOffice2007Images()->SetHandle("Office2007Black.dll"); //CXTPPaintManager::SetCustomTheme(new CCrytekTheme()); XTPSkinManager()->LoadSkin("CryDark.cjstyles"); // Apply skin, including metrics, coloring and frame XTPSkinManager()->SetApplyOptions(xtpSkinApplyMetrics | xtpSkinApplyColors | xtpSkinApplyMenus); // Apply skin to all new windows and threads XTPSkinManager()->SetAutoApplyNewWindows(TRUE); XTPSkinManager()->SetAutoApplyNewThreads(TRUE); // Apply skin to current thread and window XTPSkinManager()->EnableCurrentThread(); AfxEnableControlContainer(); // 創建 shell 管理器,以防對話框包含 // 任何 shell 樹視圖控件或 shell 列表視圖控件。 CShellManager *pShellManager = new CShellManager; // 激活“Windows Native”視覺管理器,以便在 MFC 控件中啓用主題 CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows)); // 標準初始化 // 如果未使用這些功能並希望減小 // 最終可執行文件的大小,則應移除下列 // 不需要的特定初始化例程 // 更改用於存儲設置的註冊表項 // TODO: 應適當修改該字符串, // 例如修改爲公司或組織名 SetRegistryKey(_T("應用程序嚮導生成的本地應用程序")); CTestXTDlg dlg; m_pMainWnd = &dlg; INT_PTR nResponse = dlg.DoModal(); if (nResponse == IDOK) { // TODO: 在此放置處理何時用 // “確定”來關閉對話框的代碼 } else if (nResponse == IDCANCEL) { // TODO: 在此放置處理何時用 // “取消”來關閉對話框的代碼 } else if (nResponse == -1) { TRACE(traceAppMsg, 0, "警告: 對話框創建失敗,應用程序將意外終止。\n"); TRACE(traceAppMsg, 0, "警告: 如果您在對話框上使用 MFC 控件,則無法 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS。\n"); } // 刪除上面創建的 shell 管理器。 if (pShellManager != NULL) { delete pShellManager; } // 由於對話框已關閉,所以將返回 FALSE 以便退出應用程序, // 而不是啓動應用程序的消息泵。 return FALSE; }
效果對比: