摘要:它是一款全自動圖生成器,支持。但是圖并不方便操作。因為經常使用來做圖,所以如果能生成一個可以導入到的文件那就更好了。文件支持導入文件,那文件到底是什么樣子的是導出時,生成的圖片,包含各個元素。導入主要看的是。
Phuml項目需要畫uml圖,手寫浪費時間,于是就搜了一些相關的工具來生成它。有php插件phpumd等等。發現了一個簡單易用的工具,那就是phuml。
它是一款全自動uml圖生成器,支持php5。
安裝教程git clone https://github.com/jakobwesthoff/phuml //下載源碼 yum install graphviz //安裝圖形庫 cd phuml/src/app ./phuml -r /path -graphviz -createAssociations false -neato test.png //生成uml圖
是不是很簡單。
但是uml圖并不方便操作。因為經常使用processon來做圖,所以如果能生成一個可以導入到processon的.pos文件那就更好了。
processon支持導入.pos文件,那.pos文件到底是什么樣子的?
{ "diagram":{ //image是導出時,生成的圖片,elements包含各個元素。導入主要看的是elements。 "image":{ "height":322, "pngdata":"", //導出時,base64格式圖片 "width":310, "y":9, "x":26 }, "elements":{ "page":{ "gridSize":15, //網格大小 "showGrid":true, //顯示網格 "orientation":"portrait", //頁面方向 portrait豎向 "height":1500, //頁面高度 "backgroundColor":"transparent", //背景顏色 "width":1250, //頁面長度 "padding":20 //頁面的灰邊寬度 }, "elements":{ "15a3b34d769898":{ //生成一串隨機id作為標識,每個圖形都對應著一個 "textBlock":[ //文本塊,uml圖為三塊 //類名 { "position":{ "w":"w-20", "h":"30", "y":"0", "x":"10" }, "text":"類" }, //屬性 { "position":{ "w":"w-20", "h":47, "y":"35", "x":"10" }, "text":"+ attribute1:type = defaultValue + attribute2:type - attribute3:type", "fontStyle":{ "bold":false, "textAlign":"left" } }, //方法 { "position":{ "w":"w-20", "h":145, "y":93, "x":"10" }, "text":"+ operation1(params):returnType - operation2(params) - operation3() + operation1(params):returnType - operation2(params) - operation3() + operation1(params):returnType - operation2(params) - operation3()", "fontStyle":{ "bold":false, "textAlign":"left" } } ], "lineStyle":{ }, "link":"", "children":[ ], "parent":"", "attribute":{ "linkable":true, "visible":true, "container":false, "rotatable":true, "markerOffset":5, "collapsable":false, "collapsed":false }, "fontStyle":{ "bold":true }, "resizeDir":[ "tl", "tr", "br", "bl" ], "dataAttributes":[ ], "shapeStyle":{ "alpha":1 }, "id":"15a3b34d769898", "anchors":[ { "y":"0", "x":"w/2" }, { "y":"h", "x":"w/2" }, { "y":"h/2", "x":"0" }, { "y":"h/2", "x":"w" } ], "title":"類", "category":"uml_class", "name":"cls", "path":[ { "actions":[ { "action":"move", "y":"4", "x":"0" }, { "y1":"0", "action":"quadraticCurve", "y":"0", "x":"4", "x1":"0" }, { "action":"line", "y":"0", "x":"w-4" }, { "y1":"0", "action":"quadraticCurve", "y":"4", "x":"w", "x1":"w" }, { "action":"line", "y":"h-4", "x":"w" }, { "y1":"h", "action":"quadraticCurve", "y":"h", "x":"w-4", "x1":"w" }, { "action":"line", "y":"h", "x":"4" }, { "y1":"h", "action":"quadraticCurve", "y":"h-4", "x":"0", "x1":"0" }, { "action":"close" } ] }, { "fillStyle":{ "type":"none" }, "actions":[ { "action":"move", "y":30, "x":"0" }, { "action":"line", "y":30, "x":"w" }, { "action":"move", "y":88, "x":"0" }, { "action":"line", "y":88, "x":"w" } ] }, { "lineStyle":{ "lineWidth":0 }, "fillStyle":{ "type":"none" }, "actions":[ { "action":"move", "y":"0", "x":"0" }, { "action":"line", "y":"0", "x":"w" }, { "action":"line", "y":"h", "x":"w" }, { "action":"line", "y":"h", "x":"0" }, { "action":"close" } ] } ], "fillStyle":{ }, "locked":false, "group":"", "props":{ "w":230, "heights":[ 30, 50, 145 ], "angle":0, "h":242, "y":49, "zindex":1, "x":66 } } } } }, "meta":{ "id":"58a29cdce4b028637aca553f", "member":"saber", "exportTime":"2017-02-14 14:00:44", "diagramInfo":{ "category":"uml", "title":"訂單", "created":"2017-02-14 13:59:56", "attributes":null, "creator":"saber", "modified":"2017-02-14 14:00:25" }, "type":"ProcessOn Schema File", "version":"1.0" } }
所以只要仿照著它的格式來一份就能生成一份pos文件。
使用git clone https://github.com/sabercoding/phuml.git //下載源碼 ./phuml -r /path -processon test.pos //生成pos文件待優化之處
類圖大小及文本塊大小
類之間的關系
類排版
最新發表在這里
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/22375.html
摘要:截至發文,最新版本為內容機密,團隊使用首選私有部署,形式部署非常簡單,只要分鐘,行代碼,你就可擁有自己專屬的媲美的流程圖應用。私有部署的還有一個好處是可以進行二次開發。 ...
上次講了2個游戲源碼 前端實戰之js推箱子游戲(有界面、附源碼、贊關藏) Python實戰:五子棋小游戲,切身感受一下前端和桌面應用的區別,選擇自己喜歡的 本來今天準備寫一篇面向對象文章,但是想一想,講面向對象之前還是先給大家介紹幾款實用的工具,更加快速的理解,掌握知識點。 1.UML 統一建模語言(Unified Modeling Language,UML)是一種為面向對象系統的產品進行說明、可...
摘要:單例模式模式系列的開篇,首先介紹的是我最喜歡的單例模式,簡單而言,這屬于生成一個且只生成一個對象實例的特殊類。問題良好設計的系統通過方法調用傳遞對象實例。面向對象設計模式目錄 單例模式 模式系列的開篇,首先介紹的是我最喜歡的單例模式(Singleton),簡單而言,這屬于:生成一個、且只生成一個對象實例的特殊類。 這個唯一存在的類,將替代Global關鍵字,并且更安全。 產生前提 全局...
摘要:分鐘快速部署數字繪經常有小伙伴問,有沒有一款好用又免費的畫圖軟件,畫畫流程圖思維導圖今天就介紹一款開源的在線畫圖軟件,可以滿足多方的需求。為了方便部署和解決環境兼容性等問題,采用來部署安裝數字繪。 5分鐘快速部署DataDraw數字繪 經常有小伙伴問,有沒有一款好用又免費的畫圖軟件,畫畫流程圖、UML、思維導圖?今天就介紹一款開源的在線畫圖軟件,可以滿足多方的需求。 DataDraw數...
閱讀 1668·2023-04-26 00:30
閱讀 3145·2021-11-25 09:43
閱讀 2868·2021-11-22 14:56
閱讀 3183·2021-11-04 16:15
閱讀 1137·2021-09-07 09:58
閱讀 2014·2019-08-29 13:14
閱讀 3101·2019-08-29 12:55
閱讀 982·2019-08-29 10:57