问题
我在使用WPF进行编程的时候,发现的一个最大问题就是WPF与中文输入法的兼容性问题。
出现的问题大概分为两种:
- 程序崩溃;
- 无法切换输入法。
在笔者的环境中并未遇到过崩溃的情况,只是后一种情况。但我想这两种情况的原因应该一样。
具体的表现为:在WPF中的Textbox控件中输入汉字的时候,我们需要先切换输入法。切换之后状态栏显示切换成功,而开始键入拼音的时候却发现直接将拼音输入了Textbox框中,情形好似并未切换成功。
而且更为棘手的是,这种情况并不是绝对的,重启程序和多次切换输入法都可能会变为正常。
我的环境为Win10 + VS2012 + WPF4.5 + QQ拼音输入法5.1
解决方案
由于这个问题仅仅存在于中文输入环境中,外国人应该没有此问题,因此在Stack Overflow并未找到解决方案。
我在遇到这个问题后晾了好久都未解决,后来看到WPF中有个WindowsFormsHost控件,也就是WinForm宿主。因此我想,既然WinForm中不存在这个问题,那么把WinForm的Textbox通过此宿主来代替WPF的Textbox是否能解决这个问题呢?
经过尝试,发现确实可以。具体步骤为:
1、在窗口布局中加入一个WindowsFormsHost控件,设置Name(此处为host);
2、用代码在host中加入一个WinForm的Textbox:
host.Child = new System.Windows.Forms.TextBox();
不足
当然这种方案并不是完美的,比如以下几点:
性能、外观不足
WPF相比WinForm的一个最大好处是界面更绚丽和流畅。使用这种方案则失去了这种好处,好在Textbox一般并不需要背景图片或者半透明之类的特效,因此此处影响不大。
可移植性
由于此方案混合了两种GUI框架,因此无法用于仅支持WPF的环境中。