PlantUML画图使用详解:类图、流程图、时序图等
创作时间:
作者:
@小白创作中心
PlantUML画图使用详解:类图、流程图、时序图等
引用
51CTO
1.
https://blog.51cto.com/u_9849794/13110582
PlantUML 是一个用于绘制各种类型图表的脚本语言,广泛应用于软件开发和系统设计领域。本文将详细介绍如何使用 PlantUML 绘制类图、流程图、时序图、用例图、状态图和组件图,并通过具体的代码案例帮助读者快速掌握其使用方法。
什么是 PlantUML
PlantUML 是一个画图脚本语言,用它可以快速地画出:
1. 类图
案例1:
@startuml
abstract class AbstractList
abstract AbstractCollection
interface List
interface Collection
List <|-- AbstractList
Collection <|-- AbstractCollection
Collection <|- List
AbstractCollection <|- AbstractList
AbstractList <|-- ArrayList
class ArrayList {
Object[] elementData
size()
}
enum TimeUnit {
DAYS
HOURS
MINUTES
}
@enduml
案例2:
@startuml
class Track
class Media

class Trip{
String tripID;
String tracks;
String medias;
}
Trip --> Track
Trip --> Media
interface ITripTrackCollection{
void start();
void stop();
void pause();
void destory();
}
class TripTrackCollection implements ITripTrackCollection{
Vector<LocationInfo> mLocations;
ExtcutorService mVecoterThread;
ScheduledExecutorService mDatabaseThread;
}
class TrackCollectService extends Service implements ITripTrackCollection{
TripTrackCollection TripTrackCollection;
}
TrackCollectService -->TripTrackCollection
@enduml
2. 流程图
案例1:
@startuml
(*) --> "check input"
If "input is verbose" then
--> [Yes] "turn on verbosity"

