翻譯|使用教程|編輯:吳園園|2020-01-02 11:14:58.783|閱讀 421 次
概述:盡管在組內使用占位符很常見,但這不是必需的。例如,使用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@ke049m.cn
文章轉載自:GoJS