用java小程序applet实现无限级树结构

原创 2004年10月24日 14:44:00

该程序可以根据从指定的xml文件中读取的有关信息动态的建立一棵树。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

1.该树的特点:

1)无限级树结构

        理论上树的深度可以无限,树的深度由xml文件所给的信息确定;

        数据加载采用一次加载和动态加载相结合的方法;

        每次打开相关页时重新加载树结构,真正的做到了建立树的动态性。

2)复用性

       由于这棵树是通过读取xml文件建立的,树的程序代码固定,所以具有很强的复用性。只需要给出xml文件,程序就可以建立对应的树。

3)与用户的交互

由于该程序是用java小程序实现的,所以可以利用java语言中监听事件的类,以响应用户操作。与用户具有更好的交互性。

2.程序结构

这棵树主要有三个类实现:

1)    TreeNode:该类起辅助作用,用来描述树的数据结构,并提供一些settergetter函数用来设置树结构的属性。

2)    IconRender:该类也是一个辅助类,用来设置树节点的图标。并且可以根据树节点的选中状态改变图标。

3)    AppletTree:该类是建立这棵树的主要类,它继承自Applet并且实现了TreeSelectionListener接口,以用来监听用户操作。树结构由javaJTree显示,我们只需要合理的设定JTree的属性就可以构造出这棵树。而它的属性是通过jdom中的Element读取xml文件提供的。上面已经提到监听用户操作是通过实现TreeSelectionListener接口完成的,但是只监听不响应毫无用处。怎样才能将监听到的用户操作传给相应的类以响应用户的操作呢?这里用的方法是通过URL将参数传递给jsp文件,再由jsp文件传给相应的操作类实现的。

这三个类的代码如下:

1TreeNode

public class TreeNode{

  private String id;

  private String name;

  private String link;

  public TreeNode(String id,String name,String link){

    this.id=id;

    this.name=name;

    this.link=link;

  }

  public String getId(){

    return id;

  }

  public void setId(String Id){

    this.id=Id;

  }

  public void  setName(String Name){

    this.name=Name;

  }

 

  public String getName(){

    return name;

  }

 

  public String toString(){

    return  name;

  }

  public String getLink(){

    return link;

  }

  public void setLink(String link){

    this.link=link;

  }

}

2. IconRender

import javax.swing.*;

import java.awt.*;

import javax.swing.tree.*;

import javax.swing.tree.DefaultTreeCellRenderer;

IconRender

class extends DefaultTreeCellRenderer {

 

 

  //创建用于显示的图标

  public static final ImageIcon leafSelectedIcon = new ImageIcon("OpenedFolder.ico");

  public static final ImageIcon leafUnSelectedIcon = new ImageIcon("closedFolder.ico");

  public static final ImageIcon folderOpen = new ImageIcon("OpenedFolder.ico");

  public static final ImageIcon folderClose = new ImageIcon("closedFolder.ico");

 

  //设定图标随选中状态的变化

  public Component getTreeCellRendererComponent(JTree

tree,Object value,boolean selectedboolean expanded,

boolean leaf, int row,boolean hasFocus)

{

    super.getTreeCellRendererComponent(tree,value, selected, expanded, leaf, row, hasFocus);

 

    if (leaf && selected) {

      setIcon(IconRender.leafSelectedIcon);

    }

    else if (leaf) {

      setIcon(IconRender.leafUnSelectedIcon);

    }

 

    return this;

  }

 

  public IconRender() {

    super();

    if((leafSelectedIcon != null)&&(leafUnSelectedIcon != null))

      System.out.println("IconRender:trace");

     

    setLeafIcon(leafUnSelectedIcon);

    setOpenIcon(folderOpen);

    setClosedIcon(folderClose);

 

  }

 

}

3AppletTree

import javax.swing.event.*;

import java.awt.*;

import java.applet.*;

import javax.swing.*;

import javax.swing.tree.*;

import java.awt.event.*;

import org.jdom.*;

//import org.w3c.dom.NodeList;

import org.jdom.input.*;

import java.io.*;

import java.util.*;

import java.net.*;

 

import java.awt.*;

import javax.swing.*;

import javax.swing.border.*;

import javax.swing.plaf.*;

import javax.swing.plaf.basic.*;

import javax.swing.plaf.metal.*;

 

 

 

import java.io.*;

//import netscape.javascript.*;

class MyWindowListener extends WindowAdapter

{

