续上一节
rtf编辑器已经基本完工,那么我们可以运行进行测试,
不错,一切都运行的很好。
但是,当我们使用了粗体时,偶尔会发生错误:
那么,分析一下造成这种情况的原因:
当选择的单一字体时不会发生,但是当两种字体混合处理的时候就会发生。
Dim selFontName As String = RichTextBox1.SelectionFont.Name
红色框内的备注告诉了我们答案,如果有多种字体,那么SelectionFont为Nothing。
那么如何解决这个问题呢?
最初的方法是,一个字一个字地分析用的字体,这样就不会发生出现多个字体的情况,就不会造成选择的字体是Nothing:
Private Sub ToolStripButton7_Click(sender As Object,e As EventArgs) Handles ToolStripButton7.Click Dim posStart As Integer = RichTextBox1.SelectionStart Dim posLength As Integer = RichTextBox1.SelectionLength For i As Integer = 0 To posLength - 1 RichTextBox1.Select(posStart + i,1) Dim selFontName As String = RichTextBox1.SelectionFont.Name Dim selFontSize As Integer = RichTextBox1.SelectionFont.Size Dim selFontStyle As FontStyle = RichTextBox1.SelectionFont.Style Xor FontStyle.Bold RichTextBox1.SelectionFont = New Font(selFontName,selFontSize,selFontStyle) Next RichTextBox1.Select(posStart,posLength) End Sub
Private Sub ToolStripButton7_Click(sender As Object,e As EventArgs) Handles ToolStripButton7.Click Dim posStart As Integer = RichTextBox1.SelectionStart Dim posLength As Integer = RichTextBox1.SelectionLength RichTextBox1.Select(posStart,1) Dim selFontStyle As FontStyle = RichTextBox1.SelectionFont.Style Xor FontStyle.Bold For i As Integer = 0 To posLength - 1 RichTextBox1.Select(posStart + i,1) Dim selFontName As String = RichTextBox1.SelectionFont.Name Dim selFontSize As Integer = RichTextBox1.SelectionFont.Size 'Dim selFontStyle As FontStyle = RichTextBox1.SelectionFont.Style Xor FontStyle.Bold-->这里被注释掉了 RichTextBox1.SelectionFont = New Font(selFontName,posLength) End Sub
先判断选择的第一个文字是不是粗体,如果不是,那么选中这一段全部都是粗体,如果是粗体,那么选中的这一段全部都不是粗体。
第一个问题是解决了,但是第二个问题始终存在。
于是,我又想了个办法,类似于处理图片时使用的双缓冲方法,增加一个richtextBox,在这个里面处理好后再复制到真正处理Rtf的RichtextBox(先在窗体上再增加一个富文本框:RichTextBox2,实际运行的时候不显示出来):
Private Sub ToolStripButton7_Click(sender As Object,e As EventArgs) Handles ToolStripButton7.Click Dim posStart As Integer = RichTextBox1.SelectionStart Dim posLength As Integer = RichTextBox1.SelectionLength RichTextBox2.Clear() ' RichTextBox2.Rtf = RichTextBox1.SelectedRtf Dim posStart2 As Integer = 0 Dim posLength2 As Integer = RichTextBox1.SelectionLength RichTextBox2.Select(posStart2,1) Dim selFontStyle As FontStyle = RichTextBox2.SelectionFont.Style Xor FontStyle.Bold For i As Integer = 0 To posLength2 - 1 RichTextBox2.Select(posStart2 + i,1) Dim selFontName As String = RichTextBox2.SelectionFont.Name Dim selFontSize As Integer = RichTextBox2.SelectionFont.Size RichTextBox2.SelectionFont = New Font(selFontName,selFontStyle) Next RichTextBox2.Select(0,RichTextBox2.TextLength) RichTextBox1.SelectedRtf = RichTextBox2.SelectedRtf RichTextBox1.Select(posStart,posLength) End Sub
这下完美解决了。不会再像打字机一样了。
不过,奇怪的是,处理的时候,RichTextBox2中也没有像打字机一样,真是太奇怪了。。。。
总之是把这个问题解决了。
最后还有些问题留给读者解决:
1、如果是打开已有文档,保存的时候不再弹出保存文件对话框。(设置一个窗体级变量保存打开的文档全路径)
学习更多vb.net知识,请参看
vb.net 教程 目录