728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - MFC - 배경지식

 

1. MFC란?

Microsoft Foundation Class의 약자이다.

해석하면, 마이크로소프트에서 만든 클래스라고 할 수 있음.

 


2. 왜 MFC를 만들었을까?

윈도우 API를 공부해본 사람이면 알겠지만, 윈도우 운영체제는 수천 가지나 되는 다양한 기능의 API함수들을 제공한다.

개발자가 너무나 많은 함수를 모두 다 기억하기엔 정말 힘들고 어려운 일이다.

일일이 모든 기능을 처음부터 끝까지 학습하는 것 또한 굉장히 고난스러운 일이기 때문에, Microsoft에서는 API함수를 각 기능별로 클래스화한 형태로 만든 것이 MFC라고 할 수 있다.

 


3. MFC의 유래

MFC의 시초는 AFX(Application Framework)에서 유래되었다고 할 수 있다.

AFX는 1990년 마이크로소프트가 윈도우 API 함수를 캡슐화하여 만든 라이브러리라고 할 수 있다.

앞서 윈도우 API함수를 캡슐화하여 만든 것이 MFC라고 하였는데, AFX는 MFC의 전 단계로 수정을 거쳐 지금의 MFC가 완성되었다고 보면 이해가 될 것이다. 1993년 이후부터 MFC 라이브러리는 Visual C++에 포함되어 제공되고 있다.

 

 


4. Visual C++, MFC, Windows의 발전사?

 

 연도

Visual C++ 

 MFC 

 Windows 버전 

 주요 특징

 비고

 1993

 MS-C 7.0

 1.0 (AFX라고 봐야함)

 3.1

 Win16 API 캡슐화

 당시에는
 MFC(Microsoft Foundation Classes)라는
 거창한 이름이 없어서 AFX(Application Framework)
 라고 부름.

 1993

 Visual C++ 1.0 /
 Quick-C 2.5

 2.0

 3.1

 Document/View 구조 정립
 DDX/DDV 매카니즘 지원
 응용 프로그램 프레임워크 구조 도입

 

 1993

 Visual C++ 1.5

 2.5

 3.1

 ODBC 관련 클래스 및 OLE 2.01을 지원

 

 1995

 Visual C++ 2.0

 3.0

 NT 3.51

 Win16에서 Win32로 전환
 Winsock API와 MAPI 클래스 추가

 멀티스레드 관련 클래스 추가

 템플릿과 예외 처리 기능 강화 

 템플릿 기능이 없었던
 시절에서 당시에는 혁명임.?

 1996

 Visual C++ 4.0

 4.0

 95

 DAO 클래스 지원

 ODBC 2.5 지원

 윈도우95 공통 컨트롤 지원

 멀티스레드 동기화를 위한 클래스 지원

 Active X 문서 서버 클래스 지원

 1. 이 때 MFC의 윤곽을

 사실상 잡았다고 봐야함.
 2. MFC42.DLL 파일을 
    보신 분은 이 때
    윤곽잡힌 파일을
    만들었다고 보면 됨.

 1997

 Visual C++ 5.0

 4.21

 95 / WinCE 2.0

 인터넷 프로그래밍 지원
 ATL 포함
 온라인 도움말 제공

 

 1998 

 Visual C++ 6.0

 6.0

 98

 데이터베이스 기능 강화
 향상된 디버깅 환경 제공
 공통 컨트롤 추가

 윈도우98이 출시된 시기.

 Visual C++ 6.0이 한창
 불티나게 팔림.

 2002~

 2005

 Visual C++.NET
 7.0 ~ 8.0

 (2002~2005)

 7.0 ~ 8.0

 XP, 
 서버 2003

 MFC와 ATL 라이브러리 일부 통합

 닷넷 프레임워크 라이브러리 추가

 비주얼 스튜디오 내 각 개발 언어간의
 개발환경통합

 2002년 초기 당시 .NET Framework가 안된다는 말과 Visual Studio 6.0으로도 충분하지 않냐의 갈림길 그리고 이전에 코드는 어떻게 하냐를 두고 갈등이 많았음.

 시간이 지난 후 이러한 갈등은 해결되었음.
(쓰레기 운영체제 윈도우 비스타와 윈도우 7 덕분에)

 

 2013

 Visual C++.NET
 12

 12

 윈도우8.1,

 윈도우 서버 2012

 이 버전부터 다국어 UI를 지원.
 윈도 8, 윈도 RT 전용 소프트웨어인 윈도 스토어 지원 앱을 만들 수 있다.
 ARM 아키텍처에서 구동할 수 있는 윈도 스토어 전용 앱을 만들 수 있다.
 출시 초기에는 윈도 7 이상에서만

