溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

GoJs分組繪圖模板go.Group如何使用

發(fā)布時間:2023-04-17 16:41:58 來源:億速云 閱讀:132 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“GoJs分組繪圖模板go.Group如何使用”,在日常操作中,相信很多人在GoJs分組繪圖模板go.Group如何使用問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”GoJs分組繪圖模板go.Group如何使用”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

    前言

    在可視化圖形中,很多的節(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);

    GoJs分組繪圖模板go.Group如何使用

    可以看出通過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")
              )
            )
          );

    GoJs分組繪圖模板go.Group如何使用

    由此可以看出設(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;
            })
          )
        )
      );

    GoJs分組繪圖模板go.Group如何使用

    然后圖形就變成了這樣,通過SubGraphExpanderButton按鈕可以控制不同的組的折疊和顯示。

    到此,關(guān)于“GoJs分組繪圖模板go.Group如何使用”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

    向AI問一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI