【PlantUML系列】流程图(四)

目录

目录

一、基础用法

[1.1 开始和结束](#1.1 开始和结束)

[1.2 操作步骤](#1.2 操作步骤)

[1.3 条件判断](#1.3 条件判断)

[1.4 并行处理](#1.4 并行处理)

[1.5 循环](#1.5 循环)

[1.6 分区](#1.6 分区)

[1.7 泳道](#1.7 泳道)

一、基础用法

1.1 开始和结束

开始一般使用**++start++关键字;结束一般使用++stop/end++** 关键字。基础用法包括:

  • start ... stop

  • start ... end

    @startuml
    start
    :执行操作A;
    stop
    @enduml

1.2 操作步骤

语法为++:operation++ ,其中 operation 是你为该步骤定义的名称。例如:

@startuml
:开始;
:执行操作A;
:执行操作B;
:结束;
@enduml

1.3 条件判断

使用PlantUML语法通常使用++if-else++关键字。通常由三种语法:

  • if (...) then (...) ... [else (...) ...] endif
  • if (...) is (...) then ... [else (...) ...] endif
  • if (...) equals (...) then ... [else (...) ...] endif

例如:

@startuml
:开始;
:执行操作A;
:判断是否满足条件;
if (满足条件) then (是)
  :执行操作B;
else (否)
  :执行操作C;
endif

if (条件) is (是) then
   :执行操作D;
else
   :执行操作E;
endif

if (条件) equals (是) then
   :执行操作F;
else
   :执行操作G;
endif
:结束;
@enduml

多分支判断使用++elseif++关键字,其中包含水平模式、垂直模式;

  • 水平模式

    @startuml
    start
    if (condition A) then (yes)
    :Text 1;
    elseif (condition B) then (yes)
    :Text 2;
    stop
    (no) elseif (condition C) then (yes)
    :Text 3;
    (no) elseif (condition D) then (yes)
    :Text 4;
    else (nothing)
    :Text else;
    endif
    stop
    @enduml

  • 垂直模式 :使用**!pragma useVerticalIf on**进入垂直模式。

    ​@startuml
    start
    !pragma useVerticalIf on
    if (condition A) then (yes)
    :Text 1;
    elseif (condition B) then (yes)
    :Text 2;
    stop
    (no) elseif (condition C) then (yes)
    :Text 3;
    (no) elseif (condition D) then (yes)
    :Text 4;
    else (nothing)
    :Text else;
    endif
    stop
    @enduml

1.4 并行处理

并行处理可以用 forkjoin 来表示,fork 表示分支开始,merge 表示分支合并。

  • fork ... fork again ... end fork

  • fork ... fork again ... end merge

    @startuml
    start
    fork
    :action 1;
    fork again
    :action 2;
    end fork

    fork
    :action 3;
    fork again
    :action 4;
    end merge
    stop
    @enduml

1.5 循环

循环包括无条件循环(Repeat loop)、有条件循环(While loop),典型的写法包括:

  • repeat ... repeat while (...) is (...) not (...)
  • repeat ... backward ... repeat while (...) is (...) -> (...)
  • while (...) end while

repeat案例:

@startuml
start

repeat
  :read data;
  :generate diagrams;
repeat while (more data?) is (yes) not (no)

repeat
  :read data;
  :generate diagrams;
backward :write data;
repeat while (more data?) is (yes)
-> no;
  :next action;

while (check filesize ?) is (not empty)
  :read file;
  backward:log;
endwhile (empty)
:close file;

stop
@enduml

1.6 分区

在PlantUML中,Partition 是用来定义分区的关键字,它允许你将多个活动组合在一起。

@startuml
start
partition Initialization {
    :read config file;
    :init internal variable;
}
partition Running {
    :wait for user interaction;
    :print information;
}

stop
@enduml

1.7 泳道

在PlantUML中,使用++|Swimlane1|++来表示泳道,例如:

@startuml
|Swimlane1|
start
:foo1;
|#AntiqueWhite|Swimlane2|
:foo2;
:foo3;
|Swimlane1|
:foo4;
|Swimlane2|
:foo5;
stop
@enduml

参考资料:New Activity Diagram Beta syntax and features

相关推荐
万维——组态4 天前
BY组态-低代码web可视化组件
前端·物联网·低代码·编辑器·流程图·组态
小沈同学呀6 天前
Java UML 类图绘制解析:结构与工具类型详解
java·开发语言·uml·plantuml
刘鑫磊up6 天前
画流程图 代码生成流程图 流程图自动运行
流程图
Le0v1n10 天前
mermaid大全(语法、流程图、时序图、甘特图、饼图、用户旅行图、类图)
流程图·甘特图
困困的果果头11 天前
【Vue + Antv X6】可拖拽流程图组件
javascript·vue.js·流程图
龙哥·三年风水14 天前
接口项目架构流程图-thinkphp6-rabbitmq
rabbitmq·php·流程图
fpcc15 天前
设计心得——流程图和数据流图绘制
流程图·软件构建
小参宿15 天前
高效绘图不再受限!本地搭建Excalidraw与随时随地高效绘制流程图教程
运维·服务器·windows·docker·centos·流程图
小破孩呦15 天前
Vue3中使用 Vue Flow 流程图方法
前端·vue.js·流程图
敏编程15 天前
Mermaid 使用教程之流程图 - 从入门到精通
流程图·mermaid