MFC-속성 시트

property sheet탭 대화 상자라고도하는은 속성 페이지가 포함 된 대화 상자입니다. 각 속성 페이지는 대화 상자 템플릿 리소스를 기반으로하며 컨트롤을 포함합니다. 상단에 탭이있는 페이지에 포함되어 있습니다. 탭은 페이지의 이름과 용도를 나타냅니다. 사용자는 속성 시트에서 탭을 클릭하여 컨트롤 집합을 선택합니다.

속성 페이지를 만들기 위해 대화 기반 MFC 프로젝트를 만들어 간단한 예제를 살펴 보겠습니다.

프로젝트가 생성되면 몇 가지 속성 페이지를 추가해야합니다.

Visual Studio를 사용하면 리소스 추가 대화 상자를 표시하고 대화 노드를 확장하고 IDD_PROPPAGE_X 항목 중 하나를 선택하여 속성 페이지에 대한 리소스를 쉽게 만들 수 있습니다.

Step 1 − 솔루션 탐색기에서 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 추가 → 리소스를 선택합니다.

Step 2 − IDD_PROPPAGE_LARGE를 선택하고 NEW를 클릭합니다.

Step 3 −이 속성 페이지의 ID와 캡션을 다음과 같이 변경하겠습니다. IDD_PROPPAGE_1Property Page 1 위와 같이 각각.

Step 4 − 디자이너 창에서 속성 페이지를 마우스 오른쪽 버튼으로 클릭합니다.

Step 5 − 클래스 추가 옵션을 선택합니다.

Step 6 − 클래스 이름을 입력하고 기본 클래스 드롭 다운 목록에서 CPropertyPage를 선택합니다.

Step 7 − 계속하려면 마침을 클릭하십시오.

Step 8 − 위에서 언급 한 단계에 따라 IDD_PROPPAGE_2 및 캡션 속성 페이지 2가있는 속성 페이지를 하나 더 추가합니다.

Step 9− 이제 생성 된 두 개의 속성 페이지를 볼 수 있습니다. 기능을 구현하려면 속성 시트가 ​​필요합니다.

속성 시트는 속성 페이지를 함께 그룹화하고 엔티티로 유지합니다.

속성 시트를 생성하려면 아래 단계를 따르십시오.

Step 1 − 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 추가> 클래스 메뉴 옵션을 선택합니다.

Step 2 − 왼쪽 창에서 Visual C ++ → MFC를 선택하고 템플릿 창에서 MFC Class를 선택하고 추가를 클릭합니다.

Step 3 − 클래스 이름을 입력하고 기본 클래스 드롭 다운 목록에서 CPropertySheet를 선택합니다.

Step 4 − 계속하려면 마침을 클릭하십시오.

Step 5 −이 속성 시트를 시작하려면 메인 프로젝트 클래스에서 다음과 같은 변경이 필요합니다.

Step 6 − CMFCPropSheetDemo.cpp 파일에 다음 참조를 추가합니다.

#include "MySheet.h"
#include "PropPage1.h"
#include "PropPage2.h"

Step 7 − 다음 코드와 같이 CMFCPropSheetDemoApp :: InitInstance () 메서드를 수정합니다.

CMySheet mySheet(L"Property Sheet Demo");
CPropPage1 page1;
CPropPage2 page2;

mySheet.AddPage(&page1);
mySheet.AddPage(&page2);

m_pMainWnd = &mySheet;
INT_PTR nResponse = mySheet.DoModal();

Step 8 − 다음은 CMFCPropSheetDemo.cpp 파일의 전체 구현입니다.

// MFCPropSheetDemo.cpp : Defines the class behaviors for the application.
//
#include "stdafx.h"
#include "MFCPropSheetDemo.h"
#include "MFCPropSheetDemoDlg.h"
#include "MySheet.h"
#include "PropPage1.h"
#include "PropPage2.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CMFCPropSheetDemoApp
BEGIN_MESSAGE_MAP(CMFCPropSheetDemoApp, CWinApp)
   ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
END_MESSAGE_MAP()


// CMFCPropSheetDemoApp construction

CMFCPropSheetDemoApp::CMFCPropSheetDemoApp() {

   // support Restart Manager
   m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART;
   // TODO: add construction code here,
   // Place all significant initialization in InitInstance
}


// The one and only CMFCPropSheetDemoApp object

CMFCPropSheetDemoApp theApp;


// CMFCPropSheetDemoApp initialization

BOOL CMFCPropSheetDemoApp::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);
   
   CWinApp::InitInstance();
   
   
   AfxEnableControlContainer();
   
   // Create the shell manager, in case the dialog contains
   // any shell tree view or shell list view controls.
   CShellManager *pShellManager = new CShellManager;

   // Activate "Windows Native" visual manager for enabling themes in MFC controls
   CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows));
   // 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"));
   
   CMySheet mySheet(L"Property Sheet Demo");
   CPropPage1 page1;
   CPropPage2 page2;
   
   mySheet.AddPage(&page1);
   mySheet.AddPage(&page2);
   
   m_pMainWnd = &mySheet;
   INT_PTR nResponse = mySheet.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
   }else if (nResponse == -1) {    
      TRACE(traceAppMsg, 0, "Warning: dialog creation failed, 
        so application is terminating unexpectedly.\n");
      TRACE(traceAppMsg, 0, "Warning: if you are using MFC controls on the dialog, 
        you cannot #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS.\n");
   }

   // Delete the shell manager created above.
   if (pShellManager != NULL) {
      delete pShellManager;
   }

   // Since the dialog has been closed, return FALSE so that we exit the
   // application, rather than start the application's message pump.
   return FALSE;
}

Step 9− 위 코드를 컴파일하여 실행하면 다음과 같은 대화 상자가 나타납니다. 이 대화 상자에는 두 개의 속성 페이지가 있습니다.