frans
frans

Reputation: 9798

PlantUML: control arrow shape and direction

With PlantUML I've created a little state chart for my documentation:

@startuml

state Powered {
    [*]      -d->    Starting
    Powered  -r->    Starting : Some error
    Starting -d->    Operational
}
[*]     -d->   Powered  : Power On
Powered -u->   [*]      : Power Off
Powered -d->   Powered  : Reset

@enduml

(btw: PlantUML is a very nice tool to create graphical output from a textual description embedded embedded markup documents like asciidoc or reStructuredText)

This is what the given state diagram is rendered to: enter image description here

As you can see the chart is drawn a bit sloppy

As the documentation describes you have some influence on the arrow direction by writing -left-> or -l-> for short rather than just -->.

Is there a way to to influence the way how and where arrows are drawn? I'd really like to have only horizontal or vertical straight lines being drawn.

Upvotes: 11

Views: 35759

Answers (2)

gebi
gebi

Reputation: 763

To answer the original question for future readers:

In order to have only horizontal or vertical straight lines drawn, you can use skinparam linetype ortho.

In order to make all lines straight (but not necessarily horizontal or vertical) you can use skinparam linetype polyline.

(source)

Upvotes: 27

PaulH
PaulH

Reputation: 3049

PlantUML has not been designed to provide nice straight arrows when many directions are imposed. Using default layout provides cleanest and most readable result to me.

Here is an example with the same meaning, but without layout issues:

@startuml

state Powered {
  [*] --> Starting
  Starting --> Operational
}
[*] --> Powered : Power On
Powered --> [*] : Power Off
Powered --> Powered : Reset
Powered --> Powered : Fatal Error

@enduml

enter image description here

EDIT: I also changed your Powered --> Starting : Fatal Error transition to : Powered --> Powered : Fatal Error, which better expresses that from any state within Powered, a Fatal Error event will restart at the Starting substate.

Alternatively the two statements:

Powered --> Powered : Reset
Powered --> Powered : Fatal Error

can be merged in:

Powered --> Powered : Reset, Fatal Error

see OMG UML 2.5 format specification section 14.2.4.9 page 329

[<trigger> [‘,’ <trigger>]* [‘[‘ <guard>’]’] [‘/’ <behavior-expression>]]

Upvotes: 6

Related Questions