구동할 수 있는 실행 파일만 만들 수

있었지만, 업데이트 1 이상으로 갱신하면 윈도 XP에서도 구동할 수 있는 실행 파일을 만들 수 있음.
 테스트 프로페셔녈 버전에는 컴파일러가 포함되어 있지 않음.
 HLSL 컴파일 기능과 DirectX 그래픽 디버거를 포함한다. (XP 지원 모드 제외)

 컴파일 속도가 개선.
 표준 C++11을 도입.

 

 

 


5. MFC 계층도

 

다음 그림은 CObject로부터 파생된 MFC 클래스들을 나타냅니다. 

 

 

다음 그림은 CWnd 및 CCmdTarget로부터 파생된 MFC 클래스들을 나타냅니다.

 

 

다음 그림은 CObject로부터 파생되지 않은 MFC 클래스들을 나타낸다.

 

 

 


6. MFC 계층 구조

 

 

MFC는 크게 CObject로부터 파생되는 클래스CObject로부터 파생되지 않은 클래스 두 가지로 요약할 수 있음.

자세한 사항은 MFC 계층도를 살펴보고 이해하면 됨.

 

 

6-1) CObject 클래스

MFC의 최상위 클래스인 CObject 클래스는 다음과 같이 구성됨.

 

 

 

6-2) 응용 프로그램 아키텍처 클래스(Application Architecture Classes)

 

 

윈도우 응용 프로그램의 가장 기본적인 구조를 제공하는 클래스.

 

MFC는 기본적으로 전체 프레임 구성을 위한 근간을 이루는 클래스가 제공되고, CCmdTarget으로부터 파생된 CWinApp 클래스가 그 기능을 수행.

메시지루프를 돌면서 윈도우 프로시저는 원하는 메시지만을 선별하고, 나머지 메시지는 기본 처리 함수에게 역할을 맡기게 됨.

 


6-3) 윈도우 클래스

CObject 클래스로부터 파생된 클래스인 윈도우 클래스의 구성은 다음과 같음.

 

 

 

사용자 인터페이스를 제공하는 모든 윈도우 관련 클래스의 최상위에 CWnd 클래스가 있다.

CWnd 클래스에서 파생된 클래스로서 응용 프로그램의 주 골격을 만들어주는 CFrameWnd 클래스, 대화 상자인 CDialog 클래스, 사용자 영역을 담당하는 CView 클래스 그리고 윈도우가 제공하는 각종 컨트롤 등이 있음.

 

6-3-1) 일반 클래스(General Class)

 

 

 

응용 프로그램 아키텍처와 윈도우 관련 클래스를 제외한 나머지 클래스를 말한다.

즉, 기본적인 윈도우 골격에 영향을 미치지 않는 클래스를 말함.

 

예) 소켓과 같은 윈속 클래스나 데이터베이스 관련 클래스는 윈도우 골격에 영향을 미치지 않음.

 

6-3-2) CObject 클래스로부터 파생되지 않은 클래스

 

 

반응형
728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - Win32 프로그램 올려보기

 

2, http://yyman.tistory.com/485 / [MFC] 윈도우 프로그래밍 기초 - 윈도우 프로그램의 구조

3, http://yyman.tistory.com/486 / [MFC] 윈도우 프로그래밍 기초 - 윈도우 클래스 만들기

4, http://yyman.tistory.com/487 / [MFC] 윈도우 프로그래밍 기초 - 윈도우 객체 생성, 화면 띄우기

5, http://yyman.tistory.com/488 / [MFC] 윈도우 프로그래밍 기초 - 메시지 루프, 처리하기.

 

2~5번 글까지 잘 읽었다면, 이번에는 프로그램 전체 소스로 만들어 보겠습니다.

 


1. 새 프로젝트 만들기 

 

그림 1-1) 새 프로젝트 만들기, Visual Studio 2013

 

 

그림 1-2) 프로젝트 마법사, Visual Studio 2013

 

 

그림 1-3) 프로젝트 마법사, Visual Studio 2013

 

 

그림 1-4) 솔루션 탐색기, Visual Studio 2013

 

그림 1-5) 소스코드 파일 만들기

 

 


2. 구현(Implements)

 

