关闭对话框,OnClose和OnCancel

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

 

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

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

      但是,这样一来,右上角的关闭按钮也不起作用了,是因为点击关闭按钮时会自动调用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() 返回 后,如果采用消息,我觉得是否应该不会在返回后调用,而应该在消息发送后马上处理。

      

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

你可能感兴趣的:(Class)