home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c13 / swing / Trees.java < prev   
Encoding:
Java Source  |  2000-05-25  |  4.6 KB  |  121 lines

  1. //: Trees.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Simple Swing tree example. Trees can be made
  50. // vastly more complex than this.
  51. package c13.swing;
  52. import java.awt.*;
  53. import java.awt.event.*;
  54. import java.awt.swing.*;
  55. import java.awt.swing.tree.*;
  56.  
  57. // Takes an array of Strings and makes the first
  58. // element a node and the rest leaves:
  59. class Branch {
  60.   DefaultMutableTreeNode r;
  61.   public Branch(String[] data) {
  62.     r = new DefaultMutableTreeNode(data[0]);
  63.     for(int i = 1; i < data.length; i++)
  64.       r.add(new DefaultMutableTreeNode(data[i]));
  65.   }
  66.   public DefaultMutableTreeNode node() { 
  67.     return r; 
  68.   }
  69. }  
  70.  
  71. public class Trees extends JPanel {
  72.   String[][] data = {
  73.     { "Colors", "Red", "Blue", "Green" },
  74.     { "Flavors", "Tart", "Sweet", "Bland" },
  75.     { "Length", "Short", "Medium", "Long" },
  76.     { "Volume", "High", "Medium", "Low" },
  77.     { "Temperature", "High", "Medium", "Low" },
  78.     { "Intensity", "High", "Medium", "Low" },
  79.   };
  80.   static int i = 0;
  81.   DefaultMutableTreeNode root, child, chosen;
  82.   JTree tree;
  83.   DefaultTreeModel model;
  84.   public Trees() {
  85.     setLayout(new BorderLayout());
  86.     root = new DefaultMutableTreeNode("root");
  87.     tree = new JTree(root);
  88.     // Add it and make it take care of scrolling:
  89.     add(new JScrollPane(tree), 
  90.       BorderLayout.CENTER);
  91.     // Capture the tree's model:
  92.     model =(DefaultTreeModel)tree.getModel();
  93.     JButton test = new JButton("Press me");
  94.     test.addActionListener(new ActionListener() {
  95.       public void actionPerformed(ActionEvent e){
  96.         if(i < data.length) {
  97.           child = new Branch(data[i++]).node();
  98.           // What's the last one you clicked?
  99.           chosen = (DefaultMutableTreeNode)
  100.             tree.getLastSelectedPathComponent();
  101.           if(chosen == null) chosen = root;
  102.           // The model will create the 
  103.           // appropriate event. In response, the
  104.           // tree will update itself:
  105.           model.insertNodeInto(child, chosen, 0);
  106.           // This puts the new node on the 
  107.           // currently chosen node.
  108.         }
  109.       }
  110.     });
  111.     // Change the button's colors:
  112.     test.setBackground(Color.blue);
  113.     test.setForeground(Color.white);
  114.     JPanel p = new JPanel();
  115.     p.add(test);
  116.     add(p, BorderLayout.SOUTH);
  117.   }
  118.   public static void main(String args[]) {
  119.     Show.inFrame(new Trees(),200,500);
  120.   }
  121. } ///:~