MFC-管理を制御します

MFCアプリケーションでは、アプリケーションにコントロールを視覚的に追加した後、コードでそのコントロールを参照する場合は、そのコントロールに基づいて、またはそのコントロールに関連付けられた変数を宣言できます。MFCライブラリを使用すると、アプリケーションで使用される一部のコントロールの2種類の変数を値または制御変数として宣言できます。

  • 1つの変数は、コントロールに格納されている情報に使用されます。これは、 Control Variable/Instance

  • 他の変数はとして知られています Control Value Variable。ユーザーは、この変数を使用して、そのコントロールに対してある種のアクションを実行できます。

制御変数/インスタンス

制御変数は、制御を管理するクラスに基づく変数です。たとえば、ボタンコントロールはCButtonクラスに基づいています。

これらの概念を実際のプログラミングで確認するために、MFCダイアログベースのプロジェクトMFCControlManagementを作成しましょう。

プロジェクトが作成されると、デザイナウィンドウに次のダイアログボックスが表示されます。

Step 1−次のスナップショットに示すように、TODO行を削除し、1つのチェックボックスと1つの編集コントロールをドラッグします。チェックボックスのキャプションを[コントロールを有効にする]に変更します。

Step 2 −チェックボックスを右クリックします。

Step 3 − [変数の追加]を選択します。

Step 4 −これで、メンバー変数の追加ウィザードが表示されます。

このダイアログボックスでさまざまなオプションを選択できます。チェックボックスの場合、変数タイプはCButtonです。このダイアログボックスでは、デフォルトで選択されています。

同様に、コントロールIDもデフォルトで選択されているため、[カテゴリ]コンボボックスで[コントロール]を選択し、[変数名]編集ボックスにm_enableDisableCheckと入力して、[完了]をクリックする必要があります。

Step 5 −同様に、次のスナップショットに示す設定で編集コントロールの制御変数を追加します。

ダイアログクラスのヘッダーファイルを確認します。新しい変数が追加されたことがわかります。

CButton m_enableDisableCheck;
CEdit m_myEditControl;

制御値変数

コントロールに対して宣言できる別のタイプの変数は、値変数です。すべてのコントロールが値変数を提供するわけではありません。

  • 値変数は、参照する予定のコントロールに格納されている値のタイプを処理できる必要があります。

  • たとえば、テキストベースのコントロールはテキストの処理に使用されるため、テキストベースのデータ型を宣言できます。これは通常、CString変数になります。

チェックボックスと編集コントロールのこのタイプの変数を調べてみましょう。

Step 1 −チェックボックスを右クリックして、「変数の追加」を選択します。

Step 2−変数タイプはBOOLです。[カテゴリ]ドロップダウンリストから[値]を選択します。

Step 3 − [完了]をクリックして続行します。

Step 4 −同様に、次のスナップショットに示す設定を使用して、編集コントロールの値変数を追加します。

Step 5 −変数タイプにCStringを入力し、変数名フィールドにm_editControlValを入力します。

Step 6 −これらの変数がヘッダーファイルに追加されているのを確認できます。

bool m_enableDisableVal;
CString m_editControlVal;

イベントハンドラーを制御します

コントロールをアプリケーションに追加した後、視覚的に追加したか動的に作成したかにかかわらず、ユーザーがコントロールに対して実行できる可能なアクションを処理する方法も決定します。

  • すでにクラスに関連付けられているプロジェクトダイアログボックスの場合、イベントハンドラーを作成するときにいくつかのショートカットを利用できます。

  • デフォルトの制御通知イベントまたは該当するWindowsメッセージのいずれかのハンドラーをすばやく作成できます。

チェックボックスのイベントハンドラーを追加した同じ例を見てみましょう。

Step 1 −通知イベントを処理するコントロールを右クリックします。

Step 2 −ショートカットメニューで、[イベントハンドラーの追加]をクリックして、イベントハンドラーウィザードを表示します。

Step 3 − [メッセージタイプ]ボックスでイベントを選択して、[クラス]リストボックスで選択したクラスに追加します。

Step 4 − [関数ハンドラー名]ボックスでデフォルト名を受け入れるか、選択した名前を入力します。

Step 5 − [追加と編集]をクリックして、イベントハンドラーを追加します。

Step 6 −CMFCControlManagementDlg.cppファイルの最後に追加された次のイベントを確認できます。

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
}

管理を制御します

これまで、アプリケーションにコントロールを追加する方法を見てきました。次に、ユーザーの要件に従ってこれらのコントロールを管理する方法を説明します。特定のイベントハンドラーで制御変数/インスタンスを使用できます。

Step 1−次の例を見てみましょう。ここでは、チェックボックスがオン/オフのときに編集コントロールを有効/無効にします。

Step 2−チェックボックスクリックイベントハンドラーを追加しました。これが実装です-

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
}

