`
zeyuphoenix
  • 浏览: 57886 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JTree--树(基本使用)

 
阅读更多
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta name="ProgId" content="Word.Document"> <meta name="Generator" content="Microsoft Word 12"> <meta name="Originator" content="Microsoft Word 12"> <link rel="File-List" href="file:///C:%5CDOCUME%7E1%5Cphoenix%5CLOCALS%7E1%5CTemp%5Cmsohtmlclip1%5C01%5Cclip_filelist.xml"> <link rel="Edit-Time-Data" href="file:///C:%5CDOCUME%7E1%5Cphoenix%5CLOCALS%7E1%5CTemp%5Cmsohtmlclip1%5C01%5Cclip_editdata.mso"> <!--[if !mso]> <style> v":* {behavior:url(#default#VML);} o":* {behavior:url(#default#VML);} w":* {behavior:url(#default#VML);} .shape {behavior:url(#default#VML);} </style> <![endif]--><link rel="themeData" href="file:///C:%5CDOCUME%7E1%5Cphoenix%5CLOCALS%7E1%5CTemp%5Cmsohtmlclip1%5C01%5Cclip_themedata.thmx"> <link rel="colorSchemeMapping" href="file:///C:%5CDOCUME%7E1%5Cphoenix%5CLOCALS%7E1%5CTemp%5Cmsohtmlclip1%5C01%5Cclip_colorschememapping.xml"> <!--[if gte mso 9]><xml> Normal 0 false 7.8 磅 0 2 false false false EN-US ZH-CN X-NONE </xml><![endif]--><!--[if gte mso 9]><![endif]--><style> <!-- /* Font Definitions */ @font-face {font-family:宋体; panose-1:2 1 6 0 3 1 1 1 1 1;} @font-face {font-family:"Cambria Math"; panose-1:2 4 5 3 5 4 6 3 2 4;} @font-face {font-family:Calibri; panose-1:0 0 0 0 0 0 0 0 0 0; mso-font-alt:"Times New Roman";} @font-face {font-family:""@宋体"; panose-1:2 1 6 0 3 1 1 1 1 1;} /* Style Definitions */ p.MsoNormal, li.MsoNormal, div.MsoNormal { mso-style-parent:""; margin:0cm; margin-bottom:.0001pt; text-align:justify; text-justify:inter-ideograph; font-size:10.5pt; font-family:"Calibri","serif"; mso-bidi-font-family:"Times New Roman";} pre { mso-style-link:"HTML 预设格式 Char"; margin:0cm; margin-bottom:.0001pt; font-size:12.0pt; font-family:宋体;} span.apple-style-span {} span.HTMLChar {mso-style-name:"HTML 预设格式 Char"; mso-style-link:"HTML 预设格式"; font-family:宋体;} .MsoChpDefault { mso-bidi-font-family:"Times New Roman";} /* Page Definitions */ @page {} @page Section1 {size:595.3pt 841.9pt; margin:72.0pt 90.0pt 72.0pt 90.0pt; layout-grid:15.6pt;} div.Section1 {page:Section1;} --> </style> <!--[if gte mso 10]> <style> /* Style Definitions */ table.MsoNormalTable { mso-style-parent:""; font-size:10.5pt; font-family:"Calibri","serif";} </style> <![endif]-->

JTree也是一个分层显示数据的组件,它在Swing里复杂度算是中等,涉及的类不是很多,也没有复杂的UI,所以单独对一个树来说,构造和渲染都不难,对于树的操作比较麻烦的是拖拽和与其他组件数据交互.

对于JTree有几个比较重要的类和接口: TreeMode是一个接口,用来构建树的模型,实现这个接口之后我们可以把一些比较另类的组件抽象成一棵树,TreeTable就是这个原理实现的;TreeNode是一个接口,代表树的节点,DefaultMutableTreeNode是该接口的一个实现,我们一般构建树使用它就可以了,当然也可以继承它添加新的功能,或者实现TreeNode把节点变成其它组件; TreePath是一个类,负责节点到根的路径,一般不需要我们来修改; TreeSelectionModel是一个接口,表示树选择组件的当前状态,只是使用皆可以了,一般除非做很大的改动,否则不需要修改这个类;还有就是TreeCellRendererTreeCellEditor,它们是树的渲染器,实现特殊效果都需要实现它们;还有就是TreeUI,树的UI比较死板,很少需要修改.

由上面类和接口可以,树还是一个不是很复杂的组件的,除了基本使用外,我们一般会用到的也就是对Cell进行渲染,替换树的节点图片,或者给节点加个CheckBox这些了.

先看树的简单使用,Sun官方给我们提供了例子:

<!--[if gte vml 1]> <![endif]-->

这个例子只是简单的构建一棵树:

       // Create the root nodes.

        DefaultMutableTreeNode top = new DefaultMutableTreeNode(

                "The Java Series");

        //add node

        createNodes(top);

        // Create a tree that allows one selection at a time.

        tree = new JTree(top);

        tree.getSelectionModel().setSelectionMode(

                TreeSelectionModel.SINGLE_TREE_SELECTION);

当然我们也可以先创建树,再设置数据,这都是JTree的构造函数,本质上是没区别的,最终JTree也是通过setModel设置数据的:

tree = new JTree();

tree.setModel(treeModel);

构造完树之后还要把树放在JScollPanel,否则树显示会有问题:

        // Create the scroll pane and add the tree to it.

        JScrollPane treeView = new JScrollPane(tree);

到此为止,树就完成了,当然Sun也提供了许多方法便捷于我们操作树:

取得根节点:

     // get the tree root node

     TreeNode rootNode = (TreeNode)tree.getModel().getRoot();

取得树的数据模型:

     // get the tree model.

     DefaultTreeModel treeModel = (DefaultTreeModel)tree.getModel();

取得树的某一个节点的位置:

     // get tree node path.

     TreePath nodePath = new TreePath(treeModel.getPathToRoot(node));

设置节点的展开可见和选择:

     //select the node.

     tree.setSelectionPath(nodePath);

    // Ensures that the node identified by path is currently viewable.

tree.makeVisible(nodePath);

展开后滚动至节点可见:

    // Makes sure all the path components display

tree.scrollPathToVisible(nodePath);

还有一个是设置鼠标点击展开树节点的(默认是双击,改成了0就是不可点击):

   // Sets the number of mouse clicks before a node will expand or close.

   tree.setToggleClickCount(1);

另外就是一个设置Cell的高度的,但这个方法我们一般不用,大多时候是在Renderer里设置的,因为这样设置可能有UI问题:

   // Sets the height of each cell, in pixels.

   tree.setRowHeight(15);

其它还有很多,因为JTree继承JComponent,所以它有父类的所有方法,我们通过setXXXgetXXX就可以设置了.

说完基本的设置之后,说一下JTree的事件:

JTree继承JComponent,所以它有JComponent的事件,但我们一般只关注鼠标的键盘的:

    // add mouse listener

    tree.addMouseListener(this);

    // add key listener

tree.addKeyListener(this);

然后是JTree独有的事件:

    tree.addTreeExpansionListener(this);

    tree.addTreeWillExpandListener(this);

    tree.addTreeSelectionListener(this);

分别是树节点展开(折叠)、树节点将要展开(折叠)和树节点选择事件,我们一般用的多的是addTreeExpansionListeneraddTreeSelectionListener事件:

事件处理都不是很复杂,增加监听后实现方法就可以了,需要注意的是TreeSelectionListenerMouseListener,它们有事件重叠的地方:但在树的节点点击鼠标左键时触发这两个事件,点击右键时触发鼠标事件,所以这两个事件都做监听时,处理一定要注意:

先看TreeSelectionListener的处理:

     @Override

     publicvoid valueChanged(TreeSelectionEvent event) {

然后可以取得TreePath,之后取得Node

     // Returns the current lead path.

     TreePath newPath = event.getNewLeadSelectionPath();

     TreePath oldPath = event.getOldLeadSelectionPath();

或者通过JTree取得Node

JTree tree = (JTree) event.getSource();

tree.getLastSelectedPathComponent();

再看MouseListener的处理:

      @Override

    publicvoid mouseClicked(MouseEvent e) {

鼠标组件场合比较简单,因为这个时候节点被选中:

if (SwingUtilities.isLeftMouseButton(e)

                    && e.getClickCount() == 1) {

       // Returns the last path component

       DefaultMutableTreeNode node = (DefaultMutableTreeNode) tree

                        .getLastSelectedPathComponent();

    }

右键则要得出节点位置再处理:

     if (SwingUtilities.isRightMouseButton(e)) {

        // Returns the row for the specified location.

        int selectRow = tree.getRowForLocation(e.getX(), e.getY());

        // Returns the path for the node at the specified location.

        TreePath selectPath = tree.getPathForLocation(e.getX(), e

                        .getY());

        if (selectPath != null) {

             // set select

             tree.setSelectionPath(selectPath);

             // get tree node.

            DefaultMutableTreeNode treeNode = (DefaultMutableTreeNode) selectPath.getLastPathComponent();

      }

之后有了树和选择节点就可以做自己的业务逻辑了.

另外JTree的节点的增加、修改和删除也需要看一下,如果我们使用DefaultTreeModel的话,这些操作都很简单,通过它的insertNodeInto



removeNodeFromParentnodeChanged等方法就可以实现了,但是如果是我们自己实现的TreeModel,必须再做完数据的操作之后UpdateUI更新界面,



或者学习Sun的事件机制,触发事件然后在View层更新画面,一般都不推荐这么做,除非你的TreeModel的数据特别复杂,没办法使用
DefaultTreeModel



这个数据容器
,例如TreeTable.

到此,除了JTreeRendererEditor之外,只剩下JTree的取数据了.JTree的数据取得我们一般都是用递归,这儿写个从任何节点递归其下所有的例子:

    private List<TreeNode> treeNodeList = new ArrayList<TreeNode>();

    publicvoid getChildNodeList(TreeNode treeNode) {

        if (treeNode == null) {

            thrownew RuntimeException("error treenode.");

        }

        if (treeNodeList == null) {

            treeNodeList = new ArrayList<TreeNode>();

        }

        if (treeNode.getChildCount() >= 0) {

            for (Enumeration<TreeNode> e = treeNode.children(); e

                    .hasMoreElements();) {

                TreeNode childNode = (TreeNode) e.nextElement();

                treeNodeList.add(childNode);

                getChildNodeList(childNode);

            }

        }

    }

最后我们看一个Renderer的例子,Sun官方提供的:

<!--[if gte vml 1]> <![endif]-->

首先看它的Renderer实现,这个是直接继承DefaultTreeCellRenderer

privateclass MyRenderer extends DefaultTreeCellRenderer {

然后复写它的getTreeCellRendererComponent方法:

    @Override

    public Component getTreeCellRendererComponent(JTree tree, Object value, boolean sel, boolean expanded, boolean leaf, int row,

        boolean hasFocus) {

它的默认实现时一个JLabel,在里面我们就可以设置它的效果了,这里设置一个图片:

setIcon(tutorialIcon);

当然我们也可以继承其它组件,实现TreeCellRenderer接口,实现更多效果.

使用很简单,直接使用JTreesetCellRenderer方法就可以了:

tree.setCellRenderer(new MyRenderer(tutorialIcon));

总结,基本树的操作和呈现设置都这里就完成了,可以看出,树还是比较简单的,后面我预计还有两个主题,一个是关于JTreeRendererEditor,在那儿实现一棵树的节点的图片特性,可用与否,选择隐藏等;另外就是关于树的选择框了,其实也是RendererEditor的使用,只不过为了逻辑和应用,做的更复杂.

分享到:
评论

相关推荐

    Swing-JTree.rar_jtree_jtree Demo_swing 树

    这个“Swing-JTree.rar”文件包含了一个关于JTree的经典示例,名为“jtree树案例”,这将帮助我们更好地理解和使用这个组件。 JTree的主要功能: 1. **显示层次结构数据**:JTree可以用来表示和展示具有层级关系的...

    java使用jtree动态实现二叉树

    在Java编程中,`JTree`是Swing库中的一个组件,用于展示树形数据结构。这个组件在GUI(图形用户界面)应用中非常常见,因为它可以清晰地展示层次关系的数据,比如文件系统目录结构。在Java中动态实现二叉树,即在...

    如何使用JTree,JTree使用方法

    ### 如何使用JTree:详解与实践 #### JTree简介 `JTree`是Java Swing中的一个组件,用于展示层次化的数据结构。它允许用户在应用程序中构建树形视图来表示目录结构、组织结构图等。`JTree`继承自`JComponent`类,...

    JTree2.0 目录树

    JTree的基本使用** JTree是javax.swing.tree包的一部分,它继承自JComponent,因此可以像其他Swing组件一样添加到容器中。创建JTree通常需要以下步骤: - **创建DefaultMutableTreeNode对象**:这是树节点的基础...

    JTree2.0 目录树demo源码

    下面我们将深入探讨`JTree`的基本概念,以及如何通过源码运行和理解`JTree2.0`目录树Demo。 1. **JTree基本概念** - **组件**:`JTree`是Java AWT和Swing框架的一部分,它是一个可以显示多级数据的组件。 - **...

    instrument/JTree-开源

    总之,`instrument/JTree`库是对Java Swing JTree组件的有力补充,它扩展了基本功能,使开发者能够创建更复杂、交互性更强的用户界面。结合开源社区的持续支持和更新,这个库为Java GUI开发带来了更多的可能性和便利...

    (一)如何使用JTree

    此外,JTree还可以与其他Swing组件结合使用,如JTable,创建复杂的视图,例如在树中选择一个节点后,在表格中显示与该节点相关的详细信息。 总之,JTree是Java Swing中用于展示和操作层次数据的强大工具。通过理解...

    java组件之jtree使用

    除了以上的基本用法外,`JTree`还支持许多其他的操作,比如扩展节点、折叠节点、改变节点图标等。这些操作可以通过调用`JTree`的各种方法来实现。 - **扩展节点**:可以使用`expandPath`方法来展开特定的路径或节点...

    JTree 需要树的可以研究下

    "JTree_Simple"可能指的是一个示例程序或代码片段,展示了如何简单地创建和使用`JTree`。通常,这样的示例会包含创建基本的树结构、添加监听器以及处理用户交互的代码。 在实际开发中,理解并熟练运用`JTree`可以...

    JTree2.0

    1. **基本使用**:解释如何通过`DefaultMutableTreeNode`创建基本的树结构,并使用`JTree`类实例化一个可视化的树组件。 2. **数据模型**:介绍`TreeModel`接口,它是树数据的抽象表示,以及如何自定义模型以适应...

    JTree控件的使用

    `JTree`是`JComponent`的子类,因此它具备组件的基本功能,并且可以通过添加监听器来响应用户的交互事件。 `JTree`的构造函数多样,可以根据不同的数据源创建树结构。例如,可以使用`HashTable`、`Object`数组、`...

    jtree的详细使用说明

    通过本篇介绍,我们不仅了解了如何使用 `JTree` 的基本构造方法来创建树形结构,还学习了如何使用 `Hashtable` 来组织数据以及如何展示这些数据。此外,我们还简要探讨了 `JTree` 的一些高级特性,如自定义渲染器、...

    jtree树应用

    JTree组件的基本概念** JTree是Java Swing中一个可视化组件,它允许用户以树状形式查看数据。每个节点(TreeNode)可以有零个或多个子节点,形成一个层次结构。用户可以通过单击节点来展开或折叠其子节点,从而...

    java中JTree的简单应用

    首先,让我们了解JTree的基本用法。JTree可以通过两种方式创建:一种是通过默认的树模型,另一种是通过自定义的TreeModel。默认的树模型通常使用DefaultMutableTreeNode类,而自定义的TreeModel则允许开发者更灵活地...

    java-根据过滤条件显示树形结构

    总结一下,Java中根据过滤条件显示树形结构涉及的主要知识点有:树形数据结构的实现,自定义节点类,过滤逻辑的定义,以及使用Swing的`JTree`组件进行可视化展示。理解并掌握这些概念,可以帮助你有效地处理复杂的...

    JTree组件资料

    创建`JTree`的基本步骤如下: 1. **构建树模型**: 首先,你需要创建一个`DefaultTreeModel`对象,该对象包含树的数据结构。你可以通过`DefaultMutableTreeNode`来构建树的节点,然后将这些节点添加到模型中。 2. *...

    JTree的用法

    ### JTree的用法详解 #### 一、引言 `JTree` 是 Java Swing 库中的一个重要组件,用于在图形用户界面 ...对于初学者来说,掌握 `JTree` 的基本使用方法是非常重要的,这有助于更好地理解 Java Swing 框架的高级特性。

    JTree

    1. **模型(Model)**:`JTree` 使用 `DefaultTreeModel` 或自定义的 `TreeModel` 来存储和管理树的数据。模型负责处理节点的添加、删除和修改,并通知 `JTree` 进行相应的更新。 2. **节点(Node)**:在树中,每...

    使用SwingWorker异步加载JTree

    在实际应用中,可能还需要考虑错误处理、进度条显示等更复杂的需求,但这个基本的示例展示了使用SwingWorker异步加载JTree的基本思路。 博客“使用SwingWorker异步加载JTree”可能还涵盖了如何创建和启动...

Global site tag (gtag.js) - Google Analytics