如何在 JTree 中獲取該節點同級節點的數量?


要獲取該節點的同級節點數,請使用 getSiblingCount() 方法。假設你有一個具有 4 個子節點的節點。查詢此節點的任意一個子節點的同級節點。此處,“eight”是子節點 −

eight.getSiblingCount());

注 − 請記住,一個節點就是它自身的同級節點。

以下示例用於在 JTree 中獲取該節點的同級節點數 −

示例

package my;
import javax.swing.JFrame;
import javax.swing.JTree;
import javax.swing.tree.DefaultMutableTreeNode;
public class SwingDemo {
   public static void main(String[] args) throws Exception {
      JFrame frame = new JFrame("Demo");
      DefaultMutableTreeNode node = new DefaultMutableTreeNode("Products");
      DefaultMutableTreeNode node1 = new DefaultMutableTreeNode("Clothing (Product1 - P66778)");
      DefaultMutableTreeNode node2 = new DefaultMutableTreeNode("Accessories (Product2 - P66779)");
      DefaultMutableTreeNode node3 = new DefaultMutableTreeNode("Home Decor (Product3 - P66780)");
      DefaultMutableTreeNode node4 = new DefaultMutableTreeNode("Electronics (Product4 - P66781)");
      node.add(node1);
      node.add(node2);
      node.add(node3);
      node.add(node4);
      DefaultMutableTreeNode one = new DefaultMutableTreeNode("Shirt");
      DefaultMutableTreeNode two = new DefaultMutableTreeNode("T-shirt");
      DefaultMutableTreeNode three = new DefaultMutableTreeNode("Hoodie");
      DefaultMutableTreeNode four = new DefaultMutableTreeNode("Sunglasses");
      DefaultMutableTreeNode five = new DefaultMutableTreeNode("Frames");
      DefaultMutableTreeNode six = new DefaultMutableTreeNode("Belts");
      DefaultMutableTreeNode seven = new DefaultMutableTreeNode("Showpieces & Figurines");
      DefaultMutableTreeNode eight = new DefaultMutableTreeNode("Clocks");
      DefaultMutableTreeNode nine = new DefaultMutableTreeNode("Wall Shelves");
      DefaultMutableTreeNode ten = new DefaultMutableTreeNode("Mobile Accessories");
      DefaultMutableTreeNode eleven = new DefaultMutableTreeNode("Smart Wearable Tech");
      DefaultMutableTreeNode twelve = new DefaultMutableTreeNode("Health Care Applicances");
      DefaultMutableTreeNode thirteen = new DefaultMutableTreeNode("Smart Home Automation");
      node1.add(one);
      node1.add(two);
      node1.add(three);
      node2.add(four);
      node2.add(five);
      node2.add(six);
      node3.add(seven);
      node3.add(eight);
      node3.add(nine);
      node4.add(ten);
      node4.add(eleven);
      node4.add(twelve);
      node4.add(thirteen);
      JTree tree = new JTree(node);
      for (int i = 0; i < tree.getRowCount(); i++) {
         tree.expandRow(i);
      }
      tree.putClientProperty("JTree.lineStyle", "Angled");
      System.out.println("Siblings of node 3's child node eight = "+eight.getSiblingCount());
      tree.setRowHeight(25);
      frame.add(tree);
      frame.setSize(600,450);
      frame.setVisible(true);
   }
}

輸出如下,在控制檯上顯示此節點的同級節點數 −

輸出

以下是我們 JTree −

更新於: 30-Jul-2019

125 次瀏覽

開啟你的 職業

完成課程即可取得認證

開始
廣告