GoJs分組繪圖模板go.Group使用示例詳解
前言
在可視化圖形中,很多的節(jié)點和連線都有某一個特征或者屬于某些分類,為了在使用可視化圖形的時候更加直觀的看出相同類型節(jié)點的集合,我們就會用到分組的繪圖模板。
Group的使用
//data
nodes: [
{
key: "1",
text: "三國人物志",
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);
可以看出通過group字段來判斷自己這個節(jié)點屬于哪個組,然后用isGroup來判斷該對象是一個組,而不是一個普通節(jié)點。這些組成員之間的關(guān)系又構(gòu)成了一個樹形結(jié)構(gòu),這讓我們很方便的分析這些成員之間的關(guān)系。
Group的屬性
handlesDragDropForMembers//是否可以監(jiān)聽子組的拖拽 isSubGraphExpanded//是否顯示組內(nèi)的其他節(jié)點 ungroupable//是否可以解除對應(yīng)組的的分類 wasSubGraphExpanded//是否可以折疊展開組
handlesDragDropForMembers、isSubGraphExpanded屬性
handlesDragDropForMembers屬性是設(shè)置是夠允許組內(nèi)的節(jié)點的拖拽的事件冒泡到組中,如果設(shè)置為true。則需要對組內(nèi)的節(jié)點設(shè)置mouseDragEnter、mouseDragleave、mouseDrop來分別處理拖拽過程中對應(yīng)的拖拽事件。這些放到后面事件的方法中詳細(xì)解析。
isSubGraphExpanded屬性
isSubGraphExpanded屬性是設(shè)置是否顯示組內(nèi)的其他節(jié)點,默認(rèn)為true,顯示組內(nèi)的其他節(jié)點??梢允褂胢yDiagram上的groupTemplate做一些簡單的配置看一下對應(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會把所有的組進(jìn)行折疊。
ungroupable、wasSubGraphExpanded屬性
ungroupable屬性是設(shè)置是否可以解除對應(yīng)的組,默認(rèn)為false。可以根據(jù)自己的需求去設(shè)置不同的屬性。wasSubGraphExpanded屬性設(shè)置是否可以展開和折疊組,我們可以對上面的組進(jìn)行一些拓展,就是下面這個樣子
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;
})
)
)
);

然后圖形就變成了這樣,通過SubGraphExpanderButton按鈕可以控制不同的組的折疊和顯示。
結(jié)語
在真正的開發(fā)過程中,一般遇到這種分組的情況比較少,但是gojs還是提供了組的繪圖模板供我們使用。也是拓展了很多可視化圖形的顯示空間
以上就是GoJs分組繪圖模板go.Group使用示例詳解的詳細(xì)內(nèi)容,更多關(guān)于GoJs分組繪圖模板Group的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
js實現(xiàn)仿愛微網(wǎng)兩級導(dǎo)航菜單效果代碼
這篇文章主要介紹了js實現(xiàn)仿愛微網(wǎng)兩級導(dǎo)航菜單效果代碼,通過javascript自定義函數(shù)結(jié)合鼠標(biāo)點擊事件實現(xiàn)tab切換的功能,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08
HTML頁面,測試JS對C函數(shù)的調(diào)用簡單實例
下面小編就為大家?guī)硪黄狧TML頁面,測試JS對C函數(shù)的調(diào)用簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
TypeScript條件類型與內(nèi)置條件類型超詳細(xì)講解
我們可以使用TypeScript中的條件類型來根據(jù)邏輯定義某些類型,就像是在編寫代碼那樣。它采用的語法和我們在JavaScript中熟悉的三元運算符很像:condition ? ifConditionTrue : ifConditionFalse。我們來看看他是怎么工作的2023-03-03
有趣的JavaScript隱式類型轉(zhuǎn)換操作實例分析
這篇文章主要介紹了JavaScript隱式類型轉(zhuǎn)換操作,結(jié)合實例形式分析了JavaScript隱式類型轉(zhuǎn)換操作相關(guān)實現(xiàn)技巧與注意事項,需要的朋友可以參考下2020-05-05
JS加密插件CryptoJS實現(xiàn)的DES加密示例
這篇文章主要介紹了JS加密插件CryptoJS實現(xiàn)的DES加密,結(jié)合實例形式分析了javascript使用CryptoJS插件進(jìn)行des加密的各種常見模式使用技巧,需要的朋友可以參考下2018-08-08

