发现WPF在Windows 7 的一个BUG ,多点触摸开发的注意了
问题:
系统为windows 7 触摸一体机,MutilTouch消息
例如新建一个叫Windows1普通窗口,然后设置TopMost = true,然后添加一个image(其它类似控件也可以),给image控件加上MouseLeftDown事件,
在MouseLeftDown事件中随便打开一个Form的对话框,例如打开文件对话、颜色选择对话框等:
System.Windows.Forms.OpenFileDialog file = new System.Windows.Forms.OpenFileDialog();
file.Filter = "Office Documents(*.ppt;*.pptx;*.doc;*.docx*.xls;*.xlsx)|*.ppt;*.pptx;*.doc;*.docx;*.xls;*.xlsx;";
//file.InitialDirectory = System.Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments); ;
if (file.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
……………………
}
然后用鼠标点击image控件正常,打开对话框。
而放入Windows 7 触摸一体机中,触摸点击image,可以打开对话框,关闭对话框,但是如果再次触摸在windows1窗口的非image上,则一直会继续弹出对话框,不能在windows1窗口上做任何操作,一直是弹出对话框的操作,除非点击出windwos1窗口区域外再点击回窗口。
目前发现MouseLeftDown ,MouseLeftUp等是MouseEvent的都有这个问题。头一回出现这个问题,搞了很久,以为是软件的的bug,后面多新建了几个测试案例都会出来,所以确认是一个bug。
后面想了想发现是这个TopMost 属性造成的,只要当前窗口是置顶的,并且再打开一个GDI窗口则肯定会出现这个问题,这个应该是WPF在传递转化触摸消息时出现的问题,把TopMost属性为false就没有这个问题。
实际在开发过程中,我们又避免不了使用置顶窗口和鼠标事件,这个涉及到跨NT的问题例如程序从windows xp 到 windows 7都支持,xp没有Touch,那么我们如何解决呢,其实简单,换成Button并且使用Click来处理即可。
经验愚见仅供参考,至微软WPF团队
作者:e@Board