GoJs分組繪圖模板go.Group使用示例詳解
前言
在可視化圖形中,很多的節(jié)點(diǎn)和連線都有某一個(gè)特征或者屬于某些分類,為了在使用可視化圖形的時(shí)候更加直觀的看出相同類型節(jié)點(diǎn)的集合,我們就會(huì)用到分組的繪圖模板。
Group的使用
//data
nodes: [
{
key: "1",
text: "三國(guó)人物志",
isGroup: true
},
{
key: "1-1",
text: "魏",
group: "1",
isGroup: true
},
{
key: "1-1-1",
text: "曹丕",
group: "1-1",
},
{
key: "1-2",
text: "蜀",
group: "1",
isGroup: true
},
{
key: "1-2-1",
text: "劉備",
group: "1-2",
},
{
key: "1-3",
text: "吳",
group: "1",
isGroup: true
},
{
key: "1-3-1",
text: "孫權(quán)",
group: "1-3",
},
],
links: [
],
//methods
this.myDiagram = $$(go.Diagram, "myDiagramDiv", {
});
this.myDiagram.nodeTemplate = $$(
go.Node,
"Horizontal",
$$(go.TextBlock,{background:"#67B73C"},new go.Binding("text", "text")),
);
this.myDiagram.model = new go.GraphLinksModel(this.nodes, this.links);
可以看出通過(guò)group字段來(lái)判斷自己這個(gè)節(jié)點(diǎn)屬于哪個(gè)組,然后用isGroup來(lái)判斷該對(duì)象是一個(gè)組,而不是一個(gè)普通節(jié)點(diǎn)。這些組成員之間的關(guān)系又構(gòu)成了一個(gè)樹(shù)形結(jié)構(gòu),這讓我們很方便的分析這些成員之間的關(guān)系。
Group的屬性
handlesDragDropForMembers//是否可以監(jiān)聽(tīng)子組的拖拽 isSubGraphExpanded//是否顯示組內(nèi)的其他節(jié)點(diǎn) ungroupable//是否可以解除對(duì)應(yīng)組的的分類 wasSubGraphExpanded//是否可以折疊展開(kāi)組
handlesDragDropForMembers、isSubGraphExpanded屬性
handlesDragDropForMembers屬性是設(shè)置是夠允許組內(nèi)的節(jié)點(diǎn)的拖拽的事件冒泡到組中,如果設(shè)置為true。則需要對(duì)組內(nèi)的節(jié)點(diǎn)設(shè)置mouseDragEnter、mouseDragleave、mouseDrop來(lái)分別處理拖拽過(guò)程中對(duì)應(yīng)的拖拽事件。這些放到后面事件的方法中詳細(xì)解析。
isSubGraphExpanded屬性
isSubGraphExpanded屬性是設(shè)置是否顯示組內(nèi)的其他節(jié)點(diǎn),默認(rèn)為true,顯示組內(nèi)的其他節(jié)點(diǎn)??梢允褂胢yDiagram上的groupTemplate做一些簡(jiǎn)單的配置看一下對(duì)應(yīng)的效果。
this.myDiagram.groupTemplate = $$(
go.Group,
"Auto",
{
isSubGraphExpanded: false,
},
$$(go.Shape, "Rectangle", { fill: null, stroke: "#67B73c" }),
$$(
go.Panel,
"Table",
$$(
go.TextBlock,
{
row: 0,
column: 1,
stroke: "#FF9900",
textAlign: "center",
stretch: go.GraphObject.Horizontal,
},
new go.Binding("text")
)
)
);