<Basic.cpp>

#include <Windows.h>
#include <tchar.h>

 

LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);

LPTSTR lpszClass = _T("BasicApi");


int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpszCmdParam, int nCmdShow)
{
       HWND hWnd;
       MSG Message;
       WNDCLASS WndClass;


       WndClass.cbClsExtra = 0;
       WndClass.cbWndExtra = 0;
       WndClass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
       WndClass.hCursor = LoadCursor(NULL, IDC_ARROW);
       WndClass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
       WndClass.hInstance = hInstance;
       WndClass.lpfnWndProc = (WNDPROC)WndProc;
       WndClass.lpszClassName = lpszClass;
       WndClass.lpszMenuName = NULL;
       WndClass.style = CS_HREDRAW | CS_VREDRAW;

 

       RegisterClass(&WndClass);

 

       hWnd = CreateWindow(lpszClass, LPTSTR(_T("제목")), WS_OVERLAPPEDWINDOW,
         CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, (HMENU)NULL, hInstance, NULL);

     

       ShowWindow(hWnd, nCmdShow);

      

       while (GetMessage(&Message, 0, 0, 0) )
       {
              TranslateMessage(&Message);
              DispatchMessage(&Message);
       }

 

       return Message.wParam;

}

 

 

LRESULT CALLBACK WndProc(HWND hWnd, UINT iMessage, WPARAM wParam, LPARAM lParam)
{
      HDC hdc;
      PAINTSTRUCT ps;
 
      switch (iMessage)
     {
           case WM_CREATE:
                return 0;

           case WM_PAINT:
               hdc = BeginPaint(hWnd, &ps);
               EndPaint(hWnd, &ps);
               return 0;

           case WM_DESTROY:
               PostQuitMessage(0);
               return 0;

     }

 

     return (DefWindowProc(hWnd, iMessage, wParam, lParam));

 

 

 

 

 

그림 2-1) 윈도우 화면 출력하기

 


3. 응용 예제) WndProc에 윈도우 창 종료시 알림 메시지 처리

 

 

LRESULT CALLBACK WndProc(HWND hWnd, UINT iMessage, WPARAM wParam, LPARAM lParam)
{
      HDC hdc;
      PAINTSTRUCT ps;

      int nReturn;
 
      switch (iMessage)
     {
           case WM_CREATE:
                return 0;

 

           case WM_PAINT:
               hdc = BeginPaint(hWnd, &ps);
               EndPaint(hWnd, &ps);
               return 0;

 

          case WM_CLOSE:

               nReturn = MessageBox(hWnd, _T("정말 종료하시겠습니까?"), _T("확인"), MB_YESNO);

 

               if(nReturn == IDYES)

                     DestroyWindow(hWnd);

 

               return 0;

 

 

           case WM_DESTROY:
               PostQuitMessage(0);
               return 0;

     }

 

     return (DefWindowProc(hWnd, iMessage, wParam, lParam));

 

 

 


4. 마치면서

이 코드는 잊어버려도 되지만, 윈도우 프로그램의 기본 구조는 반드시 알고 있어야 한다.

 

1. 윈도우 프로그램의 전체 구조

 

int WINAPI WinMain( .... ) // 프로그램의 시작점

{
      // 기본적인 윈도우의 형태를 생성

      // 메시지 루프를 돌린다.

}

 

LRESULT CALLBACK WndProc(......) // 메시지를 처리하는 프로시저

{

       // 윈도우 메시지를 처리한다.

}

 

2. 윈도우 프로그램의 구성 요소

    -> 1. 클래스 만들기(윈도우)

    -> 2. 객체 생성(윈도우)

    -> 3. 객체 화면 띄우기(윈도우)

    -> 4. 메시지 루프 돌리기

    -> 5. 메시지 처리하기

 


5. 참고자료(Reference)

반응형
728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - 메시지 루프, 처리하기.

 

앞서 두개의 글에서는

http://yyman.tistory.com/487 - [MFC] 윈도우 프로그래밍 기초 - 윈도우 객체 생성, 화면 띄우기

http://yyman.tistory.com/486 - [MFC] 윈도우 프로그래밍 기초 - 윈도우 클래스 만들기

 

윈도우의 객체를 만드는 기본 요소를 구현해보았다.

윈도우의 껍데기를 만드는 방법을 지금까지 수행하였는데, 이번에는 사용자로부터 명령을 받을 수 있는 기반을 만들어보고자 한다.

 


1. 원리

윈도우는 항상 루프(무한 반복)를 돌며 사용자의 메시지를 기다리고 있다가 메시지가 들어오면 받아서 처리한다.

 

1-1) 이벤트 처리 방식

-> 임의의 이벤트 (마우스 입력, 키보드 입력 등)가 발생할 때 처리하는 방식

 

 

음악을 재생하려면 플레이 버튼을 누른다. 버튼을 클릭하는 행위라고 볼 수 있지만, 근본적으로 이벤트 행위라고 볼 수 있다.

 


2. 메시지 루프

 

편집기(Editor) 프로그램의 경우, 키보드로부터 입력받은 문자를 화면에 출력하는 기능을 처리해야 한다.

이 때, IO Device(키보드, 마우스 등)으로부터 발생한 이벤트를 메시지 루프에서 감지하고 그 메시지를 윈도우 프로시져(Procedure) 함수로 보내주면, 화면에 해당하는 문자를 출력해준다.

 

즉, 윈도우 프로시져 함수로 메시지를 보내는 역할을 하는 것이 바로 메시지 루프의 역할이라고 할 수 있겠다.

 

 

 

 

이전 코드에 이어서

 

while ( GetMessage(&Message, 0, 0, 0) )

{

          TranslateMessage(&Message);   // 문자 입력을 처리하는 함수

          DispatchMessage(&Message);    // GetMessage() 함수로부터 전달된 메시지를 윈도우 프로시저로 보내는 역할 수행.

}

 

* 용어 정리

 

  용어 

 설명 

 시스템 큐

 시스템 큐는 운영체제가 가지고 있는 메시지 저장소로서 저장된 이벤트 메시지를 애플리케이션 큐로 넘겨준다.

 애플리케이션 큐

 애플리케이션 큐는 실행 중인 응용 프로그램마다 하나씩 가지고 있는 메시지 저장소이다.

 

while( ) 문으로 이루어진 메시지 루프는 GetMessage( ) 함수의 반환이 거짓이 될 때까지 계속 반복해서 돈다.

 


3. 애플리케이션에 대한 소개(읽어보기)

애플리케이션 큐는 응용프로그램이 소유한 메모리 버퍼라고 생각하면 된다.

우리가 직접 때때로 개발을 하다 보면, 애플리케이션 큐에 직접 메시지를 보내야 하는 경우가 있다.

 

-> 메시지 전달 함수 API에는 SendMessage()와 PostMessage() 함수가 있음.

 

* SendMessage() 함수

모든 메시지는 시스템 큐에서 애플리케이션 큐를 거쳐 윈도우 프로시져 함수로 전달된다고 알고 있으나, 이러한 과정을 모두 무시하고 윈도우 프로시저 함수로 바로 전달되는 메시지가 있다(). SendMessage()가 이러한 역할을 수행해준다.

이 함수는 메시지가 완전히 처리되기 전까진 반환되지 않는다. 메시지 처리 후 반드시 처리 확인이 필요한 경우에 이 함수를 사용하도록 한다.

 

* PostMessage() 함수

PostMessage() 함수를 이용하면 메시지는 시스템 큐를 거치지 않고, 직접 애플리케이션 큐에 보내진다. 이 함수로 메시지를 보내면 곧바로 반환되므로, 해당 메시지를 바로 처리하지 않고도 해당 메시지를 붙인 스레드는 다른 작업을 할 수 있다 즉, 메시지가 비동기적으로 처리 되어도 상관없는 경우에 이 함수를 사용한다.

 

쉽게 이해하려면, 저 함수의 Send, Post라는 단어로 유추해서 생각해보면 쉬울 것 같다.

마치 우편 수화물하고 같은 원리라고 보면 이해하기 쉬울 것 같다. (이메일의 경우, 보낸 후 수신확인을 통해 상대방이 확인했는지 확인하는 과정과 매우 흡사하다.

 


4. 메시지 처리하기

메시지 루프를 통해서 윈도우 프로시저로 전달된 메시지는 윈도우 프로시저가 구분하여 작업을 처리하게 된다.

따라서, 실질적인 코딩은 여기서 이뤄진다고 볼 수 있다.

 

WndProc()의 코드

 

LRESULT CALLBACK WndPrco(HWND hWnd, UINT iMessage, WPARAM wParam, LPARAM lParam)

}

 

       HDC hdc;

       PAINTSTRUCT ps;

      

       switch(iMessage){

             case WM_CREATE:

                    return 0;

             case WM_PAINT:

                    hdc = BeginPaint(hWnd, &ps);

                    EndPaint(hWnd, &ps);

                    return 0;

             case WM_DESTROY:

                    PostQuitMessage(0);

                    return 0;

       }

 

       return(DefWindowProc(hWnd, iMessage, wParam, lParam) );

 

}

 

