Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joelparkerhenderson/plantuml-examples
PlantUML eaxmples for UML, ERD, wireframes, mind maps, JSON, YAML, WBS, ASCII art, Gantt charts, C4 models, and more
https://github.com/joelparkerhenderson/plantuml-examples
Last synced: 6 days ago
JSON representation
PlantUML eaxmples for UML, ERD, wireframes, mind maps, JSON, YAML, WBS, ASCII art, Gantt charts, C4 models, and more
- Host: GitHub
- URL: https://github.com/joelparkerhenderson/plantuml-examples
- Owner: joelparkerhenderson
- License: other
- Created: 2018-11-26T02:43:47.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2025-01-20T04:53:52.000Z (about 1 month ago)
- Last Synced: 2025-02-07T10:11:17.973Z (13 days ago)
- Language: Shell
- Homepage:
- Size: 1.98 MB
- Stars: 207
- Watchers: 6
- Forks: 31
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# PlantUML examples
[PlantUML](http://plantuml.com) is a software tool that uses text formatting to create graphic diagrams. This page introduces PlantUML by showing examples with diagrams and source code, for UML, ERD, wireframes, mind maps, JSON, YAML, WBS, ASCII art, Gantt charts, C4 models, and more.
## Sequence diagram
data:image/s3,"s3://crabby-images/9d4e5/9d4e589c488c9c14fd46f2f3cbfaf297c60383a9" alt="Sequence diagram"
View Source
@startuml
skinparam monochrome true
Alpha -> Bravo
Bravo -> Alpha
@enduml## Sequence diagram with steps and divider
data:image/s3,"s3://crabby-images/9dfc3/9dfc32d84457a5862ff3af6f77806cc51bf55dc1" alt="Sequence diagram extras"
View Source
@startuml
skinparam monochrome true
Alpha -> Bravo: Step 1
Bravo -> Charlie: Step 2
== My Divider ==
Charlie -> Bravo: Step 3
Bravo -> Alpha: Step 4
@enduml## Sequence diagram with participant shapes
data:image/s3,"s3://crabby-images/9da44/9da4476551c9ea0539f962a9956d7e1f19560a35" alt="Sequence diagram extras"
View Source
@startuml
skinparam monochrome true
participant Participant as Foo
actor Actor as Foo1
boundary Boundary as Foo2
control Control as Foo3
entity Entity as Foo4
database Database as Foo5
collections Collections as Foo6
queue Queue as Foo7
Foo -> Foo1 : To actor
Foo -> Foo2 : To boundary
Foo -> Foo3 : To control
Foo -> Foo4 : To entity
Foo -> Foo5 : To database
Foo -> Foo6 : To collections
Foo -> Foo7: To queue
@enduml## Usecase diagram
data:image/s3,"s3://crabby-images/a81a9/a81a961713397a0466b7e59c7422888e03699bef" alt="Usecase diagram"
View Source
@startuml
skinparam monochrome true
left to right direction
User1 --> (Story1)
(Story1) --> (Story2)
(Story2) --> (Story3)
@enduml## Object diagram
data:image/s3,"s3://crabby-images/1c703/1c703e79eee96b88a28b2eb940fa2d9c96aa5536" alt="Object diagram"
View Source
@startuml
skinparam monochrome trueobject Object1 {
Alpha
Bravo
}object Object2 {
Charlie
Delta
}object Object3 {
Echo
Foxtrot
}Object1 <|-- Object2
Object1 <|-- Object3
@enduml## Class diagram
data:image/s3,"s3://crabby-images/81806/81806eb65cd0ec8bf458d3b67e0a2149c26738a1" alt="Class diagram"
View Source
@startuml
skinparam monochrome true' If you want to hide the "C" circle, then uncomment this line:
' hide circleclass Class1 {
{field} Alpha
{method} Bravo
}class Class2 {
{field} Charlie
{method} Delta
}class Class3 {
{field} Echo
{method} Foxtrot
}Class1 <|--o Class2
Class1 <|--* Class3
@enduml## Entity relationship diagram (ERD)
data:image/s3,"s3://crabby-images/fa804/fa804d31fd9c96457fa54d03a996640110af5e90" alt="Entity relationship diagram"
View Source
@startuml
skinparam monochrome true
skinparam linetype ortho' If you want to hide the "E" circle, then uncomment this line:
' hide circleentity Entity1 {
Alpha
Bravo
}entity Entity2 {
Charlie
Delta
}entity Entity3 {
Echo
Foxtrot
}Entity1 }o-down-o{ Entity2
Entity1 }o-down-o{ Entity3
@enduml## Package styles
data:image/s3,"s3://crabby-images/a3ca2/a3ca214b92165f58c0019be1e49416b7e46bde95" alt="Package styles"
View Source
@startuml
package "Demo Node" <> {
object Object1
}
package "Demo Rectangle" <> {
object Object2
}
package "Demo Folder" <> {
object Object3
}
package "Demo Frame" <> {
object Object4
}
package "Demo Cloud" <> {
object Object5
}
package "Demo Database" <> {
object Object6
}
@enduml## Activity diagram
data:image/s3,"s3://crabby-images/d714e/d714ef5e6d3ea32a9dd13f874b851f15c15401bf" alt="Activity diagram"
View Source
@startuml
skinparam monochrome true
start
-> Starting;
:Activity 1;
if (Question) then (yes)
:Option 1;
else (no)
:Option 2;
endif
:Activity 2;
-> Stopping;
stop
@enduml## Component diagram of items
data:image/s3,"s3://crabby-images/3ce7c/3ce7c7d86127d88bcde2e27cd1e4b1239ece2761" alt="Component diagram"
View Source
@startuml
skinparam monochrome true
component "Component"
interface "Interface"
database "Database"
cloud "Cloud"
node "Node"
package "Package"
@enduml## State diagram
data:image/s3,"s3://crabby-images/0622b/0622bc3949aaec14587bb3f5cea4f9d525daed12" alt="State diagram"
View Source
@startuml
skinparam monochrome true
[*] --> State1 : Start
State1 -> State2 : Change1
State2 -> State3 : Change2
State3 --> [*] : Stop
State1 : Description 1
State2 : Description 2
State3 : Description 3
@enduml## Deployment diagram items
data:image/s3,"s3://crabby-images/86fcf/86fcf3981f68a0df8c9340e4f7646f56fc5852cc" alt="Deployment diagram"
View Source
@startuml
skinparam monochrome true
action action
actor actor
agent agent
artifact artifact
boundary boundary
card card
circle circle
cloud cloud
collections collections
component component
control control
database database
entity entity
file file
folder folder
frame frame
hexagon hexagon
interface interface
label label
node node
package package
person person
queue queue
rectangle rectangle
stack stack
storage storage
usecase usecase
@enduml## Timing diagram
data:image/s3,"s3://crabby-images/58f5f/58f5fd3369440da069dcfb2df21914afe3ef96f1" alt="Timing diagram"
View Source
@startuml
skinparam monochrome true
concise "My Timeline" as T
@T
0 is Alpha
+100 is Bravo
+100 is Charlie
@50 <-> @+100 : My Note
@enduml## Diagrams through ASCII art (DITAA)
data:image/s3,"s3://crabby-images/fec59/fec59696ea07bb675894f696ac910519fd8e024b" alt="Diagrams through ASCII art"
View Source
@startditaa
+--------+ +-------+ +-------+
| +---+ ditaa +--> | |
| Text | +-------+ |diagram|
|Document| |!magic!| | |
| {d}| | | | |
+---+----+ +-------+ +-------+
: ^
| Lots of work |
+-------------------------+
@endditaa## Wireframe
data:image/s3,"s3://crabby-images/25f39/25f395b6267ca568fd86f89c9809d2c11650b94c" alt="Wireframe"
View Source
@startsalt
{
Hello world
[Button]
() Radio 1
(X) Radio 2
[] Checkbox 1
[X] Checkbox 2
"Enter text here "
^This is a droplist^
}
@endsalt## Gantt chart
data:image/s3,"s3://crabby-images/12bfc/12bfc09a0c6144ebe67f71781be6808a45106604" alt="Gantt chart"
View Source
@startgantt
skinparam monochrome true
[Task1] on {Alice} requires 8 days
then [Task2] on {Bob} requires 4 days and is 50% complete
then [Task3] on {Carol} lasts 2 days and is 25% complete
@endgantt## Mind map
data:image/s3,"s3://crabby-images/db9b7/db9b7aa7f9225f7548a18536129e7c419896ef1b" alt="Mind map"
View Source
@startmindmap
+ C
++ D
++ E
-- A
-- B
@endmindmap## JSON data
data:image/s3,"s3://crabby-images/9d465/9d46523bae2420e873e795d1e38b07c260606f24" alt="JSON data"
View Source
@startjson
{
"fruit":"Apple",
"size":"Large",
"color": ["Red", "Green"]
}
@endjson## YAML data
data:image/s3,"s3://crabby-images/a0c23/a0c23b0e4daa869fb161cf752bc2ee45baaa6189" alt="YAML data"
View Source
@startyaml
fruit: Apple
size: Large
color:
- Red
- Green
@endyaml## Network diagram
data:image/s3,"s3://crabby-images/e5cfa/e5cfad2e66d218a5a5a1645e1769490424e5bbf2" alt="Network diagram"
View Source
@startuml
nwdiag {
network dmz {
address = "210.x.x.x/24"web01 [address = "210.x.x.1"];
web02 [address = "210.x.x.2"];
}
}
@enduml## Work breakdown structure (WBS)
data:image/s3,"s3://crabby-images/2db84/2db84d44776d4ece456709f07ddfd0f97bb6766e" alt="Work breakdown structure"
View Source
@startwbs
* Top
** A
*** A1
*** A2
** B
*** B1
*** B2
@endwbs## OpenIconic
data:image/s3,"s3://crabby-images/e1058/e105802346915037b503d3d72f9d4696b916b6f1" alt="OpenIconic"
View Source
@startuml
title: <&heart> Demo <&heart>
@endumlOpenIconic provides open source icons. OpenIconic is now built-in to PlantUML.
## Font Awesome
data:image/s3,"s3://crabby-images/80c1d/80c1d08f77b19cf2ff8ed396cd0ce78960a6b2d6" alt="Font Awesome"
View Source
@startuml
skinparam monochrome true
!include
rectangle "<$star>"
@enduml## Procedure
data:image/s3,"s3://crabby-images/12ae8/12ae850057d362a6e5dda9664bf8b8022791ba03" alt="Procedure diagram"
View Source
@startuml!procedure $demo($name, $headline, $description)
card $name as "\n$headline\n\n$description\n"
!endprocedure$demo(MyCard, "Hello World", "This is a demonstration")
@enduml
## Procedure layout
data:image/s3,"s3://crabby-images/b4288/b42881d33ed78e7165141e0ed92db02614ece811" alt="Procedure layout diagram"
View Source
@startuml
skinparam monochrome true
skinparam defaultTextAlignment center!procedure $layout($shape, $name, $openiconic, $headline, $description)
$shape $name as "\n\n<&$openiconic>\n$headline\n\n$description\n\n"
!endprocedure$layout(card, MyCard, heart, "Hello World", "This is a demonstration")
@enduml
This shows how to create your own procedure to create a custom layout with a shape, object name, OpenIconic icon, headline that uses big size text, and a description that uses normal size text.
## Area diagram
data:image/s3,"s3://crabby-images/58c33/58c3313d026255ecb4b89c5aa9f69ce2c819193e" alt="Area diagram"
The area diagram is an example deployment diagram that shows a bunch of areas and how they interrelate. This example is useful for seeing a real-world diagram, that uses boxes, arrows, Font Awesome icons, multi-line text, Unicode padding, font sizes, and more.
View Source
@startuml
skinparam monochrome true
skinparam defaultTextAlignment center' icons
!include
!include
!include
!include
!include
!include
!include
!include
!include
!include
!include' Pipeline objects
stack ""Example\n\nexample\nexample\nexample"" as StackLeft
card "<$cubes>\nExample\n\nexample, example, example \n\n" as Pipeline1
queue "<$check_circle>\nExample\n\nexample, example, example\n\n" as Pipeline2
card "<$cloud>\nExample\n\nexample, example, example\n\n" as Pipeline3
stack "Example\n\nexample\nexample\nexample" as StackRight' Pipeline flow
StackLeft -r-> Pipeline1 : "Example"
Pipeline1 -r-> Pipeline2 : "Example"
Pipeline2 -r-> Pipeline3 : "Example"
Pipeline3 -r-> StackRight : "Example"' Left side
interface "Example" as InterfaceLeft
InterfaceLeft -u-> StackLeft' Right side
interface "Example" as InterfaceRight
InterfaceRight -u-> StackRight' Actor 1
actor "Actor 1" as Actor1
usecase "\n<$file_image_o>\nExample\n\nexample\nexample\nexample\n\n" as UseCase1
Actor1 -d-> UseCase1
UseCase1 -d-> Pipeline1' Actor 2
actor "Actor 2" as Actor2
usecase "\n<$file_code_o>\nExample\n\nexample\nexample\nexample\n\n" as UseCase2
Actor2 -d-> UseCase2
UseCase2 -d-> Pipeline1' Actor 3
actor "Actor 3" as Actor3
usecase "\n<$exchange>\nExample\n\nexample\nexample\nexample\n\n" as UseCase3
Actor3 -d-> UseCase3
UseCase3 -d-> Pipeline3' Actor 4
actor "Actor 4" as Actor4
usecase "\n<$share_alt_square>\nExample\n\nexample\nexample\nexample\n\n" as UseCase4
Actor4 -d-> UseCase4
UseCase4 -d-> Pipeline3' Diamond upper area
cloud "\n<$heart>\nExample\n\nexample, example, example\n\n" as DiamondUpper
DiamondUpper -d-> Pipeline1
DiamondUpper -d-> Pipeline2
DiamondUpper -d-> Pipeline3' Diamond lower area
database "\n<$gear>\nExample\n\nexample, example, example\n\n" as DiamondLower
DiamondLower -u-> Pipeline1
DiamondLower -u-> Pipeline2
DiamondLower -u-> Pipeline3' Hinting
UseCase1 -[hidden]r- UseCase2
UseCase2 -[hidden]r- DiamondUpper
DiamondUpper -[hidden]r- UseCase3
UseCase3 -[hidden]r- UseCase4' Pipeline 1 controls
control "Example\n\nexample\nexample\nexample" as Pipeline1Control1
control "Example\n\nexample\nexample\nexample" as Pipeline1Control2
Pipeline1Control1 -u-> Pipeline1
Pipeline1Control2 -u-> Pipeline1' Pipeline 3 controls
control "Example\n\nexample\nexample\nexample" as Pipeline3Control1
control "Example\n\nexample\nexample\nexample" as Pipeline3Control2
Pipeline3Control1 -u-> Pipeline3
Pipeline3Control2 -u-> Pipeline3@enduml
## Standard library
data:image/s3,"s3://crabby-images/79115/791153c6fbe80165eeb46b15b996fc71d0db86c6" alt="Standard library"
View Source
@startuml
stdlib
@endumlYou can list standard library folders by using the special diagram "stdlib".
## OpenIconic list
data:image/s3,"s3://crabby-images/01f5a/01f5a53492d9846f13c6e877702fb6d65a7d1cb7" alt="OpenIconic"
View Source
@startuml
listopeniconic
@endumlYou can list all the OpenIconic icon names and images by using the special diagram "listopeniconic".
## C4 model
[C4 Model](https://c4model.com/) focuses diagrams on four areas: Context, Containers, Components, Code.
[C4-PlantUML](https://github.com/plantuml-stdlib/C4-PlantUML/)
### C4 model: context diagram
data:image/s3,"s3://crabby-images/3c0a9/3c0a93d1182b40091a515d30b671868650c4b28a" alt="C4 model context diagram"
[View Source](doc/c4-model/c4-model-context-diagram/c4-model-context-diagram.plantuml)
### C4 model: container diagram
data:image/s3,"s3://crabby-images/94adf/94adf10ac6c04dd4f29d3f9adc9b1efaa30cbe80" alt="C4 model container diagram"
[View Source](doc/c4-model/c4-model-container-diagram/c4-model-container-diagram.plantuml)
### C4 model: component diagram
data:image/s3,"s3://crabby-images/4bebb/4bebbd5db07ff157db724623b1198192491ed0f9" alt="C4 model component diagram"
[View Source](doc/c4-model/c4-model-component-diagram/c4-model-component-diagram.plantuml)
### C4 model: code diagram
data:image/s3,"s3://crabby-images/a1c9c/a1c9cb947d6e6cbf05b0d199e7de49a31e5f94f8" alt="C4 model code diagram"
[View Source](doc/c4-model/c4-model-code-diagram/c4-model-code-diagram.plantuml)
## ArchiMate
[ArchiMate](https://pubs.opengroup.org/architecture/archimate32-doc/) focuses on enterprise architecture modeling language.
### ArchiMate modeling
data:image/s3,"s3://crabby-images/fa4e8/fa4e86a405db2c98a59941033e1ee86fee31f781" alt="ArchiMate modeling"
View Source
@startuml
skinparam monochrome true
!include
sprite $stakeholder jar:archimate/motivation-stakeholder
sprite $capability jar:archimate/strategy-capability
sprite $product jar:archimate/business-producttitle ArchiMate Modeling
Motivation_Stakeholder(Stakeholder, "Stakeholder")
Strategy_Capability(Capability, "Capability")
Business_Product(Product, "Product")
Rel_Assignment(Stakeholder, Capability, "Can Do")
Rel_Assignment(Capability, Product, "By Using")legend left
Legend
====
<$stakeholder> Stakeholder
<$capability> Capability
<$product> Product
endlegend@enduml
### ArchiMate grouping
data:image/s3,"s3://crabby-images/88fc3/88fc30dcdc4c27294dd4671f4f43e2a4b530d238" alt="ArchiMate grouping"
View Source
@startuml
!include
sprite $stakeholder jar:archimate/motivation-stakeholder
sprite $capability jar:archimate/strategy-capability
sprite $product jar:archimate/business-producttitle ArchiMate Modeling Layers
Grouping(Stakeholders, "Stakeholders") {
Motivation_Stakeholder(Stakeholder1, "Stakeholder 1")
Motivation_Stakeholder(Stakeholder2, "Stakeholder 2")
}Grouping(Drivers, "Drivers") {
Motivation_Driver(Driver1, "Driver 1")
Motivation_Driver(Driver2, "Driver 2")
}Grouping(Assessments, "Assessments") {
Motivation_Assessment(Assessment1, "Assessment 1")
Motivation_Assessment(Assessment2, "Assessment 2")
}Grouping(Goals, "Goals") {
Motivation_Goal(Goal1, "Goal 1")
Motivation_Goal(Goal2, "Goal 2")
}Grouping(Outcomes, "Outcomes") {
Motivation_Outcome(Outcome1, "Outcome 1")
Motivation_Outcome(Outcome2, "Outcome 2")
}Grouping(Requirements, "Requirements") {
Motivation_Requirement(Requirement1, "Requirement 1")
Motivation_Requirement(Requirement2, "Requirement 2")
}@enduml
### ArchiMate elements
data:image/s3,"s3://crabby-images/38b0f/38b0f274a3cbf8280add97f3a63e4fd4e46fd891" alt="ArchiMate elements"
View Source
@startuml
!includetitle ArchiMate Elements
' Motivation Elements
Motivation_Stakeholder(Stakeholder, "Stakeholder")
Motivation_Driver(Driver, "Driver")
Motivation_Assessment(Motivation_Assessment, "Assessment")
Motivation_Goal(Goal, "Goal")
Motivation_Outcome(Outcome, "Outcome")
Motivation_Principle(Principle, "Principle")
Motivation_Requirement(Requirement, "Requirement")
Motivation_Constraint(Constraint, "Constraint")
Motivation_Meaning(Meaning, "Meaning")
Motivation_Value(Value, "Value")' Strategy Elements
Strategy_Resource(Resource, "Resource")
Strategy_Capability(Capability, "Capability")
Strategy_CourseOfAction(CourseOfAction, "Course Of Action")
Strategy_ValueStream(ValueStream, "Strategy Value Stream")' Business Elements
Business_Actor(Business_Actor, "Business Actor")
Business_Role(Business_Role, "Business Role")
Business_Collaboration(Business_Collaboration, "Business Collaboration")
Business_Interface(Business_Interface, "Business Interface")
Business_Process(Business_Process, "Business Process")
Business_Function(Business_Function, "Business Function")
Business_Interaction(Business_Interaction, "Business Interaction")
Business_Event(Business_Event, "Business Event")
Business_Service(Business_Service, "Business Service")
Business_Object(Business_Object, "Business Object")
Business_Contract(Business_Contract, "Contract")
Business_Representation(Business_Representation, "Representation")
Business_Product(Business_Product, "Product")
Business_Location(Business_Location, "Business Location")' Application Elements
Application_Component(Application_Component, "Application Component")
Application_Collaboration(Application_Collaboration, "Application Collaboration")
Application_Interface(Application_Interface, "Application Interface")
Application_Function(Application_Function, "Application Function")
Application_Interaction(Application_Interaction, "Application Interaction")
Application_Process(Application_Process, "Application Process")
Application_Event(Application_Event, "Application Event")
Application_Service(Application_Service, "Application Service")
Application_DataObject(Application_DataObject, "Data Object")' Technology Elements
Technology_Node(Node, "Node")
Technology_Device(Device, "Device")
Technology_SystemSoftware(SystemSoftware, "System Software")
Technology_Collaboration(Technology_Collaboration, "Technology Collaboration")
Technology_Interface(Technology_Interface, "Technology Interface")
Technology_Path(Path, "Path")
Technology_CommunicationNetwork(CommunicationNetwork, "Communication Network")
Technology_Function(Technology_Function, "Technology Function")
Technology_Process(Technology_Process, "Technology Process")
Technology_Interaction(Technology_Interaction, "Technology Interaction")
Technology_Event(Technology_Event, "Technology Event")
Technology_Service(Technology_Service, "Technology Service")
Technology_Artifact(Artifact, "Artifact")'Physical Elements
Physical_Equipment(Equipment, "Equipment")
Physical_Facility(Facility, "Facility")
Physical_DistributionNetwork(DistributionNetwork, "Distribution Network")
Physical_Material(Material, "Material")'Implementation Elements
Implementation_WorkPackage(WorkPackage, "Work Package")
Implementation_Deliverable(Deliverable, "Deliverable")
Implementation_Event(Implementation_Event, "Implementation Event")
Implementation_Plateau(Plateau, "Plateau")
Implementation_Gap(Gap, "Gap")'Other Elements
Grouping(Grouping, "Grouping") {
Junction_Or(Junction_Or, "or")
Junction_And(Junction_And, "and")
}
Group(Group, "Group") {
Other_Location(Other_Location, "Location")
}@enduml
### ArchiMate sprites
data:image/s3,"s3://crabby-images/86a1a/86a1ac98de946d9174c180b2c8e57a47c5434b42" alt="ArchiMate sprites"
View Source
@startuml
listsprite
@enduml