創建組織結構圖 C#

組織結構圖 是表示組織中員工層次結構的可視化圖表。它包含他們的角色、職責、職位等和其他相關信息。您可以通過幾個 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 樣式的組織結構圖

您可以按照以下步驟創建 CompactTree 樣式的組織結構圖:

  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" });
// 定義一個哈希表以將字符串名稱映射到長形 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 圖

您可能需要創建可能遵循不同模板的不同類型的組織結構圖。在這裡,您將學習如何在 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" });
// 定義一個哈希表以將字符串名稱映射到長形 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 或 Flowchart 樣式圖表。此外,您可以訪問 文檔 部分,查看不同章節中涵蓋的其他功能。如有任何疑問,請隨時通過論壇與我們聯繫。

也可以看看

在 C# 中將 VSDM 轉換為 PDF