检索、获取、复制和插入页面

检索页面信息

在 Microsoft Visio 中,页面要么是前景页面,要么是背景页面。要获取页面信息,例如页面 ID 和页面名称,首先要确定页面是背景页面还是前景页面。

对象表示前景页面或背景页面的绘图区域。公开的 Pages 属性Diagram类支持 Aspose.Diagram.Page 对象的集合。此属性可用于检索页面信息。

使用 Page.Background 属性确定页面是前景页面还是背景页面。

检索页面信息编程示例

以下代码从 diagram 中检索页面信息。

// For complete examples and data files, please go to https://github.com/aspose-diagram/Aspose.Diagram-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_VisioPages();
// Call the diagram constructor to load diagram from a VDX file
Diagram vdxDiagram = new Diagram(dataDir + "RetrievePageInfo.vdx");
foreach (Aspose.Diagram.Page page in vdxDiagram.Pages)
{
// Checks if current page is a background page
if (page.Background == Aspose.Diagram.BOOL.True)
{
// Display information about the background page
Console.WriteLine("Background Page ID : " + page.ID);
Console.WriteLine("Background Page Name : " + page.Name);
}
else
{
// Display information about the foreground page
Console.WriteLine("\nPage ID : " + page.ID);
Console.WriteLine("Universal Name : " + page.NameU);
Console.WriteLine("ID of the Background Page : " + page.BackPage);
}
}

从 Diagram 获取 Visio 页面

有时,开发人员需要获取 Visio 图的页面详细信息。 Aspose.Diagram 具有帮助他们做到这一点的功能。

Aspose.Diagram for .NET 提供Diagram表示 Visio 绘图的类。 Diagram 类公开的 Pages 属性支持 Aspose.Diagram.Page 对象的集合。 PageCollection 类公开了可以调用以获取 Page 对象的 GetPage 方法。

通过 ID 获取 Visio 页面对象

这个例子的工作原理如下:

  1. 创建 Diagram 类的对象。
  2. 调用 Diagram.Pages 类的 GetPage 方法。

以下示例显示如何通过 id 从 Visio 绘图中获取页面对象。

通过 ID 获取页面对象编程示例

// For complete examples and data files, please go to https://github.com/aspose-diagram/Aspose.Diagram-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_VisioPages();
// Call the diagram constructor to load diagram from a VDX file
Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");
// Set page id
int pageid = 2;
// Get page object by id
Page page2 = diagram.Pages.GetPage(pageid);

按名称获取 Visio 页面对象

这个例子的工作原理如下:

  1. 创建 Diagram 类的对象。
  2. 调用 Diagram.Pages 类的 GetPage 方法。

按名称获取页面对象编程示例

以下示例显示如何从 Visio 绘图中按名称获取页面对象。

// For complete examples and data files, please go to https://github.com/aspose-diagram/Aspose.Diagram-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_VisioPages();
// Call the diagram constructor to load diagram from a VSDX file
Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");
// Set page name
string pageName = "Flow 2";
// Get page object by name
Page page2 = diagram.Pages.GetPage(pageName);

将 Visio 页面复制到另一个 Diagram

Aspose.Diagram for .NET API 允许开发人员将其内容从一个 Visio diagram 复制并添加到另一个。此帮助主题说明了如何完成此任务。

Aspose.Diagram for .NET API 有Diagram表示 Visio 绘图的类。 Diagram 类公开的 Pages 属性支持 Aspose.Diagram.Page 对象的集合。 PageCollection 类公开了可以调用以添加另一个 Page 对象的 Add 方法。

这个例子的工作原理如下:

  1. 创建 Diagram 类的新对象。
  2. 将现有的 Visio diagram 加载到 Diagram 类对象中。
  3. 添加加载的所有母版 Visio diagram
  4. 从加载的 diagram(需要复制)中获取页面对象。
  5. 设置页面对象名称和 ID。
  6. 删除新的 diagram(可选)的空白页。
  7. 调用 PageCollection 类的 Add 方法。
  8. 将新的 diagram 保存在计算机存储中。

复制一个Visio页面编程样例

下面的代码示例显示了如何将 Visio 页面对象复制到另一个 Visio 绘图中。

// For complete examples and data files, please go to https://github.com/aspose-diagram/Aspose.Diagram-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_VisioPages();
// Initialize the new visio diagram
Diagram NewDigram = new Diagram();
// Load source diagram
Diagram dgm = new Diagram(dataDir + "Drawing1.vsdx");
// Add all masters from the source Visio diagram
foreach (Master master in dgm.Masters)
NewDigram.Masters.Add(master);
// Get page object
Aspose.Diagram.Page SrcPage = dgm.Pages.GetPage("Page-1");
// Set name
SrcPage.Name = "new page";
// It calculates max page id
int max = 0;
if (NewDigram.Pages.Count != 0)
max = NewDigram.Pages[0].ID;
for (int i = 1; i < NewDigram.Pages.Count; i++)
{
if (max < NewDigram.Pages[i].ID)
max = NewDigram.Pages[i].ID;
}
// Set max page ID
int MaxPageId = max;
// Set page ID
SrcPage.ID = MaxPageId + 1;
// Add page from the source diagram
NewDigram.Pages.Add(SrcPage);
// Remove first empty page
NewDigram.Pages.Remove(NewDigram.Pages[0]);
// Save diagram
NewDigram.Save(dataDir + "CopyVisioPage_out.vsdx", SaveFileFormat.VSDX);

将 Visio Page 复制到另一个 Page 实例

Page 类的 Copy 方法采用要克隆的页面实例。

C#

 // import diagram

Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");

Page newPage = new Page();

// copy page

newPage.Copy(diagram.Pages.GetPage("Page-1"));

在 Visio 绘图中插入空白页

Aspose.Diagram for .NET可以在 Microsoft Office Visio 绘图中插入一个新的空白页。本示例主题描述了如何执行此操作。

Pages 集合公开的 Add 方法允许开发人员在 Visio diagram 中添加一个新的空白页面。应该分配页面 ID。

插入空白页编程示例

下面的一段代码在 Visio 绘图中插入了一个空白页:

// For complete examples and data files, please go to https://github.com/aspose-diagram/Aspose.Diagram-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_VisioPages();
// Load diagram
Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");
// It calculates max page id
int max = 0;
if (diagram.Pages.Count != 0)
max = diagram.Pages[0].ID;
for (int i = 1; i < diagram.Pages.Count; i++)
{
if (max < diagram.Pages[i].ID)
max = diagram.Pages[i].ID;
}
// Set max page ID
int MaxPageId = max;
// Initialize a new page object
Page newPage = new Page();
// Set name
newPage.Name = "new page";
// Set page ID
newPage.ID = MaxPageId + 1;
// Or try the Page constructor
// Page newPage = new Page(MaxPageId + 1);
// Add a new blank page
diagram.Pages.Add(newPage);
// Save diagram
diagram.Save(dataDir + "InsertBlankPage_out.vsdx", SaveFileFormat.VSDX);

在 Visio 绘图中移动页面位置

Aspose.Diagram for .NET API 可以在Visio绘图中移动页面位置。 Page 类公开的 MoveTo 方法可帮助开发人员移动页面位置。

移动页面位置编程示例

MoveTo成员以目标页面索引为参数,移动页面在Visio图中的位置:

 // import diagram

Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");

Page newPage = new Page(1);

// move page in the diagram

newPage.MoveTo(2);

diagram.Save(dataDir + "Drawing1.vsdx", SaveFileFormat.VSDX);