코드 해설

 

1. WndProc( )의 인수 구성요소

 

 

 인수 

  설명

 hWnd

 메시지를 받을 윈도우 핸들이다.

 iMessage

 전달된 메시지 값이다. 어떤 종류의 메시지인지, 즉 어떤 변화가 발생했는지에 대한 정보를 가지고 있다.

 wParam

 iMessage에 따른 부가 정보를 갖는다.

 예를 들어서 마우스 왼쪽 버튼이 눌렸을 때, 즉, WM_LBUTTONDOWN 메시지가 발생했을 때, 화면 어디쯤 위치에

 마우스 버튼이 눌러졌는지, 조합된 키가 눌러졌는지(Ctrl, Alt, Shift, 등....) 등의 정보가 필요하다.

 이러한 정보들이 wParam과 lParam에 각각 전달되며, 실제로 wParam과 lParam에 저장되어 있는 정보는 다르다.

 lParam

 

 

 

2. 메시지 구분

윈도우 프로시저의 4개의 인수 중에 iMessage에는 전달된 메시지 값이 담겨 있다.

바로 이 값으로 어떤 메시지가 들어왔는지 구분한다.

이 때 switch 문이 쓰인다.

switch 문의 괄호에 iMessage에 값에 따라 case 문으로 분기처리 된다.

 

case WM_LBUTTONDOWN:

return 0;작업처리

       return 0;

 

case 문에서 처리되지 않는 메시지는 DefWindowProc() 함수로 넘긴다.

 

3. DefWindowProc() 함수

이 함수는 WndProc에서 case문으로 처리하지 못한 메시지를 처리해준다.

 

LRESULT CALLBACK DefWindowProc(HWND hWnd, UINT iMessage, WPARAM wParam, LPARAM lParam)

{

 

      

 

}

 

 


5. 참고자료

반응형
728x90
300x250
[MFC] 윈도우 프로그래밍 기초 - 윈도우 객체 생성, 화면 띄우기

 

이번에는 윈도우 객체 생성 및 화면을 띄우는 방법에 대해서 소개하고자 합니다.

 


1. 윈도우 객체 생성

CreateWindow()의 원형 소개

 

 HWND CreateWindow(

       LPCTSTR lpClassName,

       LPCTSTR lpWindowName,

       DWORD dwStyle,

       int x, int y,

       int nWidth, int nHeight,

       HWND hWndParent,

       HMENU hMenu,

       HANDLE hInstance,

       PVOID lpParam);

 

 - lpClassName : 윈도우의 클래스를 지정하는 문자열이다.

 - lpWindowName : 윈도우의 제목 표시줄에 보여줄 문자열이다.

 - dwStyle : 윈도우의 스타일을 지정한다.

 - x, y : 윈도우의 좌표를 지정한다.

 - nWidth, nHeight : 윈도우의 폭과 높이를 장치 단위(픽셀)로 지정한다.

 - hWndParent : 부모 윈도우 또는 소유주 윈도우의 핸들을 지정한다.

 - hMenu : 겹쳐진(Overlapped) 윈도우나 팝업 윈도우의 경우 메뉴의 핸들을 지정한다.

 - hInstance : 윈도우를 생성하는 인스턴스 핸들을 지정한다.

 - lpParam : WM_CREATE 메시지의 인수 IParam으로 전달될 CREATESTRUCT 구조체의 포인터이다.

 

실제 코드 적용 )

 

 

 "이전 글 - http://yyman.tistory.com/entry/MFC-윈도우-프로그래밍-기초-윈도우-클래스-만들기"

  

 (중략)

 

 hWnd = CreateWindow(lpszClass, LPTSTR(_T("태스트")), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT,
  CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, (HMENU)NULL, hInstance, NULL); 

 


2. 윈도우 객체 화면 띄우기

 

ShowWindow() 원형

 

 BOOL ShowWindow(HWND hWnd, int nCmdShow); 

 

 <nCmdShow 설정 값>

 

 설정 값

설명 

SW_FORCEMINIMIZE 

윈도우 2000 이후에만 쓸 수 있는 Flag.

-> 윈도우를 소유한 스레드(Thread)가 차단(Block)된 상태에서도 윈도우를 최소화시킨다. 

SW_HIDE 

윈도우를 숨긴다. 

SW_MAXIMIZE 

윈도우를 최대화 시킨다. 

 SW_MINIMIZE

윈도우를 최소화 시킨다. 

SW_RESTORE 

최대화나 최소화된 윈도우를 이전 상태로 복구한다. 

SW_SHOW 

윈도우를 활성화시켜서 화면에 띄운다. 

SW_SHOWDEFAULT 

STARTUPINFO 구조체가 지정하는 보기 상태로 만든다. 

SW_SHOWMAXIMIZED 

윈도우를 최대화된 상태로 활성화한다. 

SW_SHOWMINIMIZED 

윈도우를 최소화한 상태로 활성화한다. 

SW_SHOWMININOACTIVE 

윈도우를 최소화 상태로 화면에 띄우며 활성화 상태 그대로 변경되지 않는다.

SW_SHOWNA  

윈도우를 현재 상태로 화면에 띄우며 활성화 상태 그대로 변경되지 않는다.

 SW_SHOWNOACTIVATE

최근 크기와 위치에 윈도우를 띄우며 활성화 상태 그대로 변경되지 않는다. 

SW_SHOWNORMAL 

윈도우를 화면에 띄우며 활성화한다.

만약(If), 윈도우가 최소화되어 있거나 최대화 되어 있다면 윈도우를 원래 크기로 복구한다. 

 

 

 

 

 이전 코드 참고 - http://yyman.tistory.com/entry/MFC-윈도우-프로그래밍-기초-윈도우-클래스-만들기

 

 (중략)

 

 hWnd = CreateWindow(lpszClass, LPTSTR(_T("태스트")), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT,
  CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, (HMENU)NULL, hInstance, NULL); 

 

 ShowWindow(hWnd, nCmdShow);

 

 

반응형
728x90
300x250
[MFC] 윈도우 프로그래밍 기초 - 윈도우 클래스 만들기

 

WinMain 함수에서 첫 번째 단계가 윈도우 클래스를 만드는 과정입니다.

~RegisterClass( & ...... ) 까지 만드는 과정을 윈도우 클래스를 구현한다고 보시면 됩니다.

 

Winuser.h 파일에 윈도우 클래스 생성을 위한 구조체 구조를 소개하겠습니다.

 


1. WNDCLASS 구조체

 

typedef struct tag WNDCLASS{
     UINT style;

     WNDPROC lpfnWndProc;

     int cbClsExtra;

     int cbWndExtra;

     HINSTANCE hInstance;

     HICON hIcon;

     HCURSOR hCursor;

     HBRUSH hbrBackground;

     LPCSTR lpszMenuName;

     LPCSTR lpszClassName;

 winuser.h의 구조체

 

* 클래스를 생성하는 원리만 이해하면 되므로, 현재의 코드는 암기하시거나 할 필요는 없습니다.

 


2. 구현(Implements)

 

 

 #include <Windows.h>
 #include <tchar.h>

 

 LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
 

 LPTSTR lpszClass = _T("TestApp");

 int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpszCmdParameter, int nCmdShow){

 

      HWND hWnd;
      MSG Message;

      WNDCLASS WndClass;

      WndClass.cbClsExtra = 0;
      WndClass.cbWndExtra = 0;
      WndClass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
      WndClass.hCursor = LoadCursor(NULL, IDC_ARROW);
      WndClass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
      WndClass.hInstance = hInstance;
      WndClass.lpfnWndProc = (WNDPROC)WndProc;
      WndClass.lpszClassName = lpszClass;
      WndClass.lpszMenuName = NULL;
      WndClass.style = CS_HREDRAW | CS_VREDRAW;

      RegisterClass(&WndClass);

}


LRESULT CALLBACK WndProc(HWND hWnd, UINT iMessage, WPARAM wParam, LPARAM lParam){

 

       // 이 영역은 다음에 언급하겠습니다.

 

}

 

 

반응형
728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - API와 Hello World.

 

 

1. 용어 학습

* API(Application Programming Interface)란 영어 해석 그래도 응용 프로그램을 만드는 데 필요한 함수들의 집합.

 

* SDK(Software Development Kit)라는 말로도 사용

