1. 程式人生 > >關於子對話方塊的建立與銷燬

關於子對話方塊的建立與銷燬

1.顯示對話方塊

1.1顯示模式對話方塊:

CDialogDemo dlg;
dlg.DoModal();

1.2 顯示非模式對話方塊:

CDialogDemo *dlg=new CDialogDemo(this); 
dlg->Create(IDD_GENERAL_CONTROL); 
dlg->ShowWindow(SW_SHOW);

2.銷燬對話方塊

1.CDialog::OnOK();   //確定按鈕按下         CDialog::OnCancel(); //取消按鈕被按下 2.CDialog::DestoryWindow();  3.CDialog::EndDialog( IDD );  

3.在模態對話方塊類中關閉自身對話方塊

可以在模態對話方塊類中通過PostMessage(WM_CLOSE)來關閉自身對話方塊。關閉MessageBox對話方塊後模態對話方塊隨之關閉。

參考程式碼如下:

BOOL CImportDataPromptDialog::OnInitDialog()
{
     CDialog::OnInitDialog();
 
    // TODO:  Add extra initialization here
     HANDLE hThread = StartImportDataThread();
     if (!hThread)
     {
         LOG("啟動匯入資料執行緒失敗")
     }
 
     return TRUE;  // return TRUE unless you set the focus to a control
     // EXCEPTION: OCX Property Pages should return FALSE
}
 
DWORD WINAPI CImportDataPromptDialog::ImportDataThread(LPVOID Param)
 {
    CImportDataPromptDialog* importDlg = (CImportDataPromptDialog*)Param;
 
    if (CImportLog::ExtractionXMLData(importDlg->m_sXmlFilePath, importDlg->m_sDBPath))
     {
        importDlg->MessageBox("匯入資料成功","平臺", MB_ICONINFORMATION);
         importDlg->PostMessage(WM_CLOSE);
     }
    else
     {
         importDlg->MessageBox("匯入資料失敗","平臺", MB_ICONEXCLAMATION);
         importDlg->PostMessage(WM_CLOSE);
     }
    
     return 0;
 }
 
 HANDLE CImportDataPromptDialog::StartImportDataThread()
 {
     LOG("啟動匯入資料執行緒");
     CWinThread* hThread = AfxBeginThread((AFX_THREADPROC)CImportDataPromptDialog::ImportDataThread,(LPVOID)this);
 
    return (hThread->m_hThread);
 }

4.幾個相關重要函式的詳細講解

4.1 CloseWindow

函式功能:該函式最小化指定的視窗,但並不銷燬該視窗。
函式原型:BOOL CloseWindow(HWND hWnd);

引數:hWnd:將要最小化的視窗的控制代碼。
返回值:如果函式成功,返回值為非零;如果函式失敗,返回值為零。若想獲得更多錯誤資訊,請呼叫GetLastError函式。
備註:視窗尺寸被最小化成一個圖示,並移動到螢幕的圖示區域。系統顯示視窗的圖示而不顯示視窗,並在圖示下顯示視窗標題。應用程式必須使用DestroyWindow函式銷燬視窗。

4.2 DestroyWindow 

函式功能:銷燬指定的視窗。這個函式通過傳送WM_DESTROY 訊息和 WM_NCDESTROY 訊息使視窗無效並移除其鍵盤焦點。這個函式還銷燬視窗的選單,清空執行緒的訊息佇列,銷燬與視窗過程相關的定時器,解除視窗對剪貼簿的擁有權,打斷剪貼簿器的檢視鏈。
函式原型:BOOL DestroyWindow( HWND hWnd // handle to window to destroy);
hWnd :將被銷燬的視窗的控制代碼。
返回值:如果函式成功,返回值為非零:如果函式失敗,返回值為零。若想獲得更多錯誤資訊,請呼叫GetLastError函式。
備註:一個執行緒不能使用本函式銷燬別的執行緒建立的視窗。如果這個視窗是一個不具有WS_EX_NOPARENTNOTIFY 樣式的子視窗,則銷燬視窗時將發WM_PARENTNOTIFY 訊息給其父視窗。Windows CE: 本函式將不傳送 WM_NCDESTROY 訊息.

4.3 EndDialog

函式功能該函式清除一個模態對話方塊,並使系統中止對對話方塊的任何處理
函式原型:BOOL EndDialog(HWND hDlg,int nResult);
引數:hDlg:表示要被清除的對話方塊視窗。NResult:指定從建立對話方塊函式返回到應用程式的值。
返回值:如果函式呼叫成功,則返回值為非零值;如果函式呼叫失敗則返回值為零。若想獲得錯誤資訊請呼叫GetLastError函式。
備註:由DialogBox,DialogBoxParam、DialogBoxlndirect和DialogBoxlndirectParam函式建立的對話方塊一定要用EndDialog函式來清除。應用程式從對話方塊應用程式內部呼叫EndDialog函式,該函式不能為其他目的而供使用。對話方塊應用程式可以在任何時間呼叫EndDialog函式;甚至在WM_INITDIALOG訊息處理過程中。如果應用程式在WM_INTDIALOG訊息處理過程中呼叫該函式,則對話方塊在顯示和輸入焦點被設定之前對話方塊被清除。EndDialog函式並不立即清除對話方塊。而是設定一個標誌,並且允許對話方塊應用程式把控制權返回系統。系統在試圖從應用程式佇列檢索下一個訊息之前檢測標誌。如果已經設定了標誌則系統中止訊息迴圈,清除對話方塊,且用nResUlt中的值作為從建立對話方塊的函式中返回的值。