demo_doc/puml/superhero/usecase-ex.svg

801 lines
18 KiB
XML
Raw Normal View History

2021-06-25 21:37:59 +08:00
<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentScriptType="application/ecmascript" contentStyleType="text/css" height="441.6667px" preserveAspectRatio="none" style="width:423px;height:441px;background:#00000000;" version="1.1" viewBox="0 0 423 441" width="423.9583px" zoomAndPan="magnify"><defs><linearGradient id="g1kx10g66sqza90" x1="50%" x2="50%" y1="0%" y2="100%"><stop offset="0%" stop-color="#3E4A56"/><stop offset="100%" stop-color="#4E5D6C"/></linearGradient></defs><g><rect fill="url(#g1kx10g66sqza90)" height="46.1528" rx="4.1667" ry="4.1667" style="stroke:#717D89;stroke-width:1.0416666666666667;" width="411.4583" x="2.0833" y="2.0833"/><text fill="#DF691A" font-family="Verdana" font-size="20.8333" lengthAdjust="spacing" textLength="384.375" x="15.625" y="33.4452">Usecase Diagram - superhero theme</text><!--MD5=[111002b242a260edbcaabc3e471064d0]
cluster checkout--><rect fill="#3E4A56" height="317.7083" rx="4.1667" ry="4.1667" style="stroke:#E58748;stroke-width:2.0833333333333335;" width="154.1667" x="152.6042" y="58.6528"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" font-weight="bold" lengthAdjust="spacing" textLength="61.4583" x="198.9583" y="78.5116">checkout</text><ellipse cx="229.8483" cy="231.4481" fill="#DF691A" rx="60.5774" ry="21.2328" style="stroke:#E58748;stroke-width:2.0833333333333335;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="58.3333" x="200.6816" y="234.336">checkout</text><ellipse cx="229.6325" cy="125.1981" fill="#DF691A" rx="59.8409" ry="21.2328" style="stroke:#E58748;stroke-width:2.0833333333333335;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="57.2917" x="200.9867" y="128.086">payment</text><ellipse cx="229.8419" cy="337.6981" fill="#DF691A" rx="39.2169" ry="21.2328" style="stroke:#E58748;stroke-width:2.0833333333333335;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="28.125" x="215.7794" y="340.586">help</text><!--MD5=[92848cbaf65985a669855153c5362c37]
entity customer--><ellipse cx="68.2292" cy="196.1528" fill="#DF691A" rx="8.3333" ry="8.3333" style="stroke:#E58748;stroke-width:1.5625;"/><path d="M68.2292,204.4861 L68.2292,232.6111 M54.6875,212.8194 L81.7708,212.8194 M68.2292,232.6111 L54.6875,248.2361 M68.2292,232.6111 L81.7708,248.2361 " fill="none" style="stroke:#E58748;stroke-width:1.5625;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="60.4167" x="38.0208" y="268.6157">customer</text><!--MD5=[ebeabf449828f4e0b33bbb47961e644b]
entity clerk--><ellipse cx="376.0417" cy="196.1528" fill="#DF691A" rx="8.3333" ry="8.3333" style="stroke:#E58748;stroke-width:1.5625;"/><path d="M376.0417,204.4861 L376.0417,232.6111 M362.5,212.8194 L389.5833,212.8194 M376.0417,232.6111 L362.5,248.2361 M376.0417,232.6111 L389.5833,248.2361 " fill="none" style="stroke:#E58748;stroke-width:1.5625;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="30.2083" x="360.9375" y="268.6157">clerk</text><!--MD5=[852381a7bb976b86080137fb6d718ea9]
link customer to checkout--><path d="M103.8542,231.5694 C122.8958,231.5694 147.0625,231.5694 169.0417,231.5694 " fill="none" id="customer-checkout" style="stroke:#DF691A;stroke-width:3.125;"/><!--MD5=[3ad5c6d5c608bfd6b87dc9c07c40a15f]
link checkout to payment--><path d="M229.6875,210.0694 C229.6875,193.3611 229.6875,170.1007 229.6875,152.1632 " fill="none" id="checkout-to-payment" style="stroke:#DF691A;stroke-width:3.125;stroke-dasharray:7.0,7.0;"/><polygon fill="#DF691A" points="229.6875,146.7882,225.5208,156.1632,229.6875,151.9965,233.8542,156.1632,229.6875,146.7882" style="stroke:#DF691A;stroke-width:3.125;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="45.8333" x="190.1042" y="183.7199">include</text><!--MD5=[739e7928149c8fe27c2b5850560351c7]
link help to checkout--><path d="M229.6875,316.3194 C229.6875,299.6111 229.6875,276.3507 229.6875,258.4132 " fill="none" id="help-to-checkout" style="stroke:#DF691A;stroke-width:3.125;stroke-dasharray:7.0,7.0;"/><polygon fill="#DF691A" points="229.6875,253.0382,225.5208,262.4132,229.6875,258.2465,233.8542,262.4132,229.6875,253.0382" style="stroke:#DF691A;stroke-width:3.125;"/><text fill="#FFFFFF" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="53.125" x="186.4583" y="289.9699">extends</text><!--MD5=[b4c4ee8f2d94c159d2b9e04bd372cbe0]
link checkout to clerk--><path d="M290.2396,231.5694 C313.5313,231.5694 338.625,231.5694 355.4167,231.5694 " fill="none" id="checkout-clerk" style="stroke:#DF691A;stroke-width:3.125;"/><rect fill="#4E5D6C" height="36.025" rx="5.2083" ry="5.2083" style="stroke:#717D89;stroke-width:1.0416666666666667;" width="135.4167" x="140.1042" y="389.9028"/><text fill="#ABB6C2" font-family="Verdana" font-size="12.5" lengthAdjust="spacing" textLength="112.5" x="151.5625" y="412.8866">This is my legend</text><!--MD5=[74f1a4592d9d97cb3ef01cb5564c7e56]
@startuml
!$THEME = "superhero"
!if %not(%variable_exists("$BGCOLOR"))
!$BGCOLOR = "transparent"
!endif
skinparam backgroundColor $BGCOLOR
skinparam useBetaStyle false
!$BLUE = "#DF691A"
!$INDIGO = "#6610f2"
!$PURPLE = "#6f42c1"
!$PINK = "#e83e8c"
!$RED = "#d9534f"
!$ORANGE = "#f0ad4e"
!$YELLOW = "#f0ad4e"
!$GREEN = "#5cb85c"
!$TEAL = "#20c997"
!$CYAN = "#5bc0de"
!$WHITE = "#FFF"
!$GRAY_LIGHT = "#222"
!$GRAY = "#868e96"
!$PRIMARY = "#DF691A"
!$SECONDARY = "#4E5D6C"
!$SUCCESS = "#5cb85c"
!$INFO = "#5bc0de"
!$WARNING = "#f0ad4e"
!$DANGER = "#d9534f"
!$LIGHT = "#abb6c2"
!$DARK = "#4E5D6C"
!$FGCOLOR = $WHITE
!$PRIMARY_DARK = "#e58748"
!$PRIMARY_LIGHT = "#b25415"
!$PRIMARY_TEXT = $WHITE
!$SECONDARY_DARK = "#717d89"
!$SECONDARY_LIGHT = "#3e4a56"
!$SECONDARY_TEXT = $WHITE
!$INFO_DARK = "#7ccde5"
!$INFO_LIGHT = "#499AB2"
!$INFO_TEXT = $WHITE
!$SUCCESS_DARK = "#4a934a"
!$SUCCESS_LIGHT = "#5F8F00"
!$SUCCESS_TEXT = $WHITE
!$WARNING_DARK = "#f3bd71"
!$WARNING_LIGHT = "#C08A3E"
!$WARNING_TEXT = $WHITE
!$DANGER_DARK = "#e17572"
!$DANGER_LIGHT = "#AE423F"
!$DANGER_TEXT = $WHITE
!$DARK_DARK = "#717d89"
!$DARK_LIGHT = "#3e4a56"
!$LIGHT_DARK = "#bcc5ce"
!$LIGHT_LIGHT = "#89929b"
!procedure $success($msg)
<font color=$SUCCESS><b>$msg
!endprocedure
!procedure $failure($msg)
<font color=$DANGER><b>$msg
!endprocedure
!procedure $warning($msg)
<font color=$WARNING><b>$msg
!endprocedure
!procedure $primary_scheme()
FontColor $PRIMARY_TEXT
BorderColor $PRIMARY_DARK
BackgroundColor $PRIMARY
!endprocedure
skinparam defaultFontName "Verdana"
skinparam defaultFontSize 12
skinparam dpi 100
skinparam shadowing false
skinparam roundcorner 8
skinparam ParticipantPadding 40
skinparam BoxPadding 40
skinparam Padding 5
skinparam ArrowColor $DARK
skinparam stereotype {
CBackgroundColor $SECONDARY_LIGHT
CBorderColor $SECONDARY_DARK
ABackgroundColor $SUCCESS_LIGHT
ABorderColor $SUCCESS_DARK
IBackgroundColor $DANGER_LIGHT
IBorderColor $DANGER_DARK
EBackgroundColor $WARNING_LIGHT
EBorderColor $WARNING_DARK
NBackgroundColor $INFO_LIGHT
NBorderColor $INFO_DARK
}
skinparam title {
FontColor $PRIMARY
BorderColor $SECONDARY_DARK
FontSize 20
BorderRoundCorner 8
BorderThickness 1
BackgroundColor $SECONDARY_LIGHT-$SECONDARY
}
skinparam legend {
BackgroundColor $SECONDARY
BorderColor $SECONDARY_DARK
FontColor $LIGHT
}
!startsub swimlane
skinparam swimlane {
BorderColor $INFO
BorderThickness 2
TitleBackgroundColor $SECONDARY_LIGHT-$SECONDARY
TitleFontColor $PRIMARY
}
!endsub
!startsub activity
skinparam activity {
$primary_scheme()
BarColor $SUCCESS
StartColor $INFO
EndColor $INFO
DiamondBackgroundColor $SECONDARY_LIGHT
DiamondBorderColor $SECONDARY_DARK
DiamondFontColor $SECONDARY_TEXT
}
!endsub
!startsub participant
skinparam participant {
$primary_scheme()
BorderThickness 2
}
!endsub
!startsub actor
skinparam actor {
$primary_scheme()
}
!endsub
!startsub arrow
skinparam arrow {
Thickness 3
Color $PRIMARY
FontColor $FGCOLOR
}
!endsub
!startsub sequence
skinparam sequence {
BorderColor $PRIMARY
TitleFontColor $PRIMARY
BackgroundColor $BGCOLOR
StartColor $PRIMARY
EndColor $PRIMARY
BoxBackgroundColor $BGCOLOR
BoxBorderColor $DARK
BoxFontColor $DARk
LifeLineBorderColor $SECONDARY
LifeLineBorderThickness 2
LifeLineBackgroundColor $SECONDARY_DARK
GroupBackgroundColor $SECONDARY
GroupBodyBackgroundColor $BGCOLOR
GroupBorderColor $DARK
GroupFontColor $DARK
GroupHeaderFontColor $INFO
GroupHeaderBackgroundColor $BGCOLOR
DividerBackgroundColor $DARK
DividerBorderColor $DARK
DividerBorderThickness 2
DividerFontColor $LIGHT
ReferenceBackgroundColor $BGCOLOR
ReferenceBorderColor $DARK
ReferenceFontColor $DARK
ReferenceHeaderFontColor $INFO
ReferenceHeaderBackgroundColor $SECONDARY
}
!endsub
!startsub partition
skinparam partition {
BorderColor $PRIMARY
FontColor $PRIMARY
BackgroundColor $BGCOLOR
}
!endsub
!startsub collections
skinparam collections {
$primary_scheme()
}
!endsub
!startsub control
skinparam control {
$primary_scheme()
}
!endsub
!startsub entity
skinparam entity {
$primary_scheme()
}
!endsub
!startsub boundary
skinparam boundary {
$primary_scheme()
}
!endsub
!startsub agent
skinparam agent {
BackgroundColor $WARNING
BorderColor $WARNING_LIGHT
FontColor $DARK
}
!endsub
!startsub note
skinparam note {
BorderThickness 1
BackgroundColor $INFO
BorderColor $INFO_DARK
FontColor $WHITE
}
!endsub
!startsub artifact
skinparam artifact {
BackgroundColor $DARK
BorderColor $DARK_DARK
FontColor $LIGHT
}
!endsub
!startsub component
skinparam component {
$primary_scheme()
}
!endsub
!startsub interface
skinparam interface {
BackgroundColor $DANGER_DARK
BorderColor $DANGER
FontColor $DARK
}
!endsub
!startsub storage
skinparam storage {
BackgroundColor $WARNING
BorderColor $WARNING_DARK
FontColor $WARNING_TEXT
}
!endsub
!startsub node
skinparam node {
BackgroundColor $SECONDARY
BorderColor $LIGHT
FontColor $LIGHT
}
!endsub
!startsub cloud
skinparam cloud {
BackgroundColor transparent
BorderColor $LIGHT
FontColor $DARK
}
!endsub
!startsub database
skinparam database {
$primary_scheme()
}
!endsub
!startsub class
skinparam class {
$primary_scheme()
HeaderBackgroundColor $PRIMARY_LIGHT
StereotypeFontColor $DARK
BorderThickness 1
AttributeFontColor $DARK
AttributeFontSize 11
}
!endsub
!startsub object
skinparam object {
$primary_scheme()
StereotypeFontColor $DARK
BorderThickness 1
AttributeFontColor $SECONDARY_TEXT
AttributeFontSize 11
}
!endsub
!startsub usecase
skinparam usecase {
$primary_scheme()
BorderThickness 2
StereotypeFontColor $PRIMARY
}
!endsub
!startsub rectangle
skinparam rectangle {
$primary_scheme()
BackgroundColor $SECONDARY_LIGHT
BorderThickness 2
StereotypeFontColor $PRIMARY
}
!endsub
!startsub package
skinparam package {
BackgroundColor $SECONDARY
BorderColor $PRIMARY
FontColor $PRIMARY
BorderThickness 2
}
!endsub
!startsub folder
skinparam folder {
BackgroundColor $SECONDARY_LIGHT
BorderColor $WARNING
FontColor $WARNING
BorderThickness 2
}
!endsub
!startsub frame
skinparam frame {
BackgroundColor $SECONDARY_LIGHT
BorderColor $INFO
FontColor $INFO
BorderThickness 2
}
!endsub
!startsub state
skinparam state {
$primary_scheme()
StartColor $INFO
EndColor $INFO
AttributeFontColor $SECONDARY_TEXT
AttributeFontSize 11
}
!endsub
!startsub queue
skinparam queue {
$primary_scheme()
}
!endsub
!startsub card
skinparam card {
BackgroundColor $INFO
BorderColor $INFO_DARK
FontColor $INFO_TEXT
}
!endsub
!startsub file
skinparam file {
BackgroundColor $SECONDARY_DARK
BorderColor $LIGHT
FontColor $LIGHT
}
!endsub
!startsub stack
skinparam stack {
$primary_scheme()
}
!endsub
!if %variable_exists("$THEME")
title Usecase Diagram - $THEME theme
!else
title Usecase Diagram
!endif
legend
This is my legend
endlegend
'skinparam BackgroundColor transparent
left to right direction
actor customer
actor clerk
rectangle checkout {
customer - - (checkout)
(checkout) .> (payment) : include
(help) .> (checkout) : extends
(checkout) - - clerk
}
@enduml
@startuml
skinparam backgroundColor transparent
skinparam useBetaStyle false
skinparam defaultFontName "Verdana"
skinparam defaultFontSize 12
skinparam dpi 100
skinparam shadowing false
skinparam roundcorner 8
skinparam ParticipantPadding 40
skinparam BoxPadding 40
skinparam Padding 5
skinparam ArrowColor #4E5D6C
skinparam stereotype {
CBackgroundColor #3e4a56
CBorderColor #717d89
ABackgroundColor #5F8F00
ABorderColor #4a934a
IBackgroundColor #AE423F
IBorderColor #e17572
EBackgroundColor #C08A3E
EBorderColor #f3bd71
NBackgroundColor #499AB2
NBorderColor #7ccde5
}
skinparam title {
FontColor #DF691A
BorderColor #717d89
FontSize 20
BorderRoundCorner 8
BorderThickness 1
BackgroundColor #3e4a56-#4E5D6C
}
skinparam legend {
BackgroundColor #4E5D6C
BorderColor #717d89
FontColor #abb6c2
}
skinparam swimlane {
BorderColor #5bc0de
BorderThickness 2
TitleBackgroundColor #3e4a56-#4E5D6C
TitleFontColor #DF691A
}
skinparam activity {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
BarColor #5cb85c
StartColor #5bc0de
EndColor #5bc0de
DiamondBackgroundColor #3e4a56
DiamondBorderColor #717d89
DiamondFontColor #FFF
}
skinparam participant {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
BorderThickness 2
}
skinparam actor {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam arrow {
Thickness 3
Color #DF691A
FontColor #FFF
}
skinparam sequence {
BorderColor #DF691A
TitleFontColor #DF691A
BackgroundColor transparent
StartColor #DF691A
EndColor #DF691A
BoxBackgroundColor transparent
BoxBorderColor #4E5D6C
BoxFontColor $DARk
LifeLineBorderColor #4E5D6C
LifeLineBorderThickness 2
LifeLineBackgroundColor #717d89
GroupBackgroundColor #4E5D6C
GroupBodyBackgroundColor transparent
GroupBorderColor #4E5D6C
GroupFontColor #4E5D6C
GroupHeaderFontColor #5bc0de
GroupHeaderBackgroundColor transparent
DividerBackgroundColor #4E5D6C
DividerBorderColor #4E5D6C
DividerBorderThickness 2
DividerFontColor #abb6c2
ReferenceBackgroundColor transparent
ReferenceBorderColor #4E5D6C
ReferenceFontColor #4E5D6C
ReferenceHeaderFontColor #5bc0de
ReferenceHeaderBackgroundColor #4E5D6C
}
skinparam partition {
BorderColor #DF691A
FontColor #DF691A
BackgroundColor transparent
}
skinparam collections {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam control {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam entity {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam boundary {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam agent {
BackgroundColor #f0ad4e
BorderColor #C08A3E
FontColor #4E5D6C
}
skinparam note {
BorderThickness 1
BackgroundColor #5bc0de
BorderColor #7ccde5
FontColor #FFF
}
skinparam artifact {
BackgroundColor #4E5D6C
BorderColor #717d89
FontColor #abb6c2
}
skinparam component {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam interface {
BackgroundColor #e17572
BorderColor #d9534f
FontColor #4E5D6C
}
skinparam storage {
BackgroundColor #f0ad4e
BorderColor #f3bd71
FontColor #FFF
}
skinparam node {
BackgroundColor #4E5D6C
BorderColor #abb6c2
FontColor #abb6c2
}
skinparam cloud {
BackgroundColor transparent
BorderColor #abb6c2
FontColor #4E5D6C
}
skinparam database {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam class {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
HeaderBackgroundColor #b25415
StereotypeFontColor #4E5D6C
BorderThickness 1
AttributeFontColor #4E5D6C
AttributeFontSize 11
}
skinparam object {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
StereotypeFontColor #4E5D6C
BorderThickness 1
AttributeFontColor #FFF
AttributeFontSize 11
}
skinparam usecase {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
BorderThickness 2
StereotypeFontColor #DF691A
}
skinparam rectangle {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
BackgroundColor #3e4a56
BorderThickness 2
StereotypeFontColor #DF691A
}
skinparam package {
BackgroundColor #4E5D6C
BorderColor #DF691A
FontColor #DF691A
BorderThickness 2
}
skinparam folder {
BackgroundColor #3e4a56
BorderColor #f0ad4e
FontColor #f0ad4e
BorderThickness 2
}
skinparam frame {
BackgroundColor #3e4a56
BorderColor #5bc0de
FontColor #5bc0de
BorderThickness 2
}
skinparam state {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
StartColor #5bc0de
EndColor #5bc0de
AttributeFontColor #FFF
AttributeFontSize 11
}
skinparam queue {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
skinparam card {
BackgroundColor #5bc0de
BorderColor #7ccde5
FontColor #FFF
}
skinparam file {
BackgroundColor #717d89
BorderColor #abb6c2
FontColor #abb6c2
}
skinparam stack {
FontColor #FFF
BorderColor #e58748
BackgroundColor #DF691A
}
title Usecase Diagram - superhero theme
legend
This is my legend
endlegend
left to right direction
actor customer
actor clerk
rectangle checkout {
customer - - (checkout)
(checkout) .> (payment) : include
(help) .> (checkout) : extends
(checkout) - - clerk
}
@enduml
PlantUML version 1.2021.01(Mon Feb 01 23:55:08 PST 2021)
(GPL source distribution)
Java Runtime: OpenJDK Runtime Environment
JVM: OpenJDK 64-Bit Server VM
Default Encoding: UTF-8
Language: en
Country: US
--></g></svg>