MFC-메시지 및 이벤트
응용 프로그램은 다양한 개체로 구성됩니다. 대부분의 경우 컴퓨터에서 둘 이상의 응용 프로그램이 실행되고 있으며 운영 체제는 몇 가지 할당을 수행하도록 지속적으로 요청합니다. 예측할 수없는 너무 많은 요청이 제시 될 수 있기 때문에 운영 체제는 원하는 항목, 원하는시기 및 예상되는 동작 또는 결과를 지정하기 위해 개체에 맡깁니다.
개요
Microsoft Windows 운영 체제는 한 개체가 처리해야하는 요청 유형과 다른 개체에 필요한 할당 유형을 예측할 수 없습니다.
이러한 모든 할당 및 요청을 관리하기 위해 개체는 메시지를 보냅니다.
각 개체는 보낼 메시지와시기를 결정할 책임이 있습니다.
메시지를 보내려면 컨트롤이 이벤트를 만들어야합니다.
둘을 구분하기 위해 메시지 이름은 일반적으로 Window Message를 나타내는 WM_로 시작합니다.
이벤트 이름은 일반적으로 작업을 나타내는 On으로 시작합니다.
이벤트는 메시지를 보내는 작업입니다.
메시지지도
Windows는 메시지 지향 운영 체제이므로 Windows 환경을위한 프로그래밍의 대부분은 메시지 처리와 관련됩니다. 키 입력 또는 마우스 클릭과 같은 이벤트가 발생할 때마다 메시지가 응용 프로그램에 전송되며 응용 프로그램은 이벤트를 처리해야합니다.
컴파일러가 메시지를 관리하려면 클래스 정의에 포함되어야합니다.
그만큼 DECLARE_MESSAGE_MAP 매크로는 다음 코드와 같이 클래스 정의 끝에 제공되어야합니다.
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
DECLARE_MESSAGE_MAP()
};
실제 메시지는 DECLARE_MESSAGE_MAP 줄 바로 위에 나열되어야합니다.
메시지를 구현하려면 프로그램에서 사용하는 메시지 테이블을 만들어야합니다.
이 테이블은 두 개의 구분 매크로를 사용합니다.
그것의 시작은 BEGIN_MESSAGE_MAP 그리고 END_MESSAGE_MAP 매크로.
BEGIN_MESSAGE_MAP 매크로는 다음 코드와 같이 클래스 이름과 클래스에서 파생 된 MFC 클래스의 두 인수를 사용합니다.
#include <afxwin.h>
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
DECLARE_MESSAGE_MAP()
};
CMainFrame::CMainFrame() {
// Create the window's frame
Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
CRect(120, 100, 700, 480), NULL);
}
class CMessagesApp : public CWinApp {
public:
BOOL InitInstance();
};
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
END_MESSAGE_MAP()
BOOL CMessagesApp::InitInstance(){
m_pMainWnd = new CMainFrame;
m_pMainWnd->ShowWindow(SW_SHOW);
m_pMainWnd->UpdateWindow();
return TRUE;
}
CMessagesApp theApp;
새 Win32 프로젝트를 생성하여 간단한 예를 살펴 보겠습니다.
Step 1 − MFC 프로젝트를 생성하려면 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 속성을 선택하십시오.
Step 2 − 왼쪽 섹션에서 구성 속성 → 일반을 클릭합니다.
Step 3 − 프로젝트 기본값 섹션에서 '공유 DLL에서 MFC 사용'옵션을 선택하고 확인을 클릭합니다.
Step 4 − 새 소스 파일을 추가해야합니다.
Step 5 − 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 추가 → 새 항목을 선택합니다.
Step 6 − 템플릿 섹션에서 C ++ 파일 (.cpp)을 클릭합니다.
Step 7 − 계속하려면 추가를 클릭합니다.
Step 8 − 이제 * .cpp 파일에 다음 코드를 추가합니다.
#include <afxwin.h>
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
DECLARE_MESSAGE_MAP()
};
CMainFrame::CMainFrame() {
// Create the window's frame
Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
CRect(120, 100, 700, 480), NULL);
}
class CMessagesApp : public CWinApp {
public:
BOOL InitInstance();
};
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
END_MESSAGE_MAP()
BOOL CMessagesApp::InitInstance() {
m_pMainWnd = new CMainFrame;
m_pMainWnd->ShowWindow(SW_SHOW);
m_pMainWnd->UpdateWindow();
return TRUE;
}
CMessagesApp theApp;
Windows 메시지
창 만들기, 창 표시 등과 같은 다양한 유형의 Windows 메시지가 있습니다. 다음은 일반적으로 사용되는 Windows 메시지 중 일부입니다.
메시지 | 지도 항목 | 기술 |
---|---|---|
WM_ACTIVATE | ON_WM_ACTIVATE () | 프레임 워크는 CWnd 개체가 활성화 또는 비활성화 될 때이 멤버 함수를 호출합니다. |
WM_ACTIVATEA PP | ON_WM_ACTIVATEAPP () | 프레임 워크는 활성화되는 작업의 모든 최상위 창과 비활성화되는 작업의 모든 최상위 창에 대해이 멤버 함수를 호출합니다. |
WM_APPCOMM 및 | ON_WM_APPCOMMAND () | 프레임 워크는 사용자가 애플리케이션 명령 이벤트를 생성 할 때이 멤버 함수를 호출합니다. |
WM_CANCELMODE | WM_CANCELMODE () | 프레임 워크는이 멤버 함수를 호출하여 CWnd에 내부 모드를 취소하도록 알립니다. |
WM_CHILDACTIVATE | ON_WM_CHILDACTIVATE () | CWnd 개체가 MDI (다중 문서 인터페이스) 자식 창인 경우 사용자가 창의 제목 표시 줄을 클릭하거나 창이 활성화, 이동 또는 크기 조정될 때 프레임 워크에서 OnChildActivate를 호출합니다. |
WM_CLIPBOAR DUPDATE | ON_WM_CLIPBOARDUPDATE () | 프레임 워크는 클립 보드의 내용이 변경되면이 멤버 함수를 호출합니다. |
WM_CLOSE | ON_WM_CLOSE () | 프레임 워크는이 멤버 함수를 CWnd 또는 응용 프로그램이 종료된다는 신호로 호출합니다. |
WM_CONTEXTMENU | ON_WM_CONTEXTMENU () | 사용자가 창에서 오른쪽 마우스 버튼 (오른쪽 클릭)을 클릭했을 때 프레임 워크에 의해 호출됩니다. |
WM_COPYDATA | ON_WM_COPYDATA () | 이 멤버 함수는 한 응용 프로그램에서 다른 응용 프로그램으로 데이터를 복사하기 위해 프레임 워크에서 호출됩니다. |
WM_CREATE | ON_WM_CREATE () | 프레임 워크는 응용 프로그램이 Create 또는 CreateEx 멤버 함수를 호출하여 Windows 창을 만들도록 요청할 때이 멤버 함수를 호출합니다. |
WM_CTLCOLOR | ON_WM_CTLCOLOR () | 프레임 워크는 자식 컨트롤이 그려지려고 할 때이 멤버 함수를 호출합니다. |
WM_DELETEITEM | ON_WM_DELETEITEM () | 프레임 워크는이 멤버 함수를 호출하여 소유자 그리기 목록 상자 또는 콤보 상자의 소유자에게 목록 상자 또는 콤보 상자가 파괴되었거나 항목이 제거되었음을 알립니다. |
WM_DESTROY | ON_WM_DESTROY () | 프레임 워크는이 멤버 함수를 호출하여 CWnd 개체에 소멸 중임을 알립니다. |
WM_DRAWITEM | ON_WM_DRAWITEM () | 프레임 워크는 컨트롤 또는 메뉴의 시각적 측면이 변경된 경우 소유자 그리기 단추 컨트롤, 콤보 상자 컨트롤, 목록 상자 컨트롤 또는 메뉴의 소유자에 대해이 멤버 함수를 호출합니다. |
WM_DROPFILES | ON_WM_DROPFILES () | 프레임 워크는 사용자가 드롭 된 파일의 수신자로 등록 된 창 위에 마우스 왼쪽 버튼을 놓을 때이 멤버 함수를 호출합니다. |
WM_ENABLE | ON_WM_ENABLE () | 프레임 워크는 응용 프로그램이 CWnd 개체의 사용 상태를 변경할 때이 멤버 함수를 호출합니다. 통사론. |
WM_HELPINFO | ON_WM_HELPINFO () | 응용 프로그램 내에서 F1 도움말을 처리합니다 (현재 컨텍스트 사용). |
WM_HOTKEY | ON_WM_HOTKEY () | 프레임 워크는 사용자가 시스템 전체 단축키를 누를 때이 멤버 함수를 호출합니다. |
WM_HSCROLL | ON_WM_HSCROLL () | 프레임 워크는 사용자가 창의 가로 스크롤 막대를 클릭 할 때이 멤버 함수를 호출합니다. |
WM_KEYDOWN | ON_WM_KEYDOWN () | 프레임 워크는 비 시스템 키를 누를 때이 멤버 함수를 호출합니다. |
WM_KEYUP | ON_WM_KEYUP () | 프레임 워크는 비 시스템 키가 해제 될 때이 멤버 함수를 호출합니다. |
WM_KILLFOCUS | ON_WM_KILLFOCUS () | 프레임 워크는 입력 포커스를 잃기 직전에이 멤버 함수를 호출합니다. |
WM_LBUTTONDBLCLK | ON_WM_LBUTTONDBLCLK () | 프레임 워크는 사용자가 마우스 왼쪽 버튼을 두 번 클릭 할 때이 멤버 함수를 호출합니다. |
WM_LBUTTONDOWN | ON_WM_LBUTTONDOWN () | 프레임 워크는 사용자가 마우스 왼쪽 버튼을 누를 때이 멤버 함수를 호출합니다. |
WM_LBUTTONUP | ON_WM_LBUTTONUP () | 프레임 워크는 사용자가 마우스 왼쪽 버튼을 놓을 때이 멤버 함수를 호출합니다. |
WM_MBUTTONDBLCLK | ON_WM_MBUTTONDBLCLK () | 프레임 워크는 사용자가 마우스 가운데 버튼을 두 번 클릭 할 때이 멤버 함수를 호출합니다. |
WM_MBUTTONDOWN | ON_WM_MBUTTONDOWN () | 프레임 워크는 사용자가 마우스 가운데 버튼을 누를 때이 멤버 함수를 호출합니다. |
WM_MBUTTONUP | ON_WM_MBUTTONUP () | 프레임 워크는 사용자가 마우스 가운데 버튼을 놓을 때이 멤버 함수를 호출합니다. |
WM_MENUSELECT | ON_WM_MENUSELECT () | CWnd 개체가 메뉴와 연결된 경우 사용자가 메뉴 항목을 선택할 때 프레임 워크에서 OnMenuSelect를 호출합니다. |
WM_MOUSEACTIVATE | ON_WM_MOUSEACTIVATE () | 프레임 워크는 커서가 비활성 창에 있고 사용자가 마우스 버튼을 누를 때이 멤버 함수를 호출합니다. |
WM_MOUSEHOVER | ON_WM_MOUSEHOVER () | 프레임 워크는 TrackMouseEvent에 대한 이전 호출에 지정된 기간 동안 커서가 창의 클라이언트 영역 위에있을 때이 멤버 함수를 호출합니다. |
WM_MOUSEHWHEEL | ON_WM_MOUSEHWHEEL () | 프레임 워크는 현재 창이 DWM (Desktop Window Manager)에 의해 구성되고 해당 창이 최대화 될 때이 멤버를 호출합니다. |
WM_MOUSELEAVE | ON_WM_MOUSELEAVE () | 프레임 워크는 커서가 TrackMouseEvent에 대한 이전 호출에서 지정된 창의 클라이언트 영역을 벗어날 때이 멤버 함수를 호출합니다. |
WM_MOUSEMOVE | ON_WM_MOUSEMOVE () | 프레임 워크는 마우스 커서가 움직일 때이 멤버 함수를 호출합니다. |
WM_MOVE | ON_WM_MOVE () | 프레임 워크는 CWnd 개체가 이동 된 후이 멤버 함수를 호출합니다. |
WM_PAINT | ON_WM_PAINT () | 프레임 워크는 Windows 또는 응용 프로그램이 응용 프로그램 창의 일부를 다시 그리도록 요청할 때이 멤버 함수를 호출합니다. |
WM_SETFOCUS () | ON_WM_SETFOCUS () | 프레임 워크는 입력 포커스를 얻은 후이 멤버 함수를 호출합니다. |
WM_SIZE () | ON_WM_SIZE () | 프레임 워크는 창의 크기가 변경된 후이 멤버 함수를 호출합니다. |
WM_TIMER | ON_WM_TIMER () | 프레임 워크는 타이머를 설치하는 데 사용되는 SetTimer 멤버 함수에 지정된 각 간격 후에이 멤버 함수를 호출합니다. |
WM_VSCROLL | ON_WM_VSCROLL () | 프레임 워크는 사용자가 창의 세로 스크롤 막대를 클릭 할 때이 멤버 함수를 호출합니다. |
WM_WINDOWPOSCHANGED | ON_WM_WINDOWPOSCHANGED () | 프레임 워크는 SetWindowPos 멤버 함수 또는 다른 창 관리 함수에 대한 호출의 결과로 크기, 위치 또는 Z 순서가 변경된 경우이 멤버 함수를 호출합니다. |
창 생성의 간단한 예를 살펴 보겠습니다.
WM_CREATE − 창이라고하는 객체가 생성되면 객체를 생성하는 프레임은 다음과 같은 메시지를 보냅니다. ON_WM_CREATE.
Step 1− ON_WM_CREATE를 생성하려면 afx_msg int OnCreate (LPCREATESTRUCT lpCreateStruct); 아래와 같이 DECLARE_MESSAGE_MAP () 앞에.
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
DECLARE_MESSAGE_MAP()
};
Step 2 − BEGIN_MESSAGE_MAP (CMainFrame, CFrameWnd) 뒤와 END_MESSAGE_MAP () 앞에 ON_WM_CREATE () 추가
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
ON_WM_CREATE()
END_MESSAGE_MAP()
Step 3 − 다음은 OnCreate () 구현입니다.
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {
// Call the base class to create the window
if (CFrameWnd::OnCreate(lpCreateStruct) == 0) {
// If the window was successfully created, let the user know
MessageBox(L"The window has been created!!!");
// Since the window was successfully created, return 0
return 0;
}
// Otherwise, return -1
return -1;
}
Step 4 − 이제 * .cpp 파일은 다음 코드와 같이 보일 것입니다.
#include <afxwin.h>
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
DECLARE_MESSAGE_MAP()
};
CMainFrame::CMainFrame() {
// Create the window's frame
Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
CRect(120, 100, 700, 480), NULL);
}
class CMessagesApp : public CWinApp {
public:
BOOL InitInstance();
};
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
ON_WM_CREATE()
END_MESSAGE_MAP()
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {
// Call the base class to create the window
if (CFrameWnd::OnCreate(lpCreateStruct) == 0) {
// If the window was successfully created, let the user know
MessageBox(L"The window has been created!!!");
// Since the window was successfully created, return 0
return 0;
}
// Otherwise, return -1
return -1;
}
BOOL CMessagesApp::InitInstance() {
m_pMainWnd = new CMainFrame;
m_pMainWnd -> ShowWindow(SW_SHOW);
m_pMainWnd -> UpdateWindow();
return TRUE;
}
CMessagesApp theApp;
Step 5 − 위 코드를 컴파일하고 실행하면 다음과 같은 출력이 나옵니다.
Step 6 − 확인을 클릭하면 메인 창이 나타납니다.
명령 메시지
그래픽 응용 프로그램의 주요 기능 중 하나는 사용자가 컴퓨터와 상호 작용할 수 있도록하는 Windows 컨트롤 및 리소스를 제공하는 것입니다. 우리가 배울 컨트롤의 예는 버튼, 목록 상자, 콤보 상자 등입니다.
이전 강의에서 소개 한 리소스 유형 중 하나는 메뉴입니다. 이러한 컨트롤 및 리소스는 사용자가 클릭 할 때 자체 메시지를 시작할 수 있습니다. Windows 컨트롤 또는 리소스에서 발생하는 메시지를 명령 메시지라고합니다.
명령 메시지의 간단한 예를 살펴 보겠습니다.
응용 프로그램에 새 문서를 만드는 기능을 제공하기 위해 CWinApp 클래스는 OnFileNew () 메서드를 제공합니다.
afx_msg void OnFileNew();
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
ON_COMMAND(ID_FILE_NEW, CMainFrame::OnFileNew)
END_MESSAGE_MAP()
다음은 메서드 정의입니다.
void CMainFrame::OnFileNew() {
// Create New file
}
키보드 메시지
ㅏ keyboard컴퓨터에 연결된 하드웨어 개체입니다. 기본적으로 컨트롤에 인식 가능한 기호, 문자 및 기타 문자를 입력하는 데 사용됩니다. 키보드의 각 키는 기호, 문자 또는 이들의 조합을 표시하여 키의 용도를 나타냅니다. 사용자는 일반적으로 프로그램에 신호를 보내는 키를 누릅니다.
각 키에는 운영 체제가 인식 할 수있는 코드가 있습니다. 이 코드는virtual key code.
Sr. 아니. | 상수 / 값 및 설명 |
---|---|
1 | VK_LBUTTON 왼쪽 마우스 버튼 |
2 | VK_RBUTTON 마우스 오른쪽 버튼 |
삼 | VK_CANCEL 제어 중단 처리 |
4 | VK_MBUTTON 마우스 가운데 버튼 (3 버튼 마우스) |
5 | VK_BACK 백 스페이스 키 |
6 | VK_RETURN ENTER 키 |
7 | VK_TAB TAB 키 |
8 | VK_CLEAR CLEAR 키 |
9 | VK_SHIFT Shift 키 |
10 | VK_CONTROL CTRL 키 |
11 | VK_MENU Alt 키 |
12 | VK_PAUSE PAUSE 키 |
13 | VK_CAPITAL Caps Lock 키 |
14 | VK_ESCAPE ESC 키 |
15 | VK_SPACE 스페이스 바 |
16 | VK_PRIOR PAGE UP 키 |
17 | VK_NEXT Page Down 키 |
18 | VK_END END 키 |
19 | VK_HOME 홈 키 |
20 | VK_LEFT 왼쪽 화살표 키 |
21 | VK_UP 위쪽 화살표 키 |
22 | VK_RIGHT 오른쪽 화살표 키 |
23 | VK_DOWN 아래쪽 화살표 키 |
24 | VK_SELECT SELECT 키 |
25 | VK_PRINT PRINT 키 |
26 | VK_EXECUTE EXECUTE 키 |
27 | VK_SNAPSHOT PRINT SCREEN 키 |
28 | VK_INSERT INS 키 |
29 | VK_DELETE DEL 키 |
30 | VK_NUMPAD0 숫자 키패드 0 키 |
31 | VK_NUMPAD1 숫자 키패드 1 키 |
32 | VK_NUMPAD2 숫자 키패드 2 키 |
33 | VK_NUMPAD3 숫자 키패드 3 키 |
34 | VK_NUMPAD4 숫자 키패드 4 키 |
35 | VK_NUMPAD5 숫자 키패드 5 키 |
36 | VK_NUMPAD6 숫자 키패드 6 키 |
37 | VK_NUMPAD7 숫자 키패드 7 키 |
38 | VK_NUMPAD8 숫자 키패드 8 키 |
39 | VK_NUMPAD9 숫자 키패드 9 키 |
40 | VK_MULTIPLY 곱하기 키 |
41 | VK_ADD 키 추가 |
42 | VK_SEPARATOR 구분자 키 |
43 | VK_SUBTRACT 빼기 키 |
44 | VK_DECIMAL 소수점 키 |
45 | VK_DIVIDE 키 나누기 |
46 | VK_F1 F1 키 |
47 | VK_F2 F2 키 |
48 | VK_F3 F3 키 |
49 | VK_F4 F4 키 |
50 | VK_F5 F5 키 |
52 | VK_F6 F6 키 |
53 | VK_F7 F7 키 |
54 | VK_F8 F8 키 |
55 | VK_F9 F9 키 |
56 | VK_F10 F10 키 |
57 | VK_F11 F11 키 |
58 | VK_F12 F12 키 |
59 | VK_NUMLOCK Num Lock 키 |
60 | VK_SCROLL SCROLL LOCK 키 |
61 | VK_LSHIFT 왼쪽 Shift 키 |
62 | VK_RSHIFT 오른쪽 Shift 키 |
63 | VK_LCONTROL 왼쪽 CONTROL 키 |
64 | VK_RCONTROL 오른쪽 CONTROL 키 |
키를 누르면 WM_KEYDOWN 또는 WM_SYSKEYDOWN 메시지가 스레드 메시지에 배치됩니다. 이것은 다음과 같이 정의 할 수 있습니다-
afx_msg void OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);
간단한 예를 살펴 보겠습니다.
Step 1 − 여기에 메시지가 있습니다.
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
ON_WM_CREATE()
ON_WM_KEYDOWN()
END_MESSAGE_MAP()
Step 2 − 다음은 OnKeyDown ()의 구현입니다.
void CMainFrame::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags) {
switch (nChar) {
case VK_RETURN:
MessageBox(L"You pressed Enter");
break;
case VK_F1:
MessageBox(L"Help is not available at the moment");
break;
case VK_DELETE:
MessageBox(L"Can't Delete This");
break;
default:
MessageBox(L"Whatever");
}
}
Step 3 − 위 코드를 컴파일하고 실행하면 다음과 같은 출력이 나옵니다.
Step 4 − Enter를 누르면 다음과 같은 메시지가 나타납니다.
마우스 메시지
마우스는 사용자가 컴퓨터와 상호 작용할 수 있도록 컴퓨터에 연결된 또 다른 개체입니다.
마우스 왼쪽 버튼을 누르면 ON_WM_LBUTTONDOWN 메시지가 전송됩니다. 이 메시지의 구문은 다음과 같습니다.
afx_msg void OnLButtonDown (UINT nFlags, CPoint 포인트)
마우스 오른쪽 버튼을 누르면 ON_WM_RBUTTONDOWN 메시지가 전송됩니다. 구문은-
afx_msg void OnRButtonDown (UINT nFlags, CPoint 포인트)
마찬가지로 왼쪽 마우스를 놓으면 ON_WM_LBUTTONUP 메시지가 전송됩니다. 구문은-
afx_msg void OnLButtonUp (UINT nFlags, CPoint 포인트)
오른쪽 마우스를 놓으면 ON_WM_TBUTTONUP 메시지가 전송됩니다. 구문은-
afx_msg void OnRButtonUp (UINT nFlags, CPoint 포인트)
간단한 예를 살펴 보겠습니다.
Step 1 − 다음 코드와 같이 CMainFrame 클래스 정의에 다음 두 함수를 추가합니다.
class CMainFrame : public CFrameWnd {
public:
CMainFrame();
protected:
afx_msg void OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);
afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
afx_msg void OnRButtonUp(UINT nFlags, CPoint point);
DECLARE_MESSAGE_MAP()
};
Step 2 − 다음 두 개의 메시지 맵을 추가합니다.
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
ON_WM_KEYDOWN()
ON_WM_LBUTTONDOWN()
ON_WM_RBUTTONUP()
END_MESSAGE_MAP()
Step 3 − 다음은 함수 정의입니다.
void CMainFrame::OnLButtonDown(UINT nFlags, CPoint point) {
CString MsgCoord;
MsgCoord.Format(L"Left Button at P(%d, %d)", point.x, point.y);
MessageBox(MsgCoord);
}
void CMainFrame::OnRButtonUp(UINT nFlags, CPoint point) {
MessageBox(L"Right Mouse Button Up");
}
Step 4 −이 응용 프로그램을 실행하면 다음과 같은 출력이 표시됩니다.
Step 5 − 확인을 클릭하면 다음과 같은 메시지가 나타납니다.
Step 6−이 창을 마우스 오른쪽 버튼으로 클릭합니다. 이제 마우스 오른쪽 버튼을 놓으면 다음과 같은 메시지가 나타납니다.