A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 易之规 初级黑马   /  2018-11-23 10:50  /  915 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 易之规 于 2018-11-23 10:55 编辑

@startuml

' Split into 4 pages
page 1x1
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black

package java #006600{
    package com.my.proj  #DDDDDD{
        package service{
              class BaseService{
                     fields
                     ==
                     methods()
              }
             class ExtendService{
                     fields
                     ==
                    serviceMethods
              }
             enum serviceMethods{
                    save()
                    remove()
                    modify()
                    query()
                    statistics()
             }
             ExtendService-|> BaseService: extends
        }
        package dao{
              class BaseDao{
                    fields
                    ==
                    methods()
              }
               class ExtendDao{
                    fields
                    ==
                    daoMethods
                }
             enum daoMethods{
                     insert()
                     delete()
                     update()
                     select()
                     count()
             }
             ExtendDao-|> BaseDao : extends
        }
        package domain{}
        package constant{}
        package util{
            class ContextFactory{
            }
        }


        package web {

            package servlet{
                class BaseServlet{
                    fields
                    ==
                    methods()
                }
                class ExtendServlet{
                    fields
                    ==
                    servletMethods
                }
                enum servletMethods{
                    add()
                    delete()
                    edit()
                    find()
                    calculate()
                }
                ExtendServlet -|> BaseServlet : extends
            }
        }
        servletMethods -> serviceMethods : ""
        serviceMethods ->daoMethods : ""
    }
    enum POJO{
        VO
        DTO
        DO
        BO
        QO
    }
}

package resources #000066{

    File  applicationContext.xml{
    }

}

Class File
@enduml3 类图
3.1 类之间的关系
类之间的关系通过下面的符号定义:
继承(extension) <|--
合成(composition) *--
聚合(aggregation) o--
使用”..” 来代替”--” 可以得到点线.
在这些规则下,也可以绘制下列图形
@startuml
Class01 <|-- Class02
Class03 *-- Class04
Class05 o-- Class06
Class07 .. Class08
Class09 -- Class10
@enduml
@startuml
Class11 <|.. Class12
Class13 --> Class14
Class15 ..> Class16
Class17 ..|> Class18
Class19 <--* Class20
@enduml
@startuml
Class21 #-- Class22
Class23 x-- Class24
Class25 }-- Class26
Class27 +-- Class28
Class29 ^-- Class30
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 29 of 125
3.2 关系上的标识3 类图
3.2 关系上的标识
在关系之间使用标签来说明时, 使用”:” 后接标签文字。
对元素的说明,你可以在每一边使用"" 来说明.
@startuml
Class01 "1" *-- "many" Class02 : contains
Class03 o-- Class04 : aggregation
Class05 --> "1" Class06
@enduml
在标签的开始或结束位置添加< 或> 以表明是哪个对象作用到哪个对象上。
@startuml
class Car
Driver - Car : drives >
Car *- Wheel : have 4 >
Car -- Person : < owns
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 30 of 125
3.3 添加方法3 类图
3.3 添加方法
为了声明域或者方法,你可以使用后接域名或方法名。
系统检查是否有括号来判断是方法还是域。
@startuml
Object <|-- ArrayList
Object : equals()
ArrayList : Object[] elementData
ArrayList : size()
@enduml
也可以使用{ 把域或者方法括起来
注意,这种语法对于类型/名字的顺序是非常灵活的。
@startuml
class Dummy {
String data
void methods()
}
class Flight {
flightNumber : Integer
departureTime : Date
}
@enduml
You can use {field} and {method} modifiers to override default behaviour of the parser about fields
and methods.
@startuml
class Dummy {
{field} A field (despite parentheses)
{method} Some method
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 31 of 125
3.4 定义可访问性3 类图
3.4 定义可访问性
一旦你定义了域或者方法,你可以定义相应条目的可访问性质。
- private
# protected
̃ package private
+ public
@startuml
class Dummy {
-field1
#field2
~method1()
+method2()
}
@enduml
你可以采用以下命令停用这些特性skinparam classAttributeIconSize 0 :
@startuml
skinparam classAttributeIconSize 0
class Dummy {
-field1
#field2
~method1()
+method2()
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 32 of 125
3.5 抽象与静态3 类图
3.5 抽象与静态
通过修饰符static 或者abstract,可以定义静态或者抽象的方法或者属性。
这些修饰符可以写在行的开始或者结束。也可以使用classifier 这个修饰符来代替static.
@startuml
class Dummy {
{static} String id
{abstract} void methods()
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 33 of 125
3.6 高级类体3 类图
3.6 高级类体
PlantUML 默认自动将方法和属性重新分组,你可以自己定义分隔符来重排方法和属性,下面的分隔符
都是可用的:-- .. == __.
还可以在分隔符中添加标题:
@startuml
class Foo1 {
You can use
several lines
..
as you want
and group
==
things together.
__
You can have as many groups
as you want
--
End of class
}
class User {
.. Simple Getter ..
+ getName()
+ getAddress()
.. Some setter ..
+ setName()
__ private data __
int age
-- encrypted --
String password
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 34 of 125
3.7 备注和模板3 类图
3.7 备注和模板
模板通过类关键字(”«” 和”»”) 来定义
你可以使用note left of , note right of , note top of , note bottom of 这些关键字来添加备注。
你还可以在类的声明末尾使用note left, note right,note top, note bottom 来添加备注。
此外,单独用note 这个关键字也是可以的,使用.. 符号可以作出一条连接它与其它对象的虚线。
@startuml
class Object << general >>
Object <|--- ArrayList
note top of Object : In java , every class\nextends this one.
note "This is a floating note" as N1
note "This note is connected\nto several objects." as N2
Object .. N2
N2 .. ArrayList
class Foo
note left: On last defined class
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 35 of 125
3.8 更多注释3 类图
3.8 更多注释
可以在注释中使用部分html 标签:
• <b>
• <u>
• <i>
• <s>, <del>, <strike>
• <font color="#AAAAAA"> or <font color="colorName">
• <color:#AAAAAA> or <color:colorName>
• <size:nn> to change font size
• <img src="file"> or <img:file> : the file must be accessible by the filesystem
你也可以在注释中展示多行。
你也可以在定义的class 之后直接使用note left, note right, note top, note bottom 来定义注
释。
@startuml
class Foo
note left: On last defined class
note top of Object
In java , <size:18>every </size > <u>class </u>
<b>extends </b>
<i>this </i> one.
end note
note as N1
This note is <u>also </u>
<b><color:royalBlue >on several </color >
<s>words </s> lines
And this is hosted by <img:sourceforge.jpg >
end note
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 36 of 125
3.9 链接的注释3 类图
3.9 链接的注释
在定义链接之后,你可以用note on link 给链接添加注释
如果想要改变注释相对于标签的位置,你也可以用note left on link,note right on link,note bottom
on link。(对应位置分别在label 的左边,右边,下边)
@startuml
class Dummy
Dummy --> Foo : A link
note on link #red: note that is red
Dummy --> Foo2 : Another link
note right on link #blue
this is my note on right link
and in blue
end note
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 37 of 125
3.10 抽象类和接口3 类图
3.10 抽象类和接口
用关键字"abstract" 或"abstract class" 来定义抽象类。抽象类用斜体显示。也可以使用
interface, annotation 和enum 关键字。
@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
}
annotation SuppressWarnings
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 38 of 125
3.11 使用非字母字符3 类图
3.11 使用非字母字符
如果你想在类(或者枚举)的显示中使用非字母符号,你可以:
• 在类的定义中使用as 关键字
• 在类名旁边加上""
@startuml
class "This is my class" as class1
class class2 as "It works this way too"
class2 *-- "foo/dummy" : use
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 39 of 125
3.12 隐藏属性、函数等3 类图
3.12 隐藏属性、函数等
通过使用命令“hide/show”,你可以用参数表示类的显示方式。
基础命令是: hide empty members. 这个命令会隐藏空白的方法和属性。
除empty members 外,你可以用:
• empty fields 或者empty attributes 空属性,
• empty methods 空函数,
• fields 或attributes 隐藏字段或属性,即使是被定义了
• methods 隐藏方法,即使是被定义了
• members 隐藏字段和方法,即使是被定义了
• circle 类名前带圈的,
• stereotype 原型。
同样可以使用hide 或show 关键词,对以下内容进行设置:
• class 所有类,
• interface 所有接口,
• enum 所有枚举,
• <<foo1>> 实现foo1 的类,
• 一个既定的类名。
你可以使用show/hide 命令来定义相关规则和例外。
@startuml
class Dummy1 {
+myMethods()
}
class Dummy2 {
+hiddenMethod()
}
class Dummy3 <<Serializable >> {
String name
}
hide members
hide <<Serializable >> circle
show Dummy1 methods
show <<Serializable >> fields
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 40 of 125
3.13 隐藏类3 类图
3.13 隐藏类
你也可以使用show/hide 命令来隐藏类
如果你定义了一个大的!included 文件,且想在文件包含之后隐藏部分类,该功能会很有帮助。
@startuml
class Foo1
class Foo2
Foo2 *-- Foo1
hide Foo2
@enduml
3.14 泛型(generics)
你可以用< 和> 来定义类的泛型。
@startuml
class Foo <? extends Element > {
int size()
}
Foo *- Element
@enduml
It is possible to disable this drawing using skinparam genericDisplay old command.
3.15 指定标记(Spot)
通常标记字符(C, I, E or A) 用于标记类(classes), 接口(interface), 枚举(enum)和抽象类(abstract
classes).
但是当你想定义原型时,可以增加对应的单个字符及颜色,来定义自己的标记(spot),就像下面一
样:
@startuml
class System << (S,#FF7700) Singleton >>
class Date << (D,orchid) >>
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 41 of 125
3.16 包3 类图
3.16 包
你可以通过关键词package 声明包,同时可选的来声明对应的背景色(通过使用html 色彩代码或
名称)。
注意:包可以被定义为嵌套。
@startuml
package "Classic Collections" #DDDDDD {
Object <|-- ArrayList
}
package net.sourceforge.plantuml {
Object <|-- Demo1
Demo1 *- Demo2
}
@enduml
3.17 包样式
包可以定义不同的样式。
你可以通过以下的命令来设置默认样式: skinparam packageStyle, 或者对包使用对应的模板:
@startuml
scale 750 width
package foo1 <<Node >> {
class Class1
}
package foo2 <<Rectangle >> {
class Class2
}
package foo3 <<Folder >> {
class Class3
}
package foo4 <<Frame >> {
class Class4
}
package foo5 <<Cloud >> {
class Class5
}
package foo6 <<Database >> {
class Class6
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 42 of 125
3.18 命名空间(Namespaces) 3 类图
你也可以参考下面的示例来定义包之间的连线:
@startuml
skinparam packageStyle rectangle
package foo1.foo2 {
}
package foo1.foo2.foo3 {
class Object
}
foo1.foo2 +-- foo1.foo2.foo3
@enduml
3.18 命名空间(Namespaces)
In packages, the name of a class is the unique identifier of this class. It means that you cannot have
two classes with the very same name in different packages.
In that case, you should use namespaces instead of packages.
You can refer to classes from other namespaces by fully qualify them. Classes from the default
namespace are qualified with a starting dot.
Note that you don’t have to explicitly create namespace : a fully qualified class is automatically
put in the right namespace.
@startuml
class BaseClass
namespace net.dummy #DDDDDD {
.BaseClass <|-- Person
Meeting o-- Person
.BaseClass <|- Meeting
}
namespace net.foo {
net.dummy.Person <|- Person
.BaseClass <|-- Person
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 43 of 125
3.19 自动创建命名空间3 类图
net.dummy.Meeting o-- Person
}
BaseClass <|-- net.unused.Person
@enduml
3.19 自动创建命名空间
使用命令set namespaceSeparator ??? 你可以自定义命名空间分隔符(为“.”以外的字符).
@startuml
set namespaceSeparator ::
class X1::X2::foo {
some info
}
@enduml
禁止自动创建包则可以使用set namespaceSeparator none.
@startuml
set namespaceSeparator none
class X1.X2.foo {
some info
}
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 44 of 125
3.20 棒棒糖接口3 类图
3.20 棒棒糖接口
需要定义棒棒糖样式的接口时可以遵循以下语法:
• bar ()- foo
• bar ()-- foo
• foo -() bar
@startuml
class foo
bar ()- foo
@enduml
3.21 改变箭头方向
类之间默认采用两个破折号-- 显示出垂直方向的线. 要得到水平方向的可以像这样使用单破折号
(或者点):
@startuml
Room o- Student
Room *-- Chair
@enduml
你也可以通过改变倒置链接来改变方向
@startuml
Student -o Room
Chair --* Room
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 45 of 125
3.22 “关系”类3 类图
也可通过在箭头内部使用关键字,例如left, right, up 或者down,来改变方向
@startuml
foo -left -> dummyLeft
foo -right -> dummyRight
foo -up-> dummyUp
foo -down -> dummyDown
@enduml
You can shorten the arrow by using only the first character of the direction (for example, -dinstead
of -down-) or the two first characters (-do-).
Please note that you should not abuse this functionality : Graphviz gives usually good results
without tweaking.
3.22 “关系”类
你可以在定义了两个类之间的关系后定义一个关系类association class 例如:
@startuml
class Student {
Name
}
Student "0..*" - "1..*" Course
(Student , Course) .. Enrollment
class Enrollment {
drop()
cancel()
}
@enduml
也可以用另一种方式:
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 46 of 125
3.23 皮肤参数3 类图
@startuml
class Student {
Name
}
Student "0..*" -- "1..*" Course
(Student , Course) . Enrollment
class Enrollment {
drop()
cancel()
}
@enduml
3.23 皮肤参数
使用skinparam 命令可以改变字体和颜色.
典型的用法:
• 在图的定义中,就像其他命令一样
• 放在引入文件里
• 放在配置文件中、提供命令行参数或ANT 任务.
@startuml
skinparam class {
BackgroundColor PaleGreen
ArrowColor SeaGreen
BorderColor SpringGreen
}
skinparam stereotypeCBackgroundColor YellowGreen
Class01 "1" *-- "many" Class02 : contains
Class03 o-- Class04 : aggregation
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 47 of 125
3.24 Skinned Stereotypes 3 类图
3.24 Skinned Stereotypes
You can define specific color and fonts for stereotyped classes.
@startuml
skinparam class {
BackgroundColor PaleGreen
ArrowColor SeaGreen
BorderColor SpringGreen
BackgroundColor <<Foo >> Wheat
BorderColor <<Foo >> Tomato
}
skinparam stereotypeCBackgroundColor YellowGreen
skinparam stereotypeCBackgroundColor << Foo >> DimGray
Class01 <<Foo >>
Class03 <<Foo >>
Class01 "1" *-- "many" Class02 : contains
Class03 o-- Class04 : aggregation
@enduml
3.25 Color gradient
It’s possible to declare individual color for classes or note using the notation.
You can use either standard color name or RGB code.
You can also use color gradient in background, with the following syntax: two colors names separated
either by:
• |,
• /,
• \,
• or -
depending the direction of the gradient.
For example, you could have:
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 48 of 125
3.26 Help on layout 3 类图
@startuml
skinparam backgroundcolor AntiqueWhite/Gold
skinparam classBackgroundColor Wheat|CornflowerBlue
class Foo #red -green
note left of Foo #blue \9932CC
this is my
note on this class
end note
package example #GreenYellow/LightGoldenRodYellow {
class Dummy
}
@enduml
3.26 Help on layout
Sometimes, the default layout is not perfect...
You can use together keyword to group some classes together : the layout engine will try to group
them (as if they were in the same package).
You can also use hidden links to force the layout.
@startuml
class Bar1
class Bar2
together {
class Together1
class Together2
class Together3
}
Together1 - Together2
Together2 - Together3
Together2 -[hidden]--> Bar1
Bar1 -[hidden]> Bar2
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 49 of 125
3.27 拆分大文件3 类图
3.27 拆分大文件
有些情况下,会有一些很大的图片文件。
可以用”page (hpages)x(vpages)” 这个命令把生成的图片文件拆分成若干个文件。
hpages 用来表示水平方向页面数,and vpages 用来表示垂直方面页面数。
你也可以使用特定的皮肤设定来给分页添加边框(见例子)
@startuml
' Split into 4 pages
page 2x2
skinparam pageMargin 10
skinparam pageExternalColor gray
skinparam pageBorderColor black
class BaseClass
namespace net.dummy #DDDDDD {
.BaseClass <|-- Person
Meeting o-- Person
.BaseClass <|- Meeting
}
namespace net.foo {
net.dummy.Person <|- Person
.BaseClass <|-- Person
net.dummy.Meeting o-- Person
}
BaseClass <|-- net.unused.Person
@enduml
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 50 of 125
3.27 拆分大文件3 类图
PlantUML : 语言参考指南(2018 年5 月11 日星期五) 51 of 125



0 个回复

您需要登录后才可以回帖 登录 | 加入黑马