WPF的RichTextBox在处理汉字时的小BUG
来源:互联网 发布:php v和phpinfo 编辑:程序博客网 时间:2024/06/08 14:13
WPF 3.5的RichTextBox在处理汉字时的小BUG
近来打算封装WPF 中的RichTextBox(.NET 3.5 SP1,在Visual studio 2008 Sp1下)为一个简易文本编辑器,发现了其在处理汉字中存在的一些小问题。
(下文均假设光标所在处文本原先没有粗体特性,并且没有选中任何文本)。
比如要输入粗体文字,在没有选中文本的情况下,压Ctrl+B切换为粗体之后,如果接着输入英文字符,则会以粗体显示,这是正确的,但如果输入的是汉字,则汉字不会变为粗体。
在Windows Form版本中RichTextBox则无此问题。不知为何微软的测试工程师会漏掉了这么明显的问题。
我还试验了一下英文句子和中文句子。 当光标位于一个英文单词内时,压Ctrl+B整个单词会切换到粗体。而对于汉字则无反应。估计RichTextBox在设计时为了支持英文单词的自动抽取,将汉字将其看成是英文单词的另一种“分界符”而不予处理。
这问题能否弥补?
我尝试着想直接通过操纵其底层的FlowDocument来解决这个问题,仔细查看了RichTextBox生成的FlowDocument,发现RichTextBox把每个设为粗体的文本都自动抽取为一个独立的Run元素,而当取消粗体时,会将这一Run元素与其相邻的Run元素合并(如果相邻的Run元素没有设为粗体的话)。
再试验粗体与斜体等复合模式时,我发现了一个规律:RichTextBox会在其文本格式或内容更改时,自动合并其样式一致的相邻的Run元素,还会自动删除为空的Run元素。真可谓相当智能。
RichTextBox内部还定义了自己的命令绑定对象响应EditingCommands.ToggleBold等命令,直接捕获Ctrl+B快捷键。
由此可见,要解决这个问题,必须干预Run元素的分分合合,同时还要处理鼠标和键盘等输入捕获事件,其工作量还真不是几个小时就能搞掂的。最终我决定放弃了,这个问题看上去不大,但要处理起来还真麻烦。
这个Bug不知在以后的版本中是否会更正。不知其他朋友是否也发现了这个问题,有无简便的法子解决?
- WPF的RichTextBox在处理汉字时的小BUG
- WPF richtextbox的使用
- WPF中RichTextBox的使用小窍门(翻译、整理)
- WPF 处理RichTextBox, ListView等的Scroll Bar 事件(event)
- WPF中RichTextBox设置文本的样式
- WPF中richtextbox的一些用法
- WPF SL 获取RichTextBox 的内容(string)
- richtextbox中插入文件路径链接时出错的处理
- winForm RichTextBox文档处理的相关功能
- WPF RICHTEXTBOX 和数据库读写图文的方法。
- WPF RICHTEXTBOX 和数据库读写图文的方法
- WPF 读取和存储RichTextBox的文档内容
- WPF RichTextBox读取存储文本的方法和常用属性
- WPF中RichTextBox实现和Winform一样的效果
- 在WPF里,也有类似的BUG
- WPF richtextbox
- 关于各种编码问题,汉字处理的一点小总结
- 汉字的处理
- PHP读取文件夹内有多少个文件
- ajax是整个java世界为了UED(用户体验)的一次倒退(转自水木清华)
- PetShop4数据访问层探秘
- PHP中文处理函数集合
- Tip #3 你知道吗?拆分视图也可以垂直分割
- WPF的RichTextBox在处理汉字时的小BUG
- PHP的Socket函数参考
- PHP设置COOKIE保留时间为浏览器进程
- c#在WORD中添加目录
- SQL Server表结构转为word表格
- 提升网站流量的26计
- VC 6.0 下搭建 wxWidgets 开发环境
- java字符编码转换研究
- ASPNET控件 FCKeditor 处理 word Ctrl+V