// CommandBarIcons.cpp // // (c)1998-2025 Codejock Software, All Rights Reserved. // // THIS SOURCE FILE IS THE PROPERTY OF CODEJOCK SOFTWARE AND IS NOT TO BE // RE-DISTRIBUTED BY ANY MEANS WHATSOEVER WITHOUT THE EXPRESSED WRITTEN // CONSENT OF CODEJOCK SOFTWARE. // // THIS SOURCE CODE CAN ONLY BE USED UNDER THE TERMS AND CONDITIONS OUTLINED // IN THE XTREME TOOLKIT PRO LICENSE AGREEMENT. CODEJOCK SOFTWARE GRANTS TO // YOU (ONE SOFTWARE DEVELOPER) THE LIMITED RIGHT TO USE THIS SOFTWARE ON A // SINGLE COMPUTER. // // CONTACT INFORMATION: // support@codejock.com // http://www.codejock.com // ///////////////////////////////////////////////////////////////////////////// #include "stdafx.h" #include "CommandBarIcons.h" #include "MainFrm.h" #include "CommandBarIconsDoc.h" #include "CommandBarIconsView.h" #include "AboutDlg.h" #include #pragma comment(lib, "Shlwapi") #ifdef _DEBUG # define new DEBUG_NEW # undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CCommandBarIconsApp BEGIN_MESSAGE_MAP(CCommandBarIconsApp, CWinApp) //{{AFX_MSG_MAP(CCommandBarIconsApp) ON_COMMAND(ID_APP_ABOUT, OnAppAbout) // NOTE - the ClassWizard will add and remove mapping macros here. // DO NOT EDIT what you see in these blocks of generated code! //}}AFX_MSG_MAP // Standard file based document commands ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew) ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen) // Standard print setup command ON_COMMAND(ID_FILE_PRINT_SETUP, CWinApp::OnFilePrintSetup) END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CCommandBarIconsApp construction CCommandBarIconsApp::CCommandBarIconsApp() { // TODO: add construction code here, // Place all significant initialization in InitInstance } ///////////////////////////////////////////////////////////////////////////// // The one and only CCommandBarIconsApp object CCommandBarIconsApp theApp; ///////////////////////////////////////////////////////////////////////////// // CCommandBarIconsApp initialization BOOL CCommandBarIconsApp::InitInstance() { AfxEnableControlContainer(); // Standard initialization // If you are not using these features and wish to reduce the size // of your final executable, you should remove from the following // the specific initialization routines you do not need. #if _MSC_VER <= 1200 // MFC 6.0 or earlier # ifdef _AFXDLL Enable3dControls(); // Call this when using MFC in a shared DLL # else Enable3dControlsStatic(); // Call this when linking to MFC statically # endif #endif // Change the registry key under which our settings are stored. // TODO: You should modify this string to be something appropriate // such as the name of your company or organization. CString ver; ver.Format(_T("Codejock %s v%d.%d.%d"), _XTP_PACKAGE_NAME, _XTPLIB_VERSION_MAJOR, _XTPLIB_VERSION_MINOR, _XTPLIB_VERSION_REVISION); SetRegistryKey(ver); LoadStdProfileSettings(); // Load standard INI file options (including MRU) InitVisualStyles(); // Register the application's document templates. Document templates // serve as the connection between documents, frame windows and views. CSingleDocTemplate* pDocTemplate; pDocTemplate = new CSingleDocTemplate(IDR_MAINFRAME, RUNTIME_CLASS(CCommandBarIconsDoc), RUNTIME_CLASS(CMainFrame), // main SDI frame window RUNTIME_CLASS(CCommandBarIconsView)); AddDocTemplate(pDocTemplate); // Parse command line for standard shell commands, DDE, file open CCommandLineInfo cmdInfo; ParseCommandLine(cmdInfo); // Dispatch commands specified on the command line if (!ProcessShellCommand(cmdInfo)) return FALSE; // The one and only window has been initialized, so show and update it. m_pMainWnd->ShowWindow(SW_SHOW); m_pMainWnd->UpdateWindow(); ((CMainFrame*)m_pMainWnd)->m_wndProperties.UpdateAll(); return TRUE; } // App command to run the dialog void CCommandBarIconsApp::OnAppAbout() { CAboutDlg aboutDlg; aboutDlg.SetAxialisCredits(); aboutDlg.DoModal(); } ///////////////////////////////////////////////////////////////////////////// // CCommandBarIconsApp message handlers XTPPaintTheme CCommandBarIconsApp::GetAppTheme(XTPPaintTheme nDefaultTheme /*= xtpThemeNone*/) const { UINT nTheme = const_cast(this)->GetProfileInt(_T(""), _T("Theme"), nDefaultTheme); return static_cast(nTheme); } CString CCommandBarIconsApp::GetAppThemeSettings(LPCTSTR lpDefaultSettings /*= NULL*/) { CString strThemeSettings = const_cast(this)->GetProfileString( _T(""), _T("ThemeSettings"), lpDefaultSettings); strThemeSettings.MakeUpper(); return strThemeSettings; } void CCommandBarIconsApp::SetAppTheme(XTPPaintTheme nTheme, LPCTSTR lpThemeSettings /*= NULL*/, BOOL bUpdateResources /*= TRUE*/) { UNREFERENCED_PARAMETER(bUpdateResources); if (NULL != lpThemeSettings) { XTPThemeDLL()->SetHandle(lpThemeSettings); } else { XTPThemeDLL()->Reset(); } XTPPaintManager()->SetTheme(nTheme); WriteProfileInt(_T(""), _T("Theme"), nTheme); CString strThemeSettings; if (NULL != lpThemeSettings) { strThemeSettings = lpThemeSettings; strThemeSettings.MakeUpper(); } WriteProfileString(_T(""), _T("ThemeSettings"), strThemeSettings); } void CCommandBarIconsApp::InitVisualStyles() { XTPPaintTheme nTheme = GetAppTheme(xtpThemeOffice2016); CString strThemeSettings = GetAppThemeSettings(xtpIniOffice2016AccessColorful); SetAppTheme(nTheme, strThemeSettings); } BOOL CCommandBarIconsApp::GetStylesPath(CString& strPath, LPCTSTR lpFileName /*= NULL*/) { TCHAR szPath[MAX_PATH + 1] = { _T('\0') }; if (0 == ::GetModuleFileName(AfxGetApp()->m_hInstance, szPath, MAX_PATH + 1)) { TRACE(_T("ERROR: Unable to obtain module file name.\n")); return FALSE; } ::PathRemoveFileSpec(szPath); SIZE_T cchAdditional = 1 + _tcslen(_T("Styles")) + (NULL != lpFileName ? 1 + _tcslen(lpFileName) : 0) + 1; if (_countof(szPath) < (_tcslen(szPath) + cchAdditional)) { TRACE(_T("ERROR: Style path is too long.\n")); return FALSE; } if (!::PathAppend(szPath, _T("Styles"))) { TRACE(_T("ERROR: Unable to append path.\n")); return FALSE; } if (NULL != lpFileName) { if (!::PathAppend(szPath, lpFileName)) { TRACE(_T("ERROR: Unable to append path.\n")); return FALSE; } } strPath = szPath; return TRUE; }