Duilib中创建子窗口后,子窗口销毁的问题
自己在学习Duilib时,学习ListDemo中的右键生成菜单,然后当菜单被点击活着失去焦点时,这个菜单窗口如何销毁的问题。
1、在这里,创建菜单时使用了子窗口的概念,创建时,使用了WS_EX_TOOLWINDOW类型,表示是一个工具栏窗口。
2、这个菜单窗口有自己的消息处理函数HandleMessage。第一次的尝试是调用CWindowWnd中的Close函数,查看了这个函数的源码,发现其中是使用PostMessage给自己发送了一个WM_CLOSE的消息,然后在HandleMessage中拦截WM_CLOSE的消息,在消息处理函数中调用了PostQuitMessage(0),此种情况下,菜单窗口是退出了,但是父窗口也是跟着退出了。因为在CPaintManager的MessageLoop中的GetMessage,当收到WM_QUIT的消息时会返回0,此时,MessageLoop中的while循环就会给打破。整个消息循环就会退出,因此整个程序退出
3、第二次的尝试,是直接在菜单项被选中和菜单窗口失去焦点时调用PostQuitMessage(0),由于跟第一次尝试是换汤不换药的动作,因此也已失败告终。
4、由于前两次的失败,然后再网上各种查询也未找到相关的解决方法。后来在查看MSDN时,查看了消息WM_CLOSE的Remark,其中说道“应用程序通过处理WM_CLOSE消息,可以在窗口销毁前对用户做一些提示,如果用户确认提示的话,通过调用DestoryWindow来销魂窗口”。因此,此基础和第一二次尝试的基础上,对代码进行了修改。首先,在菜单项被选中和菜单窗口失去焦点时调用CWindowWnd的Close函数,然后在窗口的消息处理函数中拦截WM_CLOSE消息,在WM_CLOSE的消息处理函数中通过使用DestoryWindow来达到销毁菜单窗口的目的,在调用了DestoryWindow后,再调用delete this来删除窗体本身。这样才达到了效果。
当然,在做完第4步时,也遇到了其他的一些小麻烦,稍作调试即完成。也算对window应用编程又有了点新的体会。