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−이 창을 마우스 오른쪽 버튼으로 클릭합니다. 이제 마우스 오른쪽 버튼을 놓으면 다음과 같은 메시지가 나타납니다.