GetEntity
LayoutCollector.GetEntity method
Возвращает непрозрачную позициюLayoutEnumerator
который соответствует указанному узлу. Вы можете использовать возвращаемое значение в качестве аргумента дляCurrent
учитывая, что документ being перечислен и документ узла одинаковы.
public object GetEntity(Node node)
Примечания
Этот метод работает только дляParagraph
узлы, а также неделимые линейные узлы, напримерBookmarkStart
илиShape
. Это не работает дляRun
,Cell
Row
илиTable
узлы и узлы в верхнем/нижнем колонтитуле.
Обратите внимание, что сущность вернулась дляParagraph
узел — это разрыв абзаца. Используйте соответствующий метод для перехода к родительской строке
Если вам нужно перейти кRun
текста, то вы можете вставить закладку прямо перед it , а затем перейти к закладке.
Если вам нужно перейти кCell
узел, затем вы можете перейти кParagraph
узел в этой ячейке, а затем восходит к родительской сущности. Тот же подход может быть использован дляRow
иTable
узлы.
Примеры
Показывает, как просмотреть диапазоны страниц, охватываемые узлом.
Document doc = new Document();
LayoutCollector layoutCollector = new LayoutCollector(doc);
// Вызываем метод «GetNumPagesSpanned», чтобы подсчитать, сколько страниц занимает содержимое нашего документа.
// Поскольку документ пуст, количество страниц в данный момент равно нулю.
Assert.AreEqual(doc, layoutCollector.Document);
Assert.AreEqual(0, layoutCollector.GetNumPagesSpanned(doc));
// Заполните документ 5 страницами контента.
DocumentBuilder builder = new DocumentBuilder(doc);
builder.Write("Section 1");
builder.InsertBreak(BreakType.PageBreak);
builder.InsertBreak(BreakType.PageBreak);
builder.InsertBreak(BreakType.SectionBreakEvenPage);
builder.Write("Section 2");
builder.InsertBreak(BreakType.PageBreak);
builder.InsertBreak(BreakType.PageBreak);
// Перед сборщиком макетов нам нужно вызвать метод "UpdatePageLayout", чтобы получить
// точная цифра для любой метрики, связанной с макетом, например, количество страниц.
Assert.AreEqual(0, layoutCollector.GetNumPagesSpanned(doc));
layoutCollector.Clear();
doc.UpdatePageLayout();
Assert.AreEqual(5, layoutCollector.GetNumPagesSpanned(doc));
// Мы можем видеть номера начальной и конечной страниц любого узла и их общее количество страниц.
NodeCollection nodes = doc.GetChildNodes(NodeType.Any, true);
foreach (Node node in nodes)
{
Console.WriteLine($"-> NodeType.{node.NodeType}: ");
Console.WriteLine(
$"\tStarts on page {layoutCollector.GetStartPageIndex(node)}, ends on page {layoutCollector.GetEndPageIndex(node)}," +
$" spanning {layoutCollector.GetNumPagesSpanned(node)} pages.");
}
// Мы можем перебирать сущности макета, используя LayoutEnumerator.
LayoutEnumerator layoutEnumerator = new LayoutEnumerator(doc);
Assert.AreEqual(LayoutEntityType.Page, layoutEnumerator.Type);
// LayoutEnumerator может обходить коллекцию сущностей макета как дерево.
// Мы также можем применить его к соответствующей сущности макета любого узла.
layoutEnumerator.Current = layoutCollector.GetEntity(doc.GetChild(NodeType.Paragraph, 1, true));
Assert.AreEqual(LayoutEntityType.Span, layoutEnumerator.Type);
Assert.AreEqual("¶", layoutEnumerator.Text);
Смотрите также
- class Node
- class LayoutCollector
- пространство имен Aspose.Words.Layout
- сборка Aspose.Words