由此可以看出設(shè)置isSubGraphExpanded為false會(huì)把所有的組進(jìn)行折疊。
ungroupable、wasSubGraphExpanded屬性
ungroupable屬性是設(shè)置是否可以解除對(duì)應(yīng)的組,默認(rèn)為false??梢愿鶕?jù)自己的需求去設(shè)置不同的屬性。wasSubGraphExpanded屬性設(shè)置是否可以展開(kāi)和折疊組,我們可以對(duì)上面的組進(jìn)行一些拓展,就是下面這個(gè)樣子
this.myDiagram.groupTemplate = $$(
go.Group,
"Auto",
{
wasSubGraphExpanded:true,
},
$$(go.Shape, "Rectangle", { fill: null, stroke: "#67B73c" }),
$$(
go.Panel,
"Table",
$$("SubGraphExpanderButton", { row: 0, column: 0, margin: 3 }),
$$(
go.TextBlock,
{
row: 0,
column: 1,
stroke: "#FF9900",
textAlign: "center",
stretch: go.GraphObject.Horizontal,
},
new go.Binding("text")
),
$$(
go.Placeholder,
{ row: 1, columnSpan: 2, padding: 10, alignment: go.Spot.TopLeft },
new go.Binding("padding", "isSubGraphExpanded", function (exp) {
return exp ? 10 : 0;
})
)
)
);

然后圖形就變成了這樣,通過(guò)SubGraphExpanderButton按鈕可以控制不同的組的折疊和顯示。
結(jié)語(yǔ)
在真正的開(kāi)發(fā)過(guò)程中,一般遇到這種分組的情況比較少,但是gojs還是提供了組的繪圖模板供我們使用。也是拓展了很多可視化圖形的顯示空間
以上就是GoJs分組繪圖模板go.Group使用示例詳解的詳細(xì)內(nèi)容,更多關(guān)于GoJs分組繪圖模板Group的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript中重名的函數(shù)與對(duì)象示例詳析
最近同事問(wèn)了一個(gè)問(wèn)題,說(shuō)在js中如果函數(shù)與對(duì)象重名了會(huì)怎么樣?仔細(xì)詳細(xì)這個(gè)問(wèn)題值得討論一下,所以便有了這篇文章,這篇文章主要給大家介紹了關(guān)于JavaScript中重名的函數(shù)與對(duì)象的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)一起看看吧啊。2017-09-09
javascript實(shí)現(xiàn)拖動(dòng)元素交換位置
這篇文章主要介紹了javascript實(shí)現(xiàn)拖動(dòng)元素交換位置的方法,類似拼圖游戲拖拽卡片效果,感興趣的小伙伴們可以參考一下2015-11-11
前端項(xiàng)目打包部署后如何避免讓用戶強(qiáng)制去清除瀏覽器緩存
這篇文章主要介紹了前端項(xiàng)目打包部署后如何避免讓用戶強(qiáng)制去清除瀏覽器緩存的相關(guān)資料,文中講解了瀏覽器緩存機(jī)制及其對(duì)性能優(yōu)化的重要性,探討了如何通過(guò)設(shè)置Cache-Control頭部、添加資源版本號(hào)或利用Webpack的文件命名特性來(lái)控制緩存,需要的朋友可以參考下2024-12-12
JavaScript的DOM與BOM的區(qū)別與用法詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript的DOM與BOM的區(qū)別與用法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03
JS實(shí)現(xiàn)在文本指定位置插入內(nèi)容的簡(jiǎn)單示例
下面小編就為大家分享一篇JS實(shí)現(xiàn)在文本指定位置插入內(nèi)容的簡(jiǎn)單示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
JavaScript中停止執(zhí)行setInterval和setTimeout事件的方法
這篇文章主要介紹了JavaScript中停止執(zhí)行setInterval和setTimeout事件的方法,本文給出操作實(shí)例代碼和語(yǔ)法介紹,需要的朋友可以參考下2015-05-05
Canvas實(shí)現(xiàn)放射線動(dòng)畫(huà)效果
本文主要分享了Canvas實(shí)現(xiàn)放射線動(dòng)畫(huà)的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
Bootstrap Table使用整理(五)之分頁(yè)組合查詢
這篇文章主要介紹了 Bootstrap Table使用整理(五)之分頁(yè)組合查詢的實(shí)例代碼,非常報(bào)錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-06-06