-> Microsoft에서 SDK 파일 설치를 종종 볼 수 있는 데, 이게 응용 프로그램을 만드는 데 필요한 함수들의 집합을 미리 설치한다는 의미로 
해석해볼 수 있음.

 

MFC(Microsoft Foundation Class)라는 것의 근간은 API에서 되었다고 볼 수 있음.

 

2. 용어 학습

 

C언어나 C++에서 한번이라도 해봤던 Hello World 프로그램을 윈도우 프로그래밍을 통해서 실습.

 

main()
{
       printf("Hello World!");
}

 

// C언어 기준

 

 

실습 프로그램 : Visual Studio 2013

 

1. 먼저, 당연히 Visual Studio 2013을 실행시켜야합니다. 

 

 

파일에서 새로 만들기(N) -> 프로젝트(P)를 클릭합니다.

 

Win32프로젝트 클릭합니다.

이번 실습에선 그냥 Win32Project1으로 이름 지정하겠습니다.

확인을 누릅니다.

 

 

다음을 클릭합니다.

 

 

빈 프로젝트에 체크를 한 후 마침을 클릭합니다.

 

 

 

솔루션 탐색기를 선택하고, 그림과 같이 컨텍스트 메뉴를 통해(오른쪽 버튼을 클릭하여) cpp파일을 생성합니다.

 

추가를 클릭합니다.

 

3. 코드 작성하기

 

#include <Windows.h>

#include <tchar.h>

 

int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpcmdline, int nCmdShow){

 

MessageBox(NULL, _T("Hello World"), _T("메시지"), MB_OK);

return 0;

 

}

 

 

 

반응형
728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - 타입 재정의

 

 

 자료형 

 의미 

 BYTE 

 unsigned char형 

 WORD 

 unsigned short형 

 DWORD 

 unsigned long형 

 LONG 

 long형과 같음 

 LPSTR 

 char*형과 같음 

 BOOL 

 정수형이며, TRUE 혹은 FALSE을 갖는다. 

 

기타)

HINSTANCE의 경우, 정수형이지만 핸들의 의미를 가짐.

 

실행의 다양한 예)

#include <tchar.h>

int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, char* lpcmdLine, int nCmdshow)
{

 

}

 

#include <tchar.h>

int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpcmdLine, int nCmdshow)
{

 

}

 

#include <Windows.h>
#include <tchar.h>

