翻譯|使用教程|編輯:吳園園|2020-01-02 11:14:58.783|閱讀 407 次
概述:盡管在組內使用占位符很常見,但這不是必需的。例如,使用Shape代替占位符可實現一些功能,例如使組保持固定的大小,而與其成員節點的大小和位置無關,甚至根本沒有成員節點。如果需要該功能,還可以允許用戶調整“區域”的大小。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
GoJS是一款功能強大,快速且輕量級的流程圖控件,可幫助你在JavaScript 和HTML5 Canvas程序中創建流程圖,且極大地簡化您的JavaScript / Canvas 程序。
固定大小的組
在組中 不使用占位符意味著您必須保持組的大小和位置,因為它不能取決于其成員節點的大小和位置。在這些示例中,我們將顯式設置和/或綁定節點(包括組)的Part.location。替換組模板中占位符的Shape也應獲取其GraphObject.desiredSize設置或綁定。
diagram.nodeTemplate = $(go.Node, new go.Binding("location", "loc", go.Point.parse), $(go.TextBlock, new go.Binding("text", "key")) ); diagram.groupTemplate = $(go.Group, "Vertical", { selectionObjectName: "PH", locationObjectName: "PH" }, new go.Binding("location", "loc", go.Point.parse), $(go.TextBlock, // group title { font: "Bold 12pt Sans-Serif" }, new go.Binding("text", "key")), $(go.Shape, // using a Shape instead of a Placeholder { name: "PH", fill: "lightyellow" }, new go.Binding("desiredSize", "size", go.Size.parse)) ); var nodeDataArray = [ { key: "Alpha", loc: "0 0" }, { key: "Beta", group: "Omega", loc: "75 75" }, { key: "Gamma", group: "Omega", loc: "125 75" }, { key: "Omega", isGroup: true, loc: "50 50", size: "150 50" }, { key: "Delta", loc: "200 0" } ]; var linkDataArray = [ { from: "Alpha", to: "Beta" }, // from outside the Group to inside it { from: "Beta", to: "Gamma" }, // this link is a member of the Group { from: "Omega", to: "Delta" } // from the Group to a Node ]; diagram.model = new go.GraphLinksModel(nodeDataArray, linkDataArray); diagram.select(diagram.findNodeForKey("Omega"));
需要注意的是移動的“測試版”或“伽馬”節點并不會改變大小或“歐米茄”組的位置。但是,移動或復制或刪除組時,操作中將包括那些成員節點。
可以控制用戶可以將成員節點拖動到何處。例如,“ 泳道”示例演示了一個自定義的Part.dragComputation函數,該函數將成員節點的運動限制在其包含組內。
可調整大小的組
您可以使主要形狀由用戶調整大小。(當前,組不可旋轉。)
此示例還使Part.location和GraphObject.desiredSize數據綁定TwoWay,以便當用戶移動組或調整其主要形狀的大小時,模型中的數據將自動更新。
diagram.nodeTemplate = $(go.Node, new go.Binding("location", "loc", go.Point.parse).makeTwoWay(go.Point.stringify), $(go.TextBlock, new go.Binding("text", "key")) ); diagram.groupTemplate = $(go.Group, "Vertical", { selectionObjectName: "PH", locationObjectName: "PH", resizable: true, resizeObjectName: "PH" }, new go.Binding("location", "loc", go.Point.parse).makeTwoWay(go.Point.stringify), $(go.TextBlock, // group title { font: "Bold 12pt Sans-Serif" }, new go.Binding("text", "key")), $(go.Shape, // using a Shape instead of a Placeholder { name: "PH", fill: "lightyellow" }, new go.Binding("desiredSize", "size", go.Size.parse).makeTwoWay(go.Size.stringify)) ); var nodeDataArray = [ { key: "Alpha", loc: "0 0" }, { key: "Beta", group: "Omega", loc: "75 75" }, { key: "Gamma", group: "Omega", loc: "125 75" }, { key: "Omega", isGroup: true, loc: "50 50", size: "150 50" }, { key: "Delta", loc: "200 0" } ]; var linkDataArray = [ { from: "Alpha", to: "Beta" }, // from outside the Group to inside it { from: "Beta", to: "Gamma" }, // this link is a member of the Group { from: "Omega", to: "Delta" } // from the Group to a Node ]; diagram.model = new go.GraphLinksModel(nodeDataArray, linkDataArray); diagram.select(diagram.findNodeForKey("Omega"));
不是組的容器
也可以控制用戶如何調整組的大小。例如,“ 泳道”示例演示了一個自定義的“ 調整大小工具”,該工具可以限制每個泳道可以走多小。它還演示了只有兩個調整大小手柄的自定義裝飾。
您不必使用Groups作為組織Part集合的唯一機制。例如,“ 圖層帶”示例演示了如何自定義某些Layout來自動維護背景中特殊零件的位置和大小,這些零件似乎圍繞著屬于每個布局層的節點。
不使用Group也意味著可以避免Groups固有的某些限制,例如每個Part最多可以具有一個Part。containsGroup的限制。將共享國示例演示如何可以使它看起來不止一個“組”可以包含一個節點。但是,這需要一些其他的自定義Tool和自定義Layout,或者始終顯式設置/綁定每個節點和“組”的位置和大小。
====================================================
想要購買GoJS正版授權的朋友可以
有關產品的最新消息和最新資訊,歡迎掃描關注下方微信公眾號
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:GoJS