博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TX Text Control文字处理教程(4)标记文本域
阅读量:6388 次
发布时间:2019-06-23

本文共 3520 字,大约阅读时间需要 11 分钟。

标记文本域是在文本中插入的一些标记,在文字处理器中可以通过标记文本来实现非常广泛的文字处理功能。例如:

  •         邮件合并
  •         电子表格中的计算域
  •         书签
  •         自动生成表格内容和索引
  •         超文本链接和锚点

标记文本域可以由任意字符组合而成,TX 中最多可以包含65535个标记文本域,TX会维护这些文本域的位置和编号信息,同时还可以进行加载、保存和剪贴板操作。
该章节相应的源代码可以在TX Text Control.NET的安装目录中找到:

  •         Samples\WinForms\VB.NET\ Printing
  •         Samples\WinForms\CSharp\ Printing

第一节:创建标记文本域
该节主要演示如何创建标记文本域和标记文本域的Click事件。示例程序中包含一个菜单项【Insert Field!】、两个Text Control控件,其中一个是普通文本编辑窗口,另一个是提示信息窗口。以下代码演示如何创建一个标记文本域:

private void mnuInsertField_Click(object sender, System.EventArgs e) {     TXTextControl.TextField newField = new TXTextControl.TextField();     newField.Text = "--------";     newField.ID = fieldID;     fieldID += 1;     textControl1.TextFields.Add(newField); }

通过以上代码在当前输入位置插入一个文本域,并且给文本域的ID属性设置一个位置的值。当鼠标移动至文本域时Text Control 会将光标变为手型光标,以此提示用户当前位置有一个文本域,此时点击文本域会触发TextFieldClicked事件,而且会弹出一个显示当前文本域编号的提示框。

private void textControl1_TextFieldClicked(object sender, TXTextControl.TextFieldEventArgs e) { // Field has been clicked on, update text of second TX and display it     textControl2.Text = "Field clicked, ID: " + e.TextField.ID;     textControl2.BringToFront(); } private void textControl1_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) {     textControl1.BringToFront(); }

 

第二节:书签

该示例演示如何使用标记文本域来创建书签。首先我们将用文本域的编号来访问该文本域。示例程序中包含一个【Bookmar】菜单,包含两个子菜单项【Insert】和【Go to...】。点击【Insert】菜单时会在当前位置创建一个文本域;如果选择文本不为空会将选中的文本转换为标记文本域,代码如下:

private void mnuBookmark_Insert_Click(object sender, System.EventArgs e) { if (textControl1.Text == "")     {         MessageBox.Show("Cannot insert a bookmark if the Text Control is empty.");     } else if (textControl1.Selection.Length == 0)     {         textControl1.Selection.Length = 1;     } else     {         TXTextControl.TextField newField = new TXTextControl.TextField();         newField.ID = fieldID;         newField.Text = textControl1.Selection.Text;         textControl1.Selection.Text = "";         fieldID += 1;         textControl1.TextFields.Add(newField);     } }

在文档中输入一些文本并插入一些书签,然后选择【Go To...】菜单,此时会弹出一个对话框,可以在对话框中输入书签的编号,如果该书签存在点击【OK】按钮会自动跳转到书签所在的位置,实现代码如下:

private void cmdOK_Click(object sender, System.EventArgs e) { if (Convert.ToInt32(textBox1.Text) > tx.TextFields.Count)     {         MessageBox.Show ("Invalid bookmark number!");     } else     { foreach (TXTextControl.TextField field in tx.TextFields)         { if (field.ID == Convert.ToInt32(textBox1.Text))             {                 tx.Selection.Start = field.Start - 1;                 tx.Selection.Length = field.Length;             }         }     }     Close(); }

第三节:为书签指定名称

        在商业的文本编辑器中,不仅可以通过编号来访问书签,还可以通过书签名来访问。用户在创建书签时可以为书签指定名称。在【GoTo Bookmark】对话框中用户可以选择书签名称,然后跳转到该书签所在位置。
在创建书签时,用户需要为书签指定一个名称。实现代码如下:

private void cmdOK_Click(object sender, System.EventArgs e) {     TXTextControl.TextField field = new TXTextControl.TextField();     field.Name = textBox1.Text;     field.Text = tx.Selection.Text;     tx.Selection.Text = "";     tx.TextFields.Add(Field);     Close(); }

通过以上操作,我们创建了书签并指定了书签的名字。下面将在【Goto Bookmark】对话框中显示所有书签的名字,实现代码如下:

private void frmGotoDialog_Load(object sender, System.EventArgs e) { foreach (TXTextControl.TextField Field in tx.TextFields) {         ComboBox1.Items.Add(Field.Name);     } }

在用户选择书签之后点击【OK】按钮时,将通过遍历全部书签的方式找到用户指定的书签,实现代码如下:

private void cmdOK_Click(object sender, System.EventArgs e) { foreach (TXTextControl.TextField field in tx.TextFields)     { if (field.Name == comboBox1.Text)         {             tx.Selection.Start = field.Start - 1;             tx.Selection.Length = field.Length;         }     }     Close(); }

 

转载地址:http://mudha.baihongyu.com/

你可能感兴趣的文章
关于Vuex的action传入多个参数的问题
查看>>
放弃jQuery, 使用原生js
查看>>
跨越适配&性能那道坎,企鹅电竞Android weex优化
查看>>
一文读懂鼠标滚轮事件(wheelEvent)
查看>>
腾讯云国内节点centos7.2安装k8sv1.12.3
查看>>
Python爬虫--- 1.5 爬虫实践: 获取百度贴吧内容
查看>>
解决Shell脚本$'\r': command not found问题
查看>>
ionic3使用百度地图
查看>>
JavaWEB开发11——JSP
查看>>
轻松搞定javascript中this的指向
查看>>
每天一个设计模式之单例模式
查看>>
Image Load Error Handler
查看>>
易燃易爆炸---python对Excel操作的面试题
查看>>
Vue2.5笔记:Vue中的模版
查看>>
策略路由基础命令(Linux)分享
查看>>
linux下磁盘挂载与查看
查看>>
javascript 闭包
查看>>
如何减少浏览器repaint和reflow(上)
查看>>
Exchange 2010之收件人对象管理
查看>>
Yarn详解
查看>>