C++Qt开发流程图效果,包括保存、加载功能

目录

声明

学习Qt示例 diagramscene ,在此基础上做功能的扩展。

开发环境

Vs 2022 + Qt5.9.1

实现功能

1、拖入单个流程图;

2、切换为连线功能,进行流程图之间的连线;

3、可以自由拖动流程图;

4、ctrl + 滚轮 进行放大缩小;

5、"新建" 菜单按钮进行新建;

6、"保存" 菜单按钮进行流程图设计的保存,保存为json文件;

7、"加载" 菜单按钮进行文件的读取显示。

主界面


保存文件

保存文件的格式为json。

刚刚保存的流程图设计内容,每一个流程图匹配一个uuid进行标识

json 复制代码
{
    "Diagram": [
        {
            "arrow": [
                "{5e1bfb25-9753-4bf8-82ac-864fdcb61111}",
                "{03dda701-4f00-48e1-9c2b-9fab267e2945}"
            ],
            "name": "x1",
            "uuid": "{2ca09772-db26-4d22-90e9-a9c06279c0a9}",
            "x": 1470,
            "y": 1073
        },
        {
            "arrow": [
                "{2ca09772-db26-4d22-90e9-a9c06279c0a9}"
            ],
            "name": "Item 2",
            "uuid": "{03dda701-4f00-48e1-9c2b-9fab267e2945}",
            "x": 1412,
            "y": 898
        },
        {
            "arrow": [
                "{917c0116-7a1a-482e-8055-a83550dbd2cf}",
                "{2ca09772-db26-4d22-90e9-a9c06279c0a9}"
            ],
            "name": "Item 3",
            "uuid": "{5e1bfb25-9753-4bf8-82ac-864fdcb61111}",
            "x": 1065,
            "y": 1096
        },
        {
            "arrow": [
                "{5e1bfb25-9753-4bf8-82ac-864fdcb61111}",
                "{03dda701-4f00-48e1-9c2b-9fab267e2945}"
            ],
            "name": "Item 2",
            "uuid": "{917c0116-7a1a-482e-8055-a83550dbd2cf}",
            "x": 918,
            "y": 848
        }
    ]
}

视频


可扩展的功能

1、目前只有矩形框,可以实现椭圆、圆形、菱形等;

2、对流程图做修改后不会提示是否保存;

3、可以自定义设置背景图等;

4、可以自定义填充颜色、箭头颜色等效果;

相关推荐
郝学胜-神的一滴25 分钟前
使用C++11改进工厂方法模式:支持运行时配置的增强实现
开发语言·c++·程序人生·设计模式
Korloa1 小时前
表达式(CSP-J 2021-Expr)题目详解
c语言·开发语言·数据结构·c++·算法·蓝桥杯·个人开发
yodala1 小时前
C++中的内存管理(二)
开发语言·c++
艾莉丝努力练剑2 小时前
【C语言16天强化训练】从基础入门到进阶:Day 5
c语言·c++·学习·算法
阿࿆杰࿆4 小时前
solon-flow基于bpmnJs的流程设计器
vue·流程图·react
重启的码农5 小时前
llama.cpp 分布式推理介绍(5) RPC 通信协议
c++·人工智能·神经网络
liulilittle5 小时前
UTF-8 编解码可视化分析
c++·字符串·unicode·string·字符·char·utf8
重启的码农5 小时前
llama.cpp 分布式推理介绍(6) 张量序列化 (rpc_tensor)
c++·人工智能·神经网络
让我们一起加油好吗6 小时前
【C++】模板(进阶)
c++·visualstudio·模板·泛型编程
雨落倾城夏未凉6 小时前
2.如何创建自己的类
c++·后端