--> "run command"
else
--> "run command"
Endif
-->(*)
@enduml
案例2:
start
:"步骤1处理";
:"步骤2处理";
if ("条件1判断") then (true)
:条件1成立时执行的动作;
if ("分支条件2判断") then (no)
:"条件2不成立时执行的动作";
else
if ("条件3判断") then (yes)
:"条件3成立时的动作";
else (no)
:"条件3不成立时的动作";
endif
endif
:"顺序步骤3处理";
endif
if ("条件4判断") then (yes)
:"条件4成立的动作";
else
if ("条件5判断") then (yes)
:"条件5成立时的动作";
else (no)
:"条件5不成立时的动作";
endif
endif
stop
@enduml
3. 时序图
案例1:
@startuml
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: another authentication Response
@enduml
案例2:
@startuml
title Android Broadcast procedure
participant Activity #Lime
participant ContextWrapper #Cyan
participant ContextImpl #Cyan
participant ActivityManagerService #Cyan
participant ActivityStackSupervisor #Cyan
participant ActivityStack #Cyan
participant ApplicationThreadProxy #Silver
participant InnerReceiver #Magenta
participant ReceiverDispatcher #Magenta
participant BroadcastReceiver #Magenta
autonumber
Activity -> ContextWrapper : registerReceiver()
ContextWrapper -> ContextImpl : registerReceiver()
ContextImpl -> LoadedApk : getReceiverDispatcher()
LoadedApk -> ActivityManagerProxy : registerReceiver()
ActivityManagerProxy -> ActivityManagerService : registerReceiver()
Activity -> ContextWrapper : sendBroadcast()
ContextWrapper -> ContextImpl : sendBroadcast()
ContextImpl -> ActivityManagerService: broadcastIntent()
ActivityManagerService -> ActivityManagerService : broadcastIntentLocked()
ActivityManagerService -> ActivityManagerService : collectReceiverComponents()
ActivityManagerService -> ActivityManagerService : scheduleBroadcastsLocked()
ActivityManagerService -> ActivityManagerService : processNextBroadcast()
ActivityManagerService -> ActivityManagerService : deliverToRegisteredReceiverLocked()
ActivityManagerService -> ActivityManagerService : performReceiveLocked()
ActivityManagerService -> ApplicationThreadProxy : scheduleRegisteredReceiver()
ApplicationThreadProxy -> InnerReceiver : performReceive()
InnerReceiver -> ReceiverDispatcher : performReceive()
ReceiverDispatcher -> BroadcastReceiver : onReceive()
Activity -> ContextWrapper : sendOrderedBroadcast()
ContextWrapper -> ContextImpl : sendOrderedBroadcast()
ContextImpl -> ActivityManagerService: broadcastIntent()
@enduml
4. 用例图
@startuml
:Main Admin: as Admin
(Use the application) as (Use)
User -> (Start)
User --> (Use)
Admin ---> (Use)
note right of Admin : This is an example.
note right of (Use)
A note can also
be on several lines
end note
note "This note is connected\nto several objects." as N2
(Start) .. N2
N2 .. (Use)
@enduml
5. 状态图
@startuml
scale 350 width
[*] --> NotShooting
state NotShooting {
[*] --> Idle
Idle --> Configuring : EvConfig
Configuring --> Idle : EvConfig
}
state Configuring {
[*] --> NewValueSelection
NewValueSelection --> NewValuePreview : EvNewValue
NewValuePreview --> NewValueSelection : EvNewValueRejected
NewValuePreview --> NewValueSelection : EvNewValueSaved
state NewValuePreview {
State1 -> State2
}
}
@enduml
6. 组件图
案例1:
@startuml
package "Some Group" {
HTTP - [First Component]
[Another Component]
}
package "Other Groups" {
FTP - [Second Component]
[First Component] --> FTP
}
@enduml
案例2:
@startuml
package "组件1" {
["组件1.1"] - ["组件1.2"]
["组件1.2"] -> ["组件2.1"]
}
node "组件2" {
["组件2.1"] - ["组件2.2"]
["组件2.2"] --> [负载均衡服务器]
}
cloud {
[负载均衡服务器] -> [逻辑服务器1]
[负载均衡服务器] -> [逻辑服务器2]
[负载均衡服务器] -> [逻辑服务器3]
}
database "MySql" {
folder "This is my folder" {
[Folder 3]
}
frame "Foo" {
[Frame 4]
}
}
[逻辑服务器1] --> [Folder 3]
[逻辑服务器2] --> [Frame 4]
[逻辑服务器3] --> [Frame 4]
@enduml
热门推荐
切尔诺贝利:核辐射下的生态奇观
羊年头饰成新年热门配饰,寓意吉祥又百搭
武强年画:千年民俗艺术的传承与创新
Excel双击快速跳转功能详解:从基础到进阶的全面指南
Excel工作表命名指南:从基础到高级技巧
桂林亲子游:四季带娃攻略
广州&桂林:最适合带娃的亲子游胜地
带娃出游必备:婴儿推车&安全座椅选购全攻略
寒假亲子游必备:儿童外出饮食安全全攻略
暑假亲子游必知:带娃出行法律指南
春节习俗洗浴简介
treetree的梗(treetree梗解析:热门网络用语揭秘!)
四川广元五大特色美食:从蒸凉面到核桃饼,每一道都是舌尖上的惊喜!
秋冬饮食指南:如何避免胃胀?
跨境游如何为重庆打造国际消费中心城市注入动能?
《熊出没·狂野大陆》观影攻略:购票渠道、适合人群及观影建议
《熊出没·狂野大陆》:春节档必看的角色设计解析
带孩子一起看《熊出没·狂野大陆》,欢乐加倍!
《我的世界》X《熊出没》:狂野大陆联动开启,变身动物大作战!
斗罗论坛蛇年头像设计大赛作品欣赏
马伊琍文章离婚五年:一个事业巅峰,一个陷入低谷
如何判断自己是否近视?有哪些方法可以检测视力问题?
100%资源化利用!煤矸石:从固废到绿植“温床”的蜕变
春节丽江亲子游,如何避开人潮?
体荟四季|正是江南踏春时!这5条油菜花赏花路线,一起享受春天
春节家庭出游健康指南
寒假带娃去哪儿?迪士尼乐园亲子游攻略!
人工智能在舞蹈领域的应用:智能舞蹈编排与表演
双十一买知柏地黄丸,这些价格趋势你得知道!
李子柒最新视频拍摄地揭秘:四川平武白马藏寨的神秘之美