Step 3−ダイアログが作成されたら、CMFCControlManagementDlg :: OnInitDialog()に次のコードを追加する必要があります。これにより、これらのコントロールが管理されます。

UpdateData(TRUE);
if (m_enableDisableVal)
   m_myEditControl.EnableWindow(TRUE);
else
   m_myEditControl.EnableWindow(FALSE);

Step 4 −これがCMFCControlManagementDlg.cppファイルの完全な実装です。

// MFCControlManagementDlg.cpp : implementation file
//

#include "stdafx.h"
#include "MFCControlManagement.h"
#include "MFCControlManagementDlg.h"
#include "afxdialogex.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CAboutDlg dialog used for App About

class CAboutDlg : public CDialogEx {
   public:
      CAboutDlg();
	
   // Dialog Data
   #ifdef AFX_DESIGN_TIME
      enum { IDD = IDD_ABOUTBOX };
   #endif

   protected:
      virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
      
   // Implementation
   protected:
      DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX) {

}
void CAboutDlg::DoDataExchange(CDataExchange* pDX) {
   CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()

// CMFCControlManagementDlg dialog


CMFCControlManagementDlg::CMFCControlManagementDlg(CWnd* pParent /* = NULL*/)
   :CDialogEx(IDD_MFCCONTROLMANAGEMENT_DIALOG, pParent) , 
   m_enableDisableVal(FALSE) , m_editControlVal(_T("")) {
   m_hIcon = AfxGetApp()&rarr LoadIcon(IDR_MAINFRAME);
}

void CMFCControlManagementDlg::DoDataExchange(CDataExchange* pDX) {
   CDialogEx::DoDataExchange(pDX);
   DDX_Control(pDX, IDC_CHECK1, m_enableDisableCheck);
   DDX_Control(pDX, IDC_EDIT1, m_myEditControl);
   DDX_Check(pDX, IDC_CHECK1, m_enableDisableVal);
   DDX_Text(pDX, IDC_EDIT1, m_editControlVal);
}
BEGIN_MESSAGE_MAP(CMFCControlManagementDlg, CDialogEx)
   ON_WM_SYSCOMMAND()
   ON_WM_PAINT()
   ON_WM_QUERYDRAGICON()
   ON_BN_CLICKED(IDC_CHECK1, &CMFCControlManagementDlg::OnBnClickedCheck1)
END_MESSAGE_MAP()

// CMFCControlManagementDlg message handlers

BOOL CMFCControlManagementDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
      
   // Add "About..." menu item to system menu.
   // IDM_ABOUTBOX must be in the system command range.
   ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
   ASSERT(IDM_ABOUTBOX < 0xF000);
      
   CMenu* pSysMenu = GetSystemMenu(FALSE);
   if (pSysMenu != NULL) {
      BOOL bNameValid;
      CString strAboutMenu;
      bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
      ASSERT(bNameValid);
      if (!strAboutMenu.IsEmpty()) {
         pSysMenu → AppendMenu(MF_SEPARATOR);
         pSysMenu → AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
      }
   }
	
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);        // Set big icon
   SetIcon(m_hIcon, FALSE);       // Set small icon

   // TODO: Add extra initialization here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}
void CMFCControlManagementDlg::OnSysCommand(UINT nID, LPARAM lParam) {
   if ((nID & 0xFFF0) == IDM_ABOUTBOX) {
      CAboutDlg dlgAbout;
      dlgAbout.DoModal();
   }else {
      CDialogEx::OnSysCommand(nID, lParam);
   }
}

// If you add a minimize button to your dialog, you will need the code below
// to draw the icon. For MFC applications using the document/view model,
// this is automatically done for you by the framework.

void CMFCControlManagementDlg::OnPaint() {
   if (IsIconic()) {
      CPaintDC dc(this); // device context for painting
      
      SendMessage(WM_ICONERASEBKGND,
         reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
			
      // Center icon in client rectangle
      int cxIcon = GetSystemMetrics(SM_CXICON);
      int cyIcon = GetSystemMetrics(SM_CYICON);
      CRect rect;
      GetClientRect(&rect);
      int x = (rect.Width() - cxIcon + 1) / 2;
      int y = (rect.Height() - cyIcon + 1) / 2;
		
      // Draw the icon
      dc.DrawIcon(x, y, m_hIcon);
   }else {
      CDialogEx::OnPaint();
   }
}

// The system calls this function to obtain the cursor to display while the user drags
// the minimized window.
HCURSOR CMFCControlManagementDlg::OnQueryDragIcon() {
   return static_cast<HCURSOR>(m_hIcon);
}

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
}

Step 5−上記のコードをコンパイルして実行すると、次の出力が表示されます。チェックボックスはデフォルトでオフになっています。これにより、編集コントロールも無効になります。

Step 6− [制御を有効にする]チェックボックスをオンにします。これにより、編集コントロールが自動的に有効になります。