- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在评估 PlantUML 是否可以替代 GraphViz。
它被宣传为“直观”,但老实说,主页上的第一个示例已经令人困惑。
为什么下面会创建两次“Bob”和“Alice”?我在文本中看到 2 个节点,在输出中看到 4 个节点。此外,箭头不在节点之间,而是在节点重复之间的关系之间。
Bob->Alice : hello
这对我来说是零意义。这个例子的含义是什么?还有一个更简单的例子,只有 2 个节点和它们之间的箭头?
最佳答案
我看你中了“手册的第一页不代表工具”的经典陷阱。(1)
除了各种UML图(如您遇到的序列图),PlantUML还支持各种其他软件开发相关格式(如archimate、框图、bpmn、c4、计算机网络图、erd、gantt图表、思维导图、和 wbd ),以及 json 和 yaml 文件的可视化。
其实它甚至可以理解 Graphviz 语法!(2)
由于所有这些,只有在您一些 PlantUML 的基本知识之后,“直觉”才会发生。
所以回到你的问题......你所看到的并不是你想象的那样。
将事物与 Graphviz 联系起来,而不是这样:
digraph d {
Bob -> Alice : hello
}
您实际上看到的是:(3)
@startuml
digraph sequenceDiagramExample {
bobHead [ label="Bob" pos="0,1.5!" shape="record" ];
bobPoint0 [ pos="0,0.75!" shape="point" width="0" ]
bobFoot [ label="Bob" pos="0,0!" shape="record" ];
aliceHead [ label="Alice" pos="1,1.5!" shape="record" ];
alicePoint0 [ pos="1,0.75!" shape="point" width="0" ]
aliceFoot [ label="Alice" pos="1,0!" shape="record" ];
bobHead -> bobPoint0 -> bobFoot [ dir="none" style="dashed" ]
aliceHead -> alicePoint0 -> aliceFoot [ dir="none" style="dashed" ]
bobPoint0 -> alicePoint0 [ label="hello" labelloc="c" style="solid" ]
}
@enduml
只有两个节点和它们之间的箭头的示例是什么样的取决于选择的图形类型...
您必须记住的是,使用 Graphviz,您必须自己将所有含义应用于图表。对于PlantUML,含义由PlantUML 为您提供。您需要做的就是告诉 PlantUML 您的意思。
使用一些基本指针,这很快就会变得直观。您只需要在开始之前知道要绘制什么样的图表...
从下面的示例中您可以看到,PlantUML 是一个非常强大的工具,可以添加到您的软件开发人员工具带中。
我希望这些示例有助于让事情变得更直观,并且您的第一个错误不会阻止您进一步探索 PlantUML!
@startuml
:Alice;
:Bob;
@enduml
@startuml
archimate #Application Alice
archimate #Business Bob
Alice -> Bob
@enduml
@startuml
Alice -|> Bob: Hello
@enduml
@startuml
[Alice] -> [Bob]: Hello
@enduml
@startuml
folder Alice
file Bob
Alice -> Bob: Hello
@enduml
@startuml
ditaa
+-------+ +-----+
| | hello | |
| Alice +------>| Bob |
| | | |
+-------+ +-----+
@enduml
@startgantt
[Alice]->[Bob]
@endgantt
@startjson
{
"Alice": ["Bob"]
}
@endjson
@startmindmap
+ Alice
++ Bob
@endmindmap
@startuml
nwdiag {
network hello {
Alice;
Bob;
}
}
@enduml
@startuml
object Alice
object Bob
Alice -> Bob
@enduml
@startuml
Bob -> Alice : hello
@enduml
@startuml
[*] -> Alice
Alice -> Bob: hello
Bob -> [*]
@enduml
@startuml
concise Hello
0 is Alice
+100 is Bob
@enduml
@startuml
:Alice: -> :Bob: : Hello
@enduml
@startwbs
+ Alice
++ Bob
@endwbs
neato
not dot
中渲染,见 https://stackoverflow.com/a/53470455/153049 关于PlantUML 基本示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65967752/
缩放由 scale 关键字控制。我很好奇是否有可能以某种方式或至少缩放 PlantUML 图的部分:缩放部分图的字体大小。 scale 似乎不能局限于图表的一部分(而且我还没有找到任何表明这是可能的示
据我所知,PlantUML 自动检测给定文档的图类型(序列图、用例图、类图、事件图等)。这似乎工作得相当好,但我有时发现在编辑图表时我会做一些看似微小的更改,突然我的事件图变成了类图(例如)。 我想要
在 PlantUml 中,我有一个像这样的对象: object MyObject { #field1 #field2 } 渲染效果如下: 我希望在具有字段名称的行之间有更多的空间(在本例中为 fi
我有一个类似这样的类结构: @startuml package "A" { ABase <|-- A1 ABase <|-- A2 ABase <|-- A3 } package "B" { BBas
我尝试创建一个图表,其中包含类层次结构以及使用这些类的用例。我今天尝试使用 PlantUML,但不知何故无法混合这两种图表类型。这是我能想到的最简单的文件: @startuml class Foo u
我试图在单列上垂直对齐 PlantUML 组件图的元素。我尝试了“从上到下方向”和“从左到右方向”选项,但没有很好的结果。我发现的唯一方法是将每个元素包装在一个匿名“框架”中并设置“从左到右方向”选项
我试图在单列上垂直对齐 PlantUML 组件图的元素。我尝试了“从上到下方向”和“从左到右方向”选项,但没有很好的结果。我发现的唯一方法是将每个元素包装在一个匿名“框架”中并设置“从左到右方向”选项
如何在类“Person”和“Company”之间的关联“employs”的两端指定角色名称“employer”和“employee”?当然,这与协会名称不同: 最佳答案 @startuml hide
当您想要创建标准 UML 图时,PlantUML 非常强大。 但我目前正在考虑使用 PlantUML 来记录 EIP 路由(如这些图像上的路由: https://www.google.de/searc
我安装了 sphinxcontrib-plantuml 扩展,如果我运行 HTML 构建器,它可以正常工作,例如对于相应的 testmodule.py 文件,使用以下 testmodule.rst 文
我想画一个如下图。 我的源代码是: @startuml start if (c1) then (YES) :A; else (NO) if (C2) then (NO) :A;
我正在尝试绘制一个类图,其中两个类之间的多个关系是用重数定义的。 默认情况下,结果很糟糕: @startuml class Movie { genres: String[] minut
我想将下图更改为具有单个决策节点(三个分支)和单个合并节点。 plantuml 可以制作这样的图表吗?上图源自这段代码: @startuml skinparam ConditionEndStyle d
看,我在 plantuml 中有一个循环 loop etl -> kafka: kafka -> linda: linda --> kafka: kafka --> e
我有多个单序列图。 它们中的大多数具有相同的初始化和终止序列。 可以将其从一个文件复制到另一个文件,但如果可以在单个点声明该部分会好得多。因此,如果发生更改,则无需更改所有图表。 有没有办法做到这一点
我正在评估 PlantUML 是否可以替代 GraphViz。 它被宣传为“直观”,但老实说,主页上的第一个示例已经令人困惑。 为什么下面会创建两次“Bob”和“Alice”?我在文本中看到 2 个节
类图似乎总是线性的 - 无论是水平的,或者,如果我添加 left to right direction , 垂直的。 但是,在许多情况下,布局可以更好地利用屏幕空间。看看这个: 最后一个图可以很容易地
我正在使用 plantUML 泳道来可视化内部流程,但不幸的是,当我想显示已执行和分离的流程时遇到重叠线。 我正在使用这个: @startuml title something |#dee4e8|p1
我正在使用 PlantUML API 生成事件图。 我之前使用过GraphViz,并使用rank参数来定义布局 rank=LR [for left to right] 我试图在 PlantUML 中找
我在here找到了一个很好的事件图但没有源代码。它如下所示: 我尝试用 plantuml 绘制它,下面是我的代码: @startuml skinparam linetype ortho (*) -do
我是一名优秀的程序员,十分优秀!