子對話框的創建與銷毀

伊谢尔伦
發布: 2016-11-21 11:44:49
原創
1571 人瀏覽過

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();  ::OnCancel(); //取消按鈕被按下

2.CDialog::DestoryWindow(); 

3.CDialog::EndDialog( IDD );  

3.在模態對話框類別中關閉自身對話框

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

參考程式碼如下:

<span style="font-size:18px;">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);
 }</span>
登入後複製

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中的值作為從建立對話方塊的函數中傳回的值。


相關標籤:
c++
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板