 public void windowClosing(WindowEvent e)

 {

  System.exit(1);

 }

}

 

public class AppletTree extends Applet implements TreeSelectionListener

{

  private JTree tree;

 

  private TreePath path;

  private JScrollPane treeView;

  private DefaultMutableTreeNode top;

 

  private DefaultMutableTreeNode clicknode;

 

 

 

  private String link;

 

  public AppletTree(){

}

MouseListener ml = new MouseAdapter() {

     public void mousePressed(MouseEvent e) {

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

         TreePath selPath = tree.getPathForLocation(e.getX(), e.getY());

         if(selRow != -1) {

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

             System.out.print("点击一次鼠标");

            

                //得到最后一个节点

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

                boolean isLeaf = treeNode.isLeaf();

               

                TreeNode objTreeNode = (TreeNode)treeNode.getUserObject();

                System.out.println(isLeaf);

                System.out.println(objTreeNode .getName()) ;

                System.out.println(objTreeNode .getId()) ;

                if(isLeaf)

                {//如果为叶子节点就传出去进行查询操作

                try

                      {             

                    getAppletContext().showDocument(new URL("http://127.0.0.1:8080/tree/showDevice.htm"),"f2" );            

                   }

                 catch(Exception ex)

                 {

                  System.out.print(ex);

                 }

                }

               

             }

             else if(e.getClickCount() == 2) {

             System.out.print("点击两次鼠标");

              //getAppletContext().showDocument(new URL("http://www.csdn.net/"));

                 //myDoubleClick(selRow, selPath);

             }

         }

     }

 };

 

 

public void start()

{

super.start();  

}

 

  public void init(){

    try{

    super.init();

    this.setLayout(new GridLayout(1,1));

    tree=createTree(new FileInputStream("e:/example/TreeXML.xml"));

    tree.getSelectionModel().setSelectionMode(TreeSelectionModel.SINGLE_TREE_SELECTION);

    tree.putClientProperty("JTree.lineStyle","Angled");

 

    tree.setShowsRootHandles(true);

    tree.setEditable(true);

    tree.addTreeSelectionListener( this );

    IconRender render=new IconRender();

    tree.setCellRenderer(render);

 

 

    treeView = new JScrollPane(tree);

    //topPanel.add(tree);

    this.add(treeView);

   

    tree.addMouseListener(ml);

   

    }catch(Exception e){

      e.printStackTrace();

    }

 

  }

  public JTree createTree(InputStream is){

    SAXBuilder builder = new SAXBuilder();

    try {

      Document doc = builder.build(is);

      Element root=doc.getRootElement();

      TreeNode rootNode=new

         TreeNode(root.getAttributeValue("id"),root.getAttributeValue("name"),root.getAttributeValue("HaveChildren"));

      top=new DefaultMutableTreeNode(rootNode);

      addNode(root,top);

    }  catch (Exception ex) {

      ex.printStackTrace();

    }

    //可以在这里改变jtree中连线的颜色

    UIManager.put( "Tree.hash", new ColorUIResource(Color.red) );

    return new JTree(top);

 

  }

 

  /**

   *

   * @param e 待加入树中的jdom元素

   * @param fatherNode 树节点父亲节点

   */

 

  private void addNode(Element e,DefaultMutableTreeNode fatherNode){

  try{

  Iterator it=e.getChildren().iterator();

  if(!it.hasNext())

      return;

    while(it.hasNext()){

     

      Element sub=(Element)it.next();

   

      String id=new String(sub.getAttributeValue("id").getBytes(),"GB2312");

      String name=new String(sub.getAttributeValue("name").getBytes(),"GB2312");

      String link=new String(sub.getAttributeValue("HaveChildren").getBytes(),"GB2312");

     

      System.out.println(id);

      System.out.println(name);

      System.out.println(link);

     

      TreeNode tempNode=new TreeNode(id,name,link); 

   

      DefaultMutableTreeNode node=new DefaultMutableTreeNode(tempNode);

      fatherNode.add(node);

     

      if(link.equals("true")){

      System.out.println("true~! equal test");

      addNode(sub,node);

      }

    }

    }

    catch(Exception exp)

    {

      System.out.println("encoding fail");

    }

 

  }

 

  /**

   * 根据id,查找树节点,//广度优先

   * @param id 节点id

   * @param rootNode 树根节点

   * @return DefaultMutableTreeNode

   */

  private DefaultMutableTreeNode getTreeNode(String id,DefaultMutableTreeNode rootNode){

    DefaultMutableTreeNode returnNode=null;

    if(rootNode!=null){

      Enumeration enum=rootNode.breadthFirstEnumeration();

      while(enum.hasMoreElements()){

        DefaultMutableTreeNode temp=(DefaultMutableTreeNode)enum.nextElement();

        TreeNode node=(TreeNode)temp.getUserObject();

        if(node.getId().equals(id)){

          returnNode=temp;

          break;

        }

      }

    }

    return returnNode;

 

  }

 

 

  public void valueChanged( TreeSelectionEvent event ){

    if( event.getSource() == tree ){

      path = event.getPath();

      clicknode=(DefaultMutableTreeNode)path.getLastPathComponent();

      Object uo=clicknode.getUserObject();

      if(uo instanceof TreeNode){

        TreeNode nd=(TreeNode)clicknode.getUserObject();

        link=nd.getLink();

      }

    }

  }

 

  

  public static  void main(String[] args ){

    JFrame frame1=new JFrame("test");

    AppletTree tree=new AppletTree();

    tree.init();

    frame1.getContentPane().add(tree);

    frame1.setSize(600,600);

 

    frame1.show();

    frame1.addWindowListener(new MyWindowListener());

  }

 

}

