Создать блок-схему на C# .NET

Блок-схемы созданы или предназначены для представления различных рабочих процессов. В определенных ситуациях вам может потребоваться создать блок-схемы для управления различными ситуациями. В этой статье рассказывается, как программно создать блок-схему на C#.

Установите C# API для создания блок-схемы

Вы можете создавать блок-схемы с помощью API Aspose.Diagram for .NET. Он поддерживает создание и редактирование файлов Visio в форматах VSD, VSDX и других поддерживаемых форматах. Вы можете легко установить API, загрузив файл DLL из раздела Новые выпуски или используя диспетчер пакетов NuGet с помощью следующей команды установки:

PM> Install-Package Aspose.Diagram

Программно создать блок-схему на C#

Вы можете составить блок-схему различных процессов в соответствии с вашими требованиями. Чтобы создать блок-схему, выполните следующие действия:

  1. Во-первых, создайте схему для создания диаграммы.
  2. Загрузите мастер для добавления фигур с помощью класса Diagram.
  3. Добавление фигур и соединителей из схемы.
  4. Установите макет для блок-схемы.
  5. Наконец, запишите выходной файл с блок-схемой в формате VSDX, используя метод Сохранить.

В следующем фрагменте кода показано, как программно создать блок-схему на C#:

class Program
{
    static void Main(string[] args)
    {
        // схема для диаграммы, которая будет создана
        Input diagramObject = new Input()
        {
            InputRectangles = new List<InputRectangle>() {
                    new InputRectangle() {
                        Name = "A",
                        Text = "Manager"
                    },
                    new InputRectangle() {
                        Name = "B",
                        Text = "Team Leader"
                    },
                    new InputRectangle() {
                        Name = "C",
                        Text = "Team Member"
                    },
                    new InputRectangle() {
                        Name = "D",
                        Text = "Team Member"
                    },
                    new InputRectangle() {
                        Name = "E",
                        Text = "Team Member"
                    }
                },
            InputConnectors = new List<InputConnector>() {
                    new InputConnector() {
                        OriginShapeName = "A",
                        DestinationShapeName = "B"
                    },
                    new InputConnector() {
                        OriginShapeName = "B",
                        DestinationShapeName = "C"
                    },
                    new InputConnector() {
                        OriginShapeName = "B",
                        DestinationShapeName = "D"
                    },
                    new InputConnector() {
                        OriginShapeName = "B",
                        DestinationShapeName = "E"
                    }
                }
        };

        Diagram diagram = new Diagram("BasicShapes.vss");
        Page page = diagram.Pages[0];

        Dictionary<string, long> shapeNames = new Dictionary<string, long>();

        //Добавление фигур и соединителей из схемы
        foreach (var rectangle in diagramObject.InputRectangles)
        {
            Shape shape = new Shape();
            var shapeId = diagram.AddShape(shape, @"Rectangle", 0);
            shapeNames.Add(rectangle.Name, shapeId);
            shape = page.Shapes.GetShape(shapeId);
            shape.Text.Value.Add(new Txt(rectangle.Text));
        }


        foreach (var connector in diagramObject.InputConnectors)
        {
            var connectorId = diagram.AddShape(new Shape(), "Dynamic connector", 0);
            page.ConnectShapesViaConnector(shapeNames[connector.OriginShapeName],
                                            ConnectionPointPlace.Right,
                                            shapeNames[connector.DestinationShapeName],
                                            ConnectionPointPlace.Left,
                                            connectorId);
        }


        LayoutOptions layoutOptions = new LayoutOptions()
        {
            LayoutStyle = LayoutStyle.FlowChart,
            Direction = LayoutDirection.LeftToRight,
            SpaceShapes = 5,
            EnlargePage = true
        };

        diagram.Layout(layoutOptions);

        page.PageSheet.PrintProps.PrintPageOrientation.Value = PrintPageOrientationValue.Landscape;

        DiagramSaveOptions saveOptions = new DiagramSaveOptions()
        {
            SaveFormat = SaveFileFormat.Vsdx,
            AutoFitPageToDrawingContent = true
        };

        diagram.Save("output.vsdx", saveOptions);
    }
}

public class Input
{
    public System.Collections.Generic.List<InputRectangle> InputRectangles { get; set; }
    public System.Collections.Generic.List<InputConnector> InputConnectors { get; set; }
}

public class InputRectangle
{
    public string Name { get; set; }
    public string Text { get; set; }
}

public class InputConnector
{
    public string OriginShapeName { get; set; }
    public string DestinationShapeName { get; set; }
}

Скачать пример проекта

Вы можете скачать пример проекта вместе с входными и выходными файлами.

Предварительный просмотр блок-схемы примера вывода

Сделать блок-схему на C#

Получить бесплатную лицензию API

Вы можете оценить все возможности API без каких-либо ограничений, запросив бесплатную временную лицензию.

Вывод

В этой статье вы узнали, как программно создавать блок-схемы с помощью C#. Вы можете создавать различные формы, такие как решение, процесс, а также различные макеты, такие как слева направо или справа налево и т. д. Кроме того, вы можете посетить API документацию, чтобы узнать больше о функциях API. Пожалуйста, не стесняйтесь обращаться к нам на форуме.

Смотрите также