AcceptEnd
Inhalt
[
Ausblenden
]Footnote.AcceptEnd method
Akzeptiert einen Besucher für den Besuch des Endes der Fußnote.
public override VisitorAction AcceptEnd(DocumentVisitor visitor)
Parameter | Typ | Beschreibung |
---|---|---|
visitor | DocumentVisitor | Der Dokumentbesucher. |
Rückgabewert
Die vom Besucher auszuführende Aktion.
Beispiele
Zeigt, wie die Knotenstruktur jeder Fußnote in einem Dokument gedruckt wird.
public void FootnoteToText()
{
Document doc = new Document(MyDir + "DocumentVisitor-compatible features.docx");
FootnoteStructurePrinter visitor = new FootnoteStructurePrinter();
// Wenn wir einen zusammengesetzten Knoten dazu bringen, einen Dokumentbesucher zu akzeptieren, besucht der Besucher den akzeptierenden Knoten.
// und durchläuft dann alle untergeordneten Knoten in einer Tiefensuche.
// Der Besucher kann jeden besuchten Knoten lesen und ändern.
doc.Accept(visitor);
Console.WriteLine(visitor.GetText());
}
/// <summary>
/// Durchläuft den nicht-binären Baum der untergeordneten Knoten eines Knotens.
/// Erstellt eine Karte in Form einer Zeichenfolge aller gefundenen Fußnotenknoten und ihrer untergeordneten Elemente.
/// </summary>
public class FootnoteStructurePrinter : DocumentVisitor
{
public FootnoteStructurePrinter()
{
mBuilder = new StringBuilder();
mVisitorIsInsideFootnote = false;
}
/// <summary>
/// Ruft den Klartext des vom Besucher gesammelten Dokuments ab.
/// </summary>
public string GetText()
{
return mBuilder.ToString();
}
/// <summary>
/// Wird aufgerufen, wenn im Dokument ein Fußnotenknoten gefunden wird.
/// </summary>
public override VisitorAction VisitFootnoteStart(Footnote footnote)
{
IndentAndAppendLine("[Footnote start] Type: " + footnote.FootnoteType);
mDocTraversalDepth++;
mVisitorIsInsideFootnote = true;
return VisitorAction.Continue;
}
/// <summary>
/// Wird aufgerufen, nachdem alle untergeordneten Knoten eines Fußnotenknotens besucht wurden.
/// </summary>
public override VisitorAction VisitFootnoteEnd(Footnote footnote)
{
mDocTraversalDepth--;
IndentAndAppendLine("[Footnote end]");
mVisitorIsInsideFootnote = false;
return VisitorAction.Continue;
}
/// <summary>
/// Wird aufgerufen, wenn im Dokument ein Run-Knoten gefunden wird.
/// </summary>
public override VisitorAction VisitRun(Run run)
{
if (mVisitorIsInsideFootnote) IndentAndAppendLine("[Run] \"" + run.GetText() + "\"");
return VisitorAction.Continue;
}
/// <summary>
/// Fügen Sie dem StringBuilder eine Zeile hinzu und rücken Sie sie ein, je nachdem, wie tief der Besucher im Dokumentbaum ist.
/// </summary>
/// <param name="text"></param>
private void IndentAndAppendLine(string text)
{
for (int i = 0; i < mDocTraversalDepth; i++) mBuilder.Append("| ");
mBuilder.AppendLine(text);
}
private bool mVisitorIsInsideFootnote;
private int mDocTraversalDepth;
private readonly StringBuilder mBuilder;
}
Siehe auch
- enum VisitorAction
- class DocumentVisitor
- class Footnote
- namensraum Aspose.Words.Notes
- Montage Aspose.Words