关闭对话框,OnClose和OnCancel

      我们知道,在对话框中,屏蔽ESC键自己主动退出能够选择重载OnCancel为哑函数的方法:

     void CXXXXDlg::OnCancel()
     {
        // TODO: Add your specialized code here and/or call the base class

        //CDialog::OnCancel(); //disable OnCancel
     }

      可是,这样一来,右上角的关闭button也不起作用了,是由于点击关闭button时会自己主动调用CXXXXDlg::OnCancel()l从而完毕对话框的关闭,由于CXXXXDlg::OnCancel()中什么也没有做,因此对话框就无法关闭。改动这个bug须要重载OnClose消息函数:

      void CXXXXDlg::OnClose()
      {
            // TODO: Add your message handler code here and/or call default

            CDialog::OnCancel();  //add OnCancel here


            CDialog::OnClose();           
      }

        因为OnCancle实际上是调用Enddialog(IDCANCEL),所以也能够依照例如以下改动:

      void CXXXXDlg::OnClose()
      {
            // TODO: Add your message handler code here and/or call default

             EndDialog(IDCANCEL); 


            CDialog::OnClose();           
      }

      我们知道OnClose函数是WM_CLOSE消息的响应函数,可是为什么发送WM_CLOSE消息后会自己主动调用CXXXXDlg::OnCancel()?自己跟了一下代码,大致梳理了一下流程:

           WM_CLOSE

     -> 进入void CXXXXDlg::OnClose()

     -> CDialog::OnClose()        

     -> void CXXXXDlg::OnClose()返回

     -> void CXXXXDlg::OnCancel()

      比較奇妙的是 CDialog::OnClose() 函数:

     

      这个函数中不知道以何种方式告知系统在 CXXXXDlg::OnClose() 返回 后去调用 CXXXXDlg::OnCancel(),在调试中假设把这个函数凝视掉,则不会转入CXXXXDlg::OnCancel()函数中。并且,对于CXXXXDlg::OnCancel()函数的调用是在CXXXXDlg::OnClose() 返回 后,假设採用消息,我认为是否应该不会在返回后调用,而应该在消息发送后立即处理。

      

       网上找了非常久也没有得到答案,临时记录在此,或许哪天自己明确了,或是被牛人发现了给出解答。

原文地址:https://www.cnblogs.com/mfrbuaa/p/3809716.html