【小程序】递归实现控制台输出的文件树形结构

要求:给定任意一个目录,以树形方式展现出该目录中的所有子目录和文件,另外展现的时候目录在上面,文件在下面,每一层有缩进。 代码: package myfiles; import java.io....
  • JAVAkuroro
  • JAVAkuroro
  • 2011年10月19日 21:01
  • 2194

java实现的可以无限级别添加子节点的菜单树

网上大部分菜单树,都是单独用js代码来实现的,这样做的缺点是:用户无法动态的设置菜单项,比如,超级管理员可能需要根据每个用户的权限,赋予他们不同的系统功能,不同的功能对应着不同数量的菜单项。 对于此...
  • xiyang_1990
  • xiyang_1990
  • 2014年03月11日 18:57
  • 1380

实现无限级树结构

表结构如下:数据库 id  path    title          sort     排序 1    0        首页         0 2    0,1      新闻        ...
  • afeilxc
  • afeilxc
  • 2008年10月07日 17:36
  • 415

关于无限级理解,及其树形结构

首先在表中含有parent_id字段 树级菜单的顶层parent_id=0 那么如何根据顶层菜单查找它所属的子级菜单呢? 思路如下 : 首先找到parent_id=0的记录(可以有多条,意味的...
  • qq_30259339
  • qq_30259339
  • 2016年04月03日 11:29
  • 1372

使用TreeView实现无限级扩展节点(原创)

功能实现要求:操作环境vb.net和oracle9i 由于数据量很大,所以不能利用rs结果集一次读出,在往treeview节点上填充。需要填充树型节点的字段内数据形式为以"."分割如:01   01....
  • yun15291li
  • yun15291li
  • 2005年03月25日 23:49
  • 996

PHP+JS无限级可伸缩菜单详解(递归方法)

PHP+JS无限级可伸缩菜单详解(递归方法)一般在CMS系统后台中都要用到的类别管理部分的精华--无限级分类菜单,对于新手来说,这个可能有一定难度,但是今天听完我细细道来,相信以后大家就都会弄这东东了...
  • fkedwgwy
  • fkedwgwy
  • 2008年06月18日 13:37
  • 3100

无限级目录树数据结构前端实现

无限级目录树数据结构的前端实现
  • qq_22555107
  • qq_22555107
  • 2017年11月14日 13:40
  • 358

无限级目录树--前台页面

----------------index.php----------------------------------menu_front1.js在前一个帖子上------------var judg...
  • dep_boy
  • dep_boy
  • 2006年10月31日 22:25
  • 710

javascript实现无限级联动

无限级联动的实现
  • u011003813
  • u011003813
  • 2015年01月23日 11:03
  • 445

JAVA应用小程序(Applet)

Applet是采用Java编程语言编写的小应用程序,该程序可以包含在 HTML(标准通用标记语言的一个应用)页中,与在页中包含图像的方式大致相同。 含有Applet的网页的HTML文件代码中部带有 ...
  • jianggujin
  • jianggujin
  • 2016年01月27日 09:50
  • 4369
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用java小程序applet实现无限级树结构
举报原因:
原因补充:

(最多只允许输入30个字)