int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpcmdLine, int nCmdshow)
{

 

 


저 부분은 저런 구조로 사용할 수 있구나 이정도만 봐두시면 됩니다.

이전 글에서 WinMain()의 타입 재정의의 형태를 표현해놓은 겁니다.

앞 전의 글과 http://yyman.tistory.com/481, ([MFC] 윈도우 프로그래밍 기초 - WinMain() 함수)랑 같이 이어서 진행되는 부분입니다.

반응형
728x90
300x250

[MFC] 윈도우 프로그래밍 기초 - 강좌 소개

 

이 강의는 아마도 제 생각엔 지금 2015년 기준에서 최신의 Visual Studio 2013 기반 C++ MFC 글이 될 수 있을 거 같습니다.

 


1. 제작 배경

 

주인장이 참으로 친절하게 일일이 Visual Studio 2008 책부터 구글링까지 다 동원해가면서 제작하고 있습니다.

나름대로 생각해보고 또 생각해서 다양한 정보들을 여러 참조해서 지구상에서 제일 쉬운 MFC 글을 만들어 보고 싶어서 기획했습니다. 

 


2. 흐름은

 

1. Win32 프로그래밍의 이해 (원리만)

-> 우리는 직접 노가다 하면서 Win32 프로그래밍은 하지 않습니다.

     MFC라는 게 Win32 프로그래밍을 기반으로 하고 있기에 잠시 체험(Experience)용으로? 만들었다고 생각하시면 됩니다.

2. MFC 개념 이해

    -> MFC 계층도 소개

    -> 몇개 이론 및 실습

3. 메시지 출력

4. 기본 컨트롤 익숙해지기

5. 필수 대화상자 몇개 다뤄보기.

6. 공통 컨트롤

7. 그리기 도구(GDI)

8. 라이브러리 작성법

-> 동적(Dynamic), 정적(Static) 둘 다 실습

9. 멀티스레드

10. 프로세스 통신(IPC)

 

이 정도까지 강좌를 만들어볼 계획입니다.

 

그러나 시간적인 한계도 있을 수 있기에 몇 가지는 생략될 수도 있습니다.

 


3. 실습 환경은?


Visual Studio 2013 Update 4 기준으로 작성했습니다.

 


4. MFC와 Windows API의 차이

 

번호

항목명

설명(Description)

1

MFC

 

MFC(Microsoft Foundation Class)는 Win32를 통해 C++ 개체 지향 래퍼를 제공하여 네이티브 데스크톱 응용 프로그램을 신속하게 개발할 수 있습니다. ATL(액티브 템플릿 라이브러리)은 COM 개발을 간단하게 하는 래퍼 라이브러리이며 ActiveX 컨트롤을 만드는 데 광범위하게 사용됩니다.

Visual Studio Community Edition 이상을 사용하여 MFC 또는 ATL 프로그램을 만들 수 있습니다.

Express 버전은 MFC 또는 ATL을 지원하지 않습니다.

Visual Studio 2015에서 Visual C++는 선택적 구성 요소이며 MFC와 ATL 구성 요소는 Visual C++ 아래의 선택적 하위 구성 요소입니다.

Visual Studio를 처음 설치할 때 이러한 구성 요소를 선택하지 않으면 처음으로 MFC 또는 ATL 프로젝트를 만들거나 열려고 할 때 설치하라는 메시지가 표시됩니다. 

Windows API


비공식 WinAPI 인 Windows API는 Microsoft Windows 운영 체제에서 사용할 수있는 Microsoft의 핵심 API (Application Programming Interface) 집합입니다.

이름 Windows API는 일반적으로 자체 이름(예: Win32 API)으로 참조되는 여러 가지 다른 플랫폼 구현을 집합 적으로 나타냅니다. 버전 섹션을 참조하십시오.

거의 모든 Windows 프로그램은 Windows API와 상호 작용합니다.
Windows NT 계열의 운영 체제에서는 Windows 시작 프로세스 초기에 시작된 프로그램과 같이 작은 숫자가
기본 API를 사용합니다.

개발자 지원은 소프트웨어 개발 키트 인 Microsoft Windows SDK의 형태로 제공되며 Windows API 및 관련 Windows 인터페이스를 기반으로 소프트웨어를 작성하는 데 필요한 설명서와 도구를 제공합니다.

Windows API (Win32)는 주로 프로그래밍 언어 C에 초점을두고 있습니다.
C#의 노출 된 함수와 데이터 구조는 최신 버전의 문서에서 해당 언어로 기술되어 있습니다.

그러나 API는 호출 및 콜백에 대한 규정 된 호출 규칙과 함께 (잘 정의 된) 저수준 데이터 구조를
처리 할 수있는 모든 프로그래밍 언어 컴파일러 또는 어셈블러에서 사용할 수 있습니다.
마찬가지로, API 함수의 내부 구현은 역사적으로 여러 언어로 개발되었습니다.

C는 객체 지향 프로그래밍 언어가 아니지만 Windows API와 Windows는 역사적으로 객체 지향으로

설명되었습니다.

 

MFC (Microsoft Foundation Class Library), VCL (Visual Component Library), GDI + 등이 객체지향 구조를
보다 명확하게 만드는 객체 지향 언어에 대한 많은 래퍼 클래스 및 확장 (Microsoft 및 기타)
.
예를 들어 Windows 8은 Windows API와 WinRT API를 제공합니다.이 API는 C++로 구현되며 디자인에 의해

객체지향적입니다

 

가장 정확한 정보는 아래의 링크에 접속하면 API 기능에 대해서 자세히 찾아볼 수 있습니다.

1. https://docs.microsoft.com/ko-kr/windows/desktop/apiindex/windows-api-list

 

MFC에 대한 정보입니다. 아래의 링크에 접속하면 자세히 찾아볼 수 있습니다.

https://msdn.microsoft.com/ko-kr/library/65dtx4a4.aspx

 


6. 참고자료(Reference)

 

1. MFC 개념, 마이크로소프트, https://msdn.microsoft.com/ko-kr/library/kkcb3t0w.aspx

2. Windows API Index, , 마이크로소프트, https://docs.microsoft.com/ko-kr/windows/desktop/apiindex/windows-api-list

3. Windows API Index, , 마이크로소프트, https://msdn.microsoft.com/ko-kr/library/65dtx4a4.aspx

4. MFC 데스크톱 응용 프로그램, 마이크로소프트, https://msdn.microsoft.com/ko-kr/library/d06h2x6e.aspx

반응형

+ Recent posts