主頁 >  其他 > 用寫代碼的方式畫圖-試下PlantUML吧

用寫代碼的方式畫圖-試下PlantUML吧

2023-07-08 08:00:42 其他

1 序言

所謂一圖勝千言,大家平日在作業中撰寫檔案時,往往都需要畫各種圖來表達中心思想,比如流程圖、時序圖、UML 圖,很多人選擇使用 Axure 、PrecessOn、Diagrams(darw.io)、XMind、Visio、yEd、Lucidchart、Astah 等軟體來畫圖,這些軟體功能豐富可定制化強,但是有時候會讓人局限在軟體提供的素材中,陷入滑鼠拖動繪制的泥潭,無形中浪費了寶貴時間;另一方面出于安全合規考慮,在線繪圖型別的軟體也存在資料隱私風險,

在此為大家推薦一個專注于“畫圖”本身的工具 PlantUML,通過寫代碼的方式完成滿足各種需求場景的畫圖作業,將人的精力集中到思想的表達與傳遞,避免無謂的圖形頁面樣式修改調整,進而提升作業效率,

2 工具介紹

PlantUML 是一個可以快速撰寫 UML 圖的開源組件(https://github.com/plantuml/plantuml ), 始于2009 年,支持時序圖、用例圖、類圖、物件圖、活動圖等多種 UML 圖,也支持 JSON 資料、YAML 資料、網路圖、線框圖形界面、架構圖、甘特圖、思維導圖圖示等,PlantUML 采用 GPL 協議發布,在公司內部僅作為工具,不分發不修改的前提下軟體可以正常使用,

相較與其他工具的滑鼠拖拽繪圖方式,PlantUML 的圖不是“畫”出來的,而是“寫”出來的,PlantUML 同時支持多種主題,本地安裝即可渲染出圖形,樣式豐富可定制化,而且文本格式也便于保存到 git 實作歷史記錄 diff,最重要的是學習成本很低,

3 畫圖效果

下面展示使用PlantUML 繪制的各種型別圖例,

3.1 UML類圖

3.2 活動圖

3.3 流程圖

3.4 時序圖

3.5 腦圖

4 各種主題

PlantUML 內置了 30 多種主題,可以通過 help themes 命令查看內置主題串列,

@startuml
help themes
@enduml




在檔案開頭可以通過指令 !theme 來指定需要的主題名稱,

@startuml 
!theme mars
title 這是圖的主題
header 頁眉內容
footer 頁腳內容
Alice -> Bob: 認證請求
Bob -> Bob: 認證處理
Bob -> Alice: 認證接受
@enduml




5 使用準備

PlantUML 支持各類常用開發軟體,比如 Eclipse、VS code、IntelliJ 系列軟體等,官網上也支持實時編輯;同時也支持命令列方式生成圖片,

5.1 VS code

安裝插件:

搜索安裝最新插件,然后編輯 .puml 檔案即可實時渲染出圖:

5.2 IntelliJ IDEA

安裝插件:

搜索安裝最新插件,然后編輯 .puml 檔案即可實時渲染出圖:

5.3 Eclipse

安裝插件:

搜索安裝最新插件,然后編輯 .puml 檔案即可實時渲染出圖:

5.4 命令列

從官網下載最新版 jar 包,然后執行如下命令:

# 決議 111.puml 檔案并生成 png 圖片
java -jar plantuml.jar 111.puml




5.5 在線編輯

本地渲染即可滿足使用要求,但是官網也支持在線模式,

6 語法簡介

官網上(https://plantuml.com/zh/) 提供了豐富的 demo 可供參考,基本滿足了日常的畫圖需求;頂部點擊導航欄可以查看各種圖的幫助檔案,左側導航欄提供了組件的特色設定項,

6.1 時序圖

可以使用關鍵字定義 UML 元素,如:actor(角色)、boundary(邊界)、control(控制)、entity(物體)、database(資料庫)、collections(集合)、queue(佇列),使用 as關鍵字重命名參與者,

支持使用關鍵字 autonumber 用于自動對訊息編號,title 關鍵字用于為頁面添加標題,頁面可以使用 header 和 footer 顯示頁眉和頁腳,

使用這些關鍵詞來組合訊息:alt/else、opt、loop、par、break、critical、group, 后面緊跟著訊息內容,關鍵詞 end 用來結束分組,分組是可以嵌套使用的,

6.2 用例圖

package 定義一個包,as 定義對應別名,usecase 定義用例,箭頭定義關系,

6.3 類圖

使用 class 定義類,默認會自動將屬性和方法分割開,也可以使用分隔符 --..==__. 分隔符中也可以添加文字,

6.4 部署圖

node 標識節點,file 標識檔案,cloud 定義云,效果如下:

7 標準庫

官方標準庫提供了一系列的圖例擴展功能,遵循 “C標準庫約定”,使用命令:stdlib 即可查看當前版本組件支持的標準庫,

基于這些標準庫,可以創建豐富型別的圖表,包括但不限于架構圖、AWS 部署圖、Azure 庫等等,

8 C4模型與C4PlantUML

8.1 C4 模型

為什么我們需要架構圖呢?這是因為整個產品不只是開發人員使用的,從開發,測驗,架構師,專案經理,產品經理,UI 互動設計師,用戶,這么多的人員,需要一種方式能夠讓團隊的每個人腦子里的架構可視化出來,形成統一的理解,這就是架構圖,

C4 模型一種架構設計的方法論,忽略不在同一個抽象層級的細節,從而可以更好的表達和可視化,是軟體系統建模的圖形表示技巧,C4 模型會用到一些現有的建模技巧,例如統一建模語言(UML)及 ER 模型(ERD),會將系統結構化分解,分解為容器(container)和組件(component),

可以類比地圖,地圖分 4 個級別,國家,省,市,街道;C4 模型也分 4 個層級,依其階層關系分類:

1.統背景關系圖(Context diagrams),第一層的圖,說明系統、和其使用者以及其他系統的關系,

2.容器圖(Container diagrams),第二層的圖,將系統分解為彼此相關的容器(container),容器可以是應用程式或是資料存盤,

3.組件圖(Component diagrams),第三層的圖,將容器分別為彼此相關的組件,也說明組件和其他組件(或是其他系統)的關系,

4.代碼圖(Code diagrams),第四層的圖,提供架構元素的設計細節,可以對應到程式碼,在此層級的 C4 模型會用到目前已有的標示方式,例如統一建模語言、ER 模型或是集成開發環境產生的示意圖,

C4 模型的第一層到第三層,用到五種基礎的圖示元素:人、軟體系統、容器、組件和關系,此技術沒有規定元素的布局、形狀、顏色或是風格,C4 模型建議以嵌套框為基礎的簡單圖表,方便互動式的協作繪圖,C4 模型也鼓勵良好的建模實務,例如在每一個圖都加上標題以及圖例,以及清楚的標示,以方便目標讀者的理解,

8.2 C4PlantUML

基于開源專案 C4-PlantUML 可以實作軟體模型圖制作,同時官方標準庫里也包括了這個組件,

@startuml "enterprise"
'!include https://raw.githubusercontent.com/plantuml-stdlib/C4-PlantUML/master/C4_Container.puml
'!include C:/repo/C4-PlantUML/C4_Container.puml
!include <C4/C4_Container>

title 網銀系統容器圖

Person(customer, 客戶, "銀行客戶有自己的私人銀行賬號")
 
System_Boundary(c1, "網銀") {
    Container(web_app, "Web 應用", "Java, Spring MVC", "傳遞靜態內容和網銀SPA")
    Container(spa, "單頁應用", "JavaScript, Angular", "通過瀏覽器對用戶提供所有的網銀功能")
    Container(mobile_app, "手機應用", "C#, Xamarin", "通過手機設備提供有限的網銀功能")
    ContainerDb(database, "資料庫", "SQL 資料庫", "存盤用戶的注冊資訊,隨機認證密碼,訪問日志等")
    Container(backend_api, "API應用", "Java, Docker容器", "通過API提供網銀功能")
}

System_Ext(email_system, "郵件系統", "網路軟體交換系統")
System_Ext(banking_system, "Mainframe銀行系統", "存盤所有的核心客戶,賬號,事務銀行資訊")

Rel(customer, web_app, "使用", "HTTPS")
Rel(customer, spa, "使用", "HTTPS")
Rel(customer, mobile_app, "使用")

Rel_Neighbor(web_app, spa, "傳輸")
Rel(spa, backend_api, "使用", "異步, JSON/HTTPS")
Rel(mobile_app, backend_api, "使用", "異步, JSON/HTTPS")
Rel_Back_Neighbor(database, backend_api, "讀寫", "同步, JDBC")

Rel_Back(customer, email_system, "發送郵件到")
Rel_Back(email_system, backend_api, "發送郵件", SMTP")
Rel_Neighbor(backend_api, banking_system, "使用", "同步/異步, XML/HTTPS")




效果如下:

9 小結

PlantUML 使用格式良好且可讀的代碼來呈現圖表,相比于其他工具,PlantUML 將目光聚焦到畫圖本身,用戶只需要根據規范去寫邏輯代碼就可以生成比較好看且整潔的圖表,簡單高效,大家不必刻意去記它的語法,在使用的程序中去查閱檔案參考,很快就可以上手,

最后,感謝你的閱讀,如果這篇文章讓你有所識訓,也歡迎你將它分享給更多的人,

作者:京東物流 高世雄

內容來源:京東云開發者社區

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/556780.html

標籤:其他

上一篇:中國對鎵和鍺實施出口管制:全球半導體行業的新挑戰與機遇

下一篇:返回列表

標籤雲
其他(162204) Python(38266) JavaScript(25527) Java(18291) C(15239) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7290) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4613) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) HtmlCss(1993) .NET技术(1986) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1882) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 用寫代碼的方式畫圖-試下PlantUML吧

    為大家推薦一個專注于“畫圖”本身的工具 PlantUML,通過寫代碼的方式完成滿足各種需求場景的畫圖作業,將人的精力集中到思想的表達與傳遞,避免無謂的圖形頁面樣式修改調整,進而提升作業效率 ......

    uj5u.com 2023-07-08 08:00:42 more
  • 中國對鎵和鍺實施出口管制:全球半導體行業的新挑戰與機遇

    隨著全球半導體行業的競爭日益激烈,中國近日宣布對鎵和鍺實施出口管制,這是對美國對中國半導體行業技術封鎖的回應。這一決定可能會對全球半導體供應鏈產生深遠影響,引發一場全球范圍內的科技和經濟震動。 ......

    uj5u.com 2023-07-08 08:00:33 more
  • 京東統一頭尾管理系統探索實踐

    你瀏覽過的每一個網頁的背后都是有許多個業務系統在支撐,并由專門的研發團隊來負責維護。而各業務系統為了能夠保持統一的網頁風格,往往都會使用相同的頁面頭部和尾部,我們稱之為公共頭尾。 ......

    uj5u.com 2023-07-08 08:00:27 more
  • 最近很火的開源培訓系統,支持免費商用,3個月1000star!

    專案簡介 PlayEdu 開源培訓系統自發布以來,3個月內幫助上千位開發者部署了私有化培訓平臺,并在 Github 上獲得了1000star。 專案地址 Github 地址:https://github.com/PlayEdu/PlayEdu GItee 地址:https://gitee.com/p ......

    uj5u.com 2023-07-08 08:00:05 more
  • SkyEye處理器仿真系列:龍芯2K1000處理器

    ??SkyEye簡介: 天目全數字實時仿真軟體SkyEye作為基于可視化建模的硬體行為級仿真平臺,能夠為嵌入式軟體提供虛擬化運行環境,開發、測驗人員可在該虛擬運行環境上進行軟體開發、軟體測驗和軟體驗證活動。小到芯片,大到系統,SkyEye均可進行模擬。 01.背景介紹 1936年,被譽為“計算機科學 ......

    uj5u.com 2023-07-08 07:53:55 more
  • 測驗技術的重要性與應用:現狀、方法和未來展望

    在軟體開發領域,測驗技術扮演著至關重要的角色。測驗技術是通過系統性的驗證和評估來檢查軟體系統的正確性、可靠性和性能的程序。它旨在發現潛在的缺陷、錯誤和漏洞,并提供反饋和建議給開發團隊,以便及時修復和改進。測驗技術的目標是確保軟體系統能夠按照預期的方式作業,并滿足用戶的需求和期望。 ......

    uj5u.com 2023-07-08 07:53:47 more
  • 自適應辛普森法積分演算法推導

    引子 有時候我們需要計算一個函式的定積分,粗略上可以使用估算的方法。如圖所示,將原本的曲線粗略地看成一個梯形。這個方法叫梯形法則(Trapezoidal Rule)。也叫做一階牛頓-柯特斯閉型積分公式。 其中 所謂一階,指的就是n=1的情況。 最理想的情況就是把這個影像分割成 無數 個梯形,便可求出 ......

    uj5u.com 2023-07-07 08:26:33 more
  • 【工程報告】面試01號工程報告

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-07-07 08:26:20 more
  • ConvertToRinex批處理工具

    Convert To Rinex軟體是有天寶公司(Trimble)所開發的GNSS資料解碼程式,?于將天GNSS接識訓的原始資料?件(DAT、T00、T01、RT17、RT27或.cap)轉化成RINEX格式。ConverToRinex314版本可轉換為Rinex v2.10、v2.11、v3.02 ......

    uj5u.com 2023-07-07 08:26:14 more
  • CTF常見密碼編碼合集

    ASCII編碼 簡述:使用制定的7位或8位二進制陣列合來表示128或256種可能的字符。使用7位二進制數(剩下的1位二進制為0)來表示所有的大寫和小寫字母,數字0到9、標點符號,以及在美式英語中使用的特殊控制字符。 在線解密&工具:https://www.sojson.com/ascii.html ......

    uj5u.com 2023-07-07 08:24:58 more