创建组织结构图 C#

ORG 图表 是表示组织中员工层次结构的可视化图表。它包含他们的角色、职责、职位等和其他相关信息。您可以通过几个 API 调用创建不同类型的组织结构图,而无需手动绘制形状或连接。本文介绍如何在 C# 中创建 ORG 图表。

ORG Chart Maker – C# API 安装

Aspose.Diagram for .NET API 支持处理不同类型的图表。只需从 New Releases 部分下载其 DLL 文件或使用以下 NuGet 安装命令即可访问 API:

PM> Install-Package Aspose.Diagram

在 C# 中以 CompactTree 样式创建 ORG 图表

您可以按照以下步骤创建 CompactTree 样式的 ORG 图表:

  1. 从任何现有图表、模板或模板加载母版。
  2. 定义值以构建层次结构。
  3. 在节点之间添加形状和连接。
  4. 保存输出图。

下面的代码片段解释了如何在 C# 中创建 ORG 图表:

// 从任何现有图表、模板或模板加载母版
string visioStencil = "Basic Shapes.vss";
const string rectangleMaster = "Rectangle";
const string connectorMaster = "Dynamic connector";
const int pageNumber = 0;
const double width = 1;
const double height = 1;
double pinX = 4.25;
double pinY = 9.5;
// 定义值以构建层次结构
List<string> listPos = new List<string>(new string[] { "0", "0:0", "0:1", "0:2", "0:3", "0:4", "0:5", "0:6", "0:0:0", "0:0:1", "0:3:0", "0:3:1", "0:3:2", "0:6:0", "0:6:1" });
// 定义一个 Hashtable 以将字符串名称映射到长形状 id
Hashtable shapeIdMap = new Hashtable();
// 创建新图表
Diagram diagram = new Diagram(visioStencil);
diagram.Pages[pageNumber].PageSheet.PageProps.PageWidth.Value = 11;
foreach (string orgnode in listPos)
{
    // 添加一个新的矩形形状
    long rectangleId = diagram.AddShape(pinX++, pinY++, width, height, rectangleMaster, pageNumber);
    // 设置新形状的属性
    Shape shape = diagram.Pages[pageNumber].Shapes.GetShape(rectangleId);
    shape.Text.Value.Add(new Txt(orgnode));
    shape.Name = orgnode;
    shapeIdMap.Add(orgnode, rectangleId);
}
// 在节点之间创建连接
foreach (string orgName in listPos)
{
    int lastColon = orgName.LastIndexOf(':');
    if(lastColon > 0)
    {
        string parendName = orgName.Substring(0, lastColon);
        long shapeId = (long)shapeIdMap[orgName];
        long parentId = (long)shapeIdMap[parendName];
        Shape connector1 = new Shape();
        long connecter1Id = diagram.AddShape(connector1, connectorMaster, pageNumber);
        diagram.Pages[pageNumber].ConnectShapesViaConnector(parentId, ConnectionPointPlace.Right,
            shapeId, ConnectionPointPlace.Left, connecter1Id);
    }
}

//自动布局 CompactTree 图表
LayoutOptions compactTreeOptions = new LayoutOptions
{
    LayoutStyle = LayoutStyle.CompactTree,
    Direction = LayoutDirection.DownThenRight,
    EnlargePage = false
};

diagram.Pages[pageNumber].Layout(compactTreeOptions);

// 保存图表
diagram.Save("CompactTreeChart_out.vsdx", SaveFileFormat.VSDX);

以下屏幕截图显示了使用上述代码片段创建的输出 ORG 图表:

创建组织结构图 C#

在 C# 中以流程图样式创建 ORG 图表

您可能需要创建可能遵循不同模板的不同类型的 ORG 图表。在这里,您将学习如何在 C# 中以编程方式创建流程图样式的 ORG 图表:

  1. 从任何现有图表、模板或模板加载母版。
  2. 添加组织节点和连接器。
  3. 设置布局并保存输出图。

以下示例代码显示了如何在 C# 中以流程图样式创建 ORG 图表:

// 从任何现有图表、模板或模板加载母版
string visioStencil = "Basic Shapes.vss";
const string rectangleMaster = "Rectangle";
const string connectorMaster = "Dynamic connector";
const int pageNumber = 0;
const double width = 1;
const double height = 1;
double pinX = 4.25;
double pinY = 9.5;
// 定义值以构建层次结构
List<string> listPos = new List<string>(new string[] { "0", "0:0", "0:1", "0:2", "0:3", "0:4", "0:5", "0:6", "0:0:0", "0:0:1", "0:3:0", "0:3:1", "0:3:2", "0:6:0", "0:6:1" });
// 定义一个 Hashtable 以将字符串名称映射到长形状 id
Hashtable shapeIdMap = new Hashtable();
// 创建新图表
Diagram diagram = new Diagram(visioStencil);
foreach (string orgnode in listPos)
{
    // 添加一个新的矩形形状
    long rectangleId = diagram.AddShape(pinX++, pinY++, width, height, rectangleMaster, pageNumber);
    // 设置新形状的属性
    Shape shape = diagram.Pages[pageNumber].Shapes.GetShape(rectangleId);
    shape.Text.Value.Add(new Txt(orgnode));
    shape.Name = orgnode;
    shapeIdMap.Add(orgnode, rectangleId);
}
// 在节点之间创建连接
foreach (string orgName in listPos)
{
    int lastColon = orgName.LastIndexOf(':');
    if(lastColon > 0)
    {
        string parendName = orgName.Substring(0, lastColon);
        long shapeId = (long)shapeIdMap[orgName];
        long parentId = (long)shapeIdMap[parendName];
        Shape connector1 = new Shape();
        long connecter1Id = diagram.AddShape(connector1, connectorMaster, pageNumber);
        diagram.Pages[pageNumber].ConnectShapesViaConnector(parentId, ConnectionPointPlace.Right,
            shapeId, ConnectionPointPlace.Left, connecter1Id);
    }
}

//自动布局流程图
LayoutOptions flowChartOptions = new LayoutOptions
{
    LayoutStyle = LayoutStyle.FlowChart,
    Direction = LayoutDirection.TopToBottom,
    EnlargePage = true
};

diagram.Pages[pageNumber].Layout(flowChartOptions);

// 保存图表
diagram.Save("FlowChart_out.vsdx", SaveFileFormat.VSDX);

获得免费临时许可证

您可以申请 免费临时许可证 来评估 API 的全部功能。

结论

在本文中,您了解了如何在 C# 中以编程方式创建 ORG 图表。您可以从模板创建图表,并根据您的要求创建 CompactTree 或流程图样式图表。此外,您可以访问 documentation 部分以查看不同章节和部分所涵盖的其他功能。如有任何疑问,请随时通过 论坛 与我们联系。

也可以看看

在C#中将VSDM转换为PDF