VisitEditableRangeStart
内容
[
隐藏
]DocumentVisitor.VisitEditableRangeStart method
当在文档中遇到可编辑范围的开始时调用。
public virtual VisitorAction VisitEditableRangeStart(EditableRangeStart editableRangeStart)
范围 | 类型 | 描述 |
---|---|---|
editableRangeStart | EditableRangeStart | 正在访问的对象。 |
返回值
一个VisitorAction
指定如何继续枚举的值。
例子
展示如何打印文档中每个可编辑范围的节点结构。
public void EditableRangeToText()
{
Document doc = new Document(MyDir + "DocumentVisitor-compatible features.docx");
EditableRangeStructurePrinter visitor = new EditableRangeStructurePrinter();
// 当我们得到一个复合节点来接受文档访问者时,访问者会访问接受节点,
// 然后以深度优先的方式遍历该节点的所有子节点。
// 访问者可以读取和修改每个访问的节点。
doc.Accept(visitor);
Console.WriteLine(visitor.GetText());
}
/// <summary>
/// 遍历节点的子节点非二叉树。
/// 以字符串的形式创建所有遇到的 EditableRange 节点及其子节点的地图。
/// </summary>
public class EditableRangeStructurePrinter : DocumentVisitor
{
public EditableRangeStructurePrinter()
{
mBuilder = new StringBuilder();
mVisitorIsInsideEditableRange = false;
}
/// <summary>
/// 获取访问者积累的文档的纯文本。
/// </summary>
public string GetText()
{
return mBuilder.ToString();
}
/// <summary>
/// 在文档中遇到 Run 节点时调用。
/// </summary>
public override VisitorAction VisitRun(Run run)
{
// 我们想要打印运行的内容,但只有当它们位于形状内时才打印,就像在文本框中一样
if (mVisitorIsInsideEditableRange) IndentAndAppendLine("[Run] \"" + run.GetText() + "\"");
return VisitorAction.Continue;
}
/// <summary>
/// 当在文档中遇到 EditableRange 节点时调用。
/// </summary>
public override VisitorAction VisitEditableRangeStart(EditableRangeStart editableRangeStart)
{
IndentAndAppendLine("[EditableRange start] ID: " + editableRangeStart.Id + " Owner: " +
editableRangeStart.EditableRange.SingleUser);
mDocTraversalDepth++;
mVisitorIsInsideEditableRange = true;
return VisitorAction.Continue;
}
/// <summary>
/// 当对 EditableRange 节点的访问结束时调用。
/// </summary>
public override VisitorAction VisitEditableRangeEnd(EditableRangeEnd editableRangeEnd)
{
mDocTraversalDepth--;
IndentAndAppendLine("[EditableRange end]");
mVisitorIsInsideEditableRange = false;
return VisitorAction.Continue;
}
/// <summary>
/// 向 StringBuilder 附加一行并根据访问者在文档树中的深度进行缩进。
/// </summary>
/// <param name="text"></param>
private void IndentAndAppendLine(string text)
{
for (int i = 0; i < mDocTraversalDepth; i++) mBuilder.Append("| ");
mBuilder.AppendLine(text);
}
private bool mVisitorIsInsideEditableRange;
private int mDocTraversalDepth;
private readonly StringBuilder mBuilder;
}
也可以看看
- enum VisitorAction
- class EditableRangeStart
- class DocumentVisitor
- 命名空间 Aspose.Words
- 部件 Aspose.Words