-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathColorAndMono.cpp
More file actions
139 lines (112 loc) · 3.9 KB
/
ColorAndMono.cpp
File metadata and controls
139 lines (112 loc) · 3.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
//************************************************************************
// The Logitech LCD SDK, including all acompanying documentation,
// is protected by intellectual property laws. All use of the Logitech
// LCD SDK is subject to the License Agreement found in the
// "Logitech LCD SDK License Agreement" file and in the Reference Manual.
// All rights not expressly granted by Logitech are reserved.
//************************************************************************
// ColorAndMono.cpp : Defines the class behaviors for the application.
//
#include "stdafx.h"
#include "ColorAndMono.h"
#include "ColorAndMonoDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
#define LCDSAMPLE_MUTEXNAME _T("LCDSample_Mutex_1_0")
// CColorAndMonoApp
BEGIN_MESSAGE_MAP(CColorAndMonoApp, CWinApp)
ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
END_MESSAGE_MAP()
// CColorAndMonoApp construction
CColorAndMonoApp::CColorAndMonoApp()
{
// TODO: add construction code here,
// Place all significant initialization in InitInstance
m_hMutex = NULL;
m_gdiplusToken = NULL;
}
// The one and only CColorAndMonoApp object
CColorAndMonoApp theApp;
// CColorAndMonoApp initialization
BOOL CColorAndMonoApp::InitInstance()
{
// InitCommonControlsEx() is required on Windows XP if an application
// manifest specifies use of ComCtl32.dll version 6 or later to enable
// visual styles. Otherwise, any window creation will fail.
INITCOMMONCONTROLSEX InitCtrls;
InitCtrls.dwSize = sizeof(InitCtrls);
// Set this to include all the common control classes you want to use
// in your application.
InitCtrls.dwICC = ICC_WIN95_CLASSES;
InitCommonControlsEx(&InitCtrls);
// Initialize GDI+
Gdiplus::GdiplusStartupInput gdiplusStartupInput;
GdiplusStartup(&m_gdiplusToken, &gdiplusStartupInput, NULL);
CWinApp::InitInstance();
// 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
// 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
SetRegistryKey(_T("Local AppWizard-Generated Applications"));
m_hMutex = ClaimMutex(LCDSAMPLE_MUTEXNAME, NULL);
if(NULL == m_hMutex)
{
return FALSE;
}
CColorAndMonoDlg dlg;
m_pMainWnd = &dlg;
INT_PTR nResponse = dlg.DoModal();
if (nResponse == IDOK)
{
// TODO: Place code here to handle when the dialog is
// dismissed with OK
}
else if (nResponse == IDCANCEL)
{
// TODO: Place code here to handle when the dialog is
// dismissed with Cancel
}
// Since the dialog has been closed, return FALSE so that we exit the
// application, rather than start the application's message pump.
return FALSE;
}
INT CColorAndMonoApp::ExitInstance()
{
if(NULL != m_hMutex)
{
ReleaseMutex(m_hMutex);
CloseHandle(m_hMutex);
m_hMutex = NULL;
}
Gdiplus::GdiplusShutdown(m_gdiplusToken);
return CWinApp::ExitInstance();
}
HANDLE CColorAndMonoApp::ClaimMutex(LPCTSTR szMutex, LPCTSTR szWndClassName)
{
// attempt to claim the mutex
HANDLE hMutex = CreateMutex(NULL, TRUE, szMutex);
if (ERROR_ALREADY_EXISTS == GetLastError())
{
if (hMutex)
{
CloseHandle(hMutex);
hMutex = NULL;
}
// bring the existing wnd to the foreground
if (szWndClassName)
{
HWND hExistingWnd = FindWindow(szWndClassName, NULL);
if (hExistingWnd)
{
ShowWindow(hExistingWnd, SW_RESTORE);
SetForegroundWindow(hExistingWnd);
}
}
return NULL;
}
return hMutex;
}