JTree drag and drop utilites : Tree « Swing JFC « Java

Java
1. 2D Graphics GUI
2. 3D
3. Advanced Graphics
4. Ant
5. Apache Common
6. Chart
7. Class
8. Collections Data Structure
9. Data Type
10. Database SQL JDBC
11. Design Pattern
12. Development Class
13. EJB3
14. Email
15. Event
16. File Input Output
17. Game
18. Generics
19. GWT
20. Hibernate
21. I18N
22. J2EE
23. J2ME
24. JDK 6
25. JNDI LDAP
26. JPA
27. JSP
28. JSTL
29. Language Basics
30. Network Protocol
31. PDF RTF
32. Reflection
33. Regular Expressions
34. Scripting
35. Security
36. Servlets
37. Spring
38. Swing Components
39. Swing JFC
40. SWT JFace Eclipse
41. Threads
42. Tiny Application
43. Velocity
44. Web Services SOA
45. XML
Java Tutorial
Java Source Code / Java Documentation
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java » Swing JFC » TreeScreenshots 
JTree drag and drop utilites
   
/* Copyright (c) 2006, 2009, Carl Burch. License information is located in the
 * com.cburch.logisim.Main source code and at www.cburch.com/logisim/. */
 

import java.awt.AlphaComposite;
import java.awt.Graphics2D;
import java.awt.Insets;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.awt.dnd.DnDConstants;
import java.awt.dnd.DragGestureEvent;
import java.awt.dnd.DragGestureListener;
import java.awt.dnd.DragSource;
import java.awt.dnd.DragSourceDragEvent;
import java.awt.dnd.DragSourceDropEvent;
import java.awt.dnd.DragSourceEvent;
import java.awt.dnd.DragSourceListener;
import java.awt.dnd.DropTargetDragEvent;
import java.awt.dnd.DropTargetDropEvent;
import java.awt.dnd.DropTargetEvent;
import java.awt.dnd.DropTargetListener;
import java.awt.image.BufferedImage;
import java.util.Arrays;

import javax.swing.JComponent;
import javax.swing.JTree;
import javax.swing.tree.TreePath;

/* This comes from "Denis" at http://forum.java.sun.com/thread.jspa?forumID=57&threadID=296255 */

/*
 * My program use 4 classes. The application displays two trees.
 * You can drag (move by default or copy with ctrl pressed) a node from the left tree to the right one, from the right to the left and inside the same tree.
 * The rules for moving are :
 *   - you can't move the root
 *   - you can't move the selected node to its subtree (in the same tree).
 *   - you can't move the selected node to itself (in the same tree).
 *   - you can't move the selected node to its parent (in the same tree).
 *   - you can move a node to anywhere you want according to the 4 previous rules.
 *  The rules for copying are :
 *   - you can copy a node to anywhere you want.
 *
 * In the implementation I used DnD version of Java 1.3 because in 1.4 the DnD is too restrictive :
 * you can't do what you want (displaying the image of the node while dragging, changing the cursor
 * according to where you are dragging, etc...). In 1.4, the DnD is based on the 1.3 version but
 * it is too encapsulated.
 */


public class JTreeUtil {
    private static final Insets DEFAULT_INSETS = new Insets(20202020);
    private static final DataFlavor NODE_FLAVOR = new DataFlavor(
            DataFlavor.javaJVMLocalObjectMimeType, "Node");

    private static Object draggedNode;
    private static BufferedImage image = null// buff image

    private static class TransferableNode implements Transferable {
        private Object node;
        private DataFlavor[] flavors = NODE_FLAVOR };

        public TransferableNode(Object nd) {
            node = nd;
        }

        public synchronized Object getTransferData(DataFlavor flavor)
                throws UnsupportedFlavorException {
            if(flavor == NODE_FLAVOR) {
                return node;
            else {
                throw new UnsupportedFlavorException(flavor);
            }
        }

        public DataFlavor[] getTransferDataFlavors() {
            return flavors;
        }

        public boolean isDataFlavorSupported(DataFlavor flavor) {
            return Arrays.asList(flavors).contains(flavor);
        }
    }

    /*
     * This class is the most important. It manages all the DnD behavior. It is
     * abstract because it contains two abstract methods:
     *   public abstract boolean canPerformAction(JTree target,
     *     Object draggedNode, int action, Point location);
     *   public abstract boolean executeDrop(DNDTree tree,
     *     Object draggedNode, Object newParentNode, int action);
     * we have to override to give the required behavior of DnD in your tree.
     */
    private static class TreeTransferHandler implements
            DragGestureListener, DragSourceListener, DropTargetListener {
        private JTree tree;
        private JTreeDragController controller;
        private DragSource dragSource; // dragsource
        private Rectangle rect2D = new Rectangle();
        private boolean drawImage;

        protected TreeTransferHandler(JTree tree, JTreeDragController controller,
                int action, boolean drawIcon) {
            this.tree = tree;
            this.controller = controller;
            drawImage = drawIcon;
            dragSource = new DragSource();
            dragSource.createDefaultDragGestureRecognizer(tree, action, this);
        }

        /* Methods for DragSourceListener */
        public void dragDropEnd(DragSourceDropEvent dsde) {
            /*
            if(dsde.getDropSuccess()
                    && dsde.getDropAction() == DnDConstants.ACTION_MOVE
                    && draggedNodeParent != null) {
                ((DefaultTreeModel) tree.getModel())
                        .nodeStructureChanged(draggedNodeParent);
            }
            */
        }

        public final void dragEnter(DragSourceDragEvent dsde) {
            int action = dsde.getDropAction();
            if(action == DnDConstants.ACTION_COPY) {
                dsde.getDragSourceContext().setCursor(
                        DragSource.DefaultCopyDrop);
            else {
                if(action == DnDConstants.ACTION_MOVE) {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveDrop);
                else {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveNoDrop);
                }
            }
        }

        public final void dragOver(DragSourceDragEvent dsde) {
            int action = dsde.getDropAction();
            if(action == DnDConstants.ACTION_COPY) {
                dsde.getDragSourceContext().setCursor(
                        DragSource.DefaultCopyDrop);
            else {
                if(action == DnDConstants.ACTION_MOVE) {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveDrop);
                else {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveNoDrop);
                }
            }
        }

        public final void dropActionChanged(DragSourceDragEvent dsde) {
            int action = dsde.getDropAction();
            if(action == DnDConstants.ACTION_COPY) {
                dsde.getDragSourceContext().setCursor(
                        DragSource.DefaultCopyDrop);
            else {
                if(action == DnDConstants.ACTION_MOVE) {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveDrop);
                else {
                    dsde.getDragSourceContext().setCursor(
                            DragSource.DefaultMoveNoDrop);
                }
            }
        }

        public final void dragExit(DragSourceEvent dse) {
            dse.getDragSourceContext().setCursor(DragSource.DefaultMoveNoDrop);
        }

        /* Methods for DragGestureListener */
        public final void dragGestureRecognized(DragGestureEvent dge) {
            TreePath path = tree.getSelectionPath();
            if(path != null) {
                draggedNode = path.getLastPathComponent();
                if(drawImage) {
                    Rectangle pathBounds = tree.getPathBounds(path)// getpathbounds
                                                                        // of
                                                                        // selectionpath
                    JComponent lbl = (JComponenttree
                            .getCellRenderer()
                            .getTreeCellRendererComponent(
                                    tree,
                                    draggedNode,
                                    false,
                                    tree.isExpanded(path),
                                    tree.getModel() .isLeaf(path.getLastPathComponent()),
                                    0false);// returning the label
                    lbl.setBounds(pathBounds);// setting bounds to lbl
                    image = new BufferedImage(lbl.getWidth(), lbl.getHeight(),
                            java.awt.image.BufferedImage.TYPE_INT_ARGB_PRE);// buffered
                                                                            // image
                                                                            // reference
                                                                            // passing
                                                                            // the
                                                                            // label's
                                                                            // ht
                                                                            // and
                                                                            // width
                    Graphics2D graphics = image.createGraphics();// creating
                                                                    // the
                                                                    // graphics
                                                                    // for
                                                                    // buffered
                                                                    // image
                    graphics.setComposite(AlphaComposite.getInstance(
                            AlphaComposite.SRC_OVER, 0.5f))// Sets the
                                                                // Composite for
                                                                // the
                                                                // Graphics2D
                                                                // context
                    lbl.setOpaque(false);
                    lbl.paint(graphics)// painting the graphics to label
                    graphics.dispose();
                }
                dragSource.startDrag(dge, DragSource.DefaultMoveNoDrop, image,
                        new Point(00)new TransferableNode(draggedNode),
                        this);
            }
        }

        /* Methods for DropTargetListener */

        public final void dragEnter(DropTargetDragEvent dtde) {
            Point pt = dtde.getLocation();
            int action = dtde.getDropAction();
            if(drawImage) {
                paintImage(pt);
            }
            if(controller.canPerformAction(tree, draggedNode, action, pt)) {
                dtde.acceptDrag(action);
            else {
                dtde.rejectDrag();
            }
        }

        public final void dragExit(DropTargetEvent dte) {
            if(drawImage) {
                clearImage();
            }
        }

        public final void dragOver(DropTargetDragEvent dtde) {
            Point pt = dtde.getLocation();
            int action = dtde.getDropAction();
            autoscroll(tree, pt);
            if(drawImage) {
                paintImage(pt);
            }
            if(controller.canPerformAction(tree, draggedNode, action, pt)) {
                dtde.acceptDrag(action);
            else {
                dtde.rejectDrag();
            }
        }

        public final void dropActionChanged(DropTargetDragEvent dtde) {
            Point pt = dtde.getLocation();
            int action = dtde.getDropAction();
            if(drawImage) {
                paintImage(pt);
            }
            if(controller.canPerformAction(tree, draggedNode, action, pt)) {
                dtde.acceptDrag(action);
            else {
                dtde.rejectDrag();
            }
        }

        public final void drop(DropTargetDropEvent dtde) {
            try {
                if(drawImage) {
                    clearImage();
                }
                int action = dtde.getDropAction();
                Transferable transferable = dtde.getTransferable();
                Point pt = dtde.getLocation();
                if(transferable
                        .isDataFlavorSupported(NODE_FLAVOR)
                        && controller.canPerformAction(tree, draggedNode, action, pt)) {
                    TreePath pathTarget = tree.getPathForLocation(pt.x, pt.y);
                    Object node = transferable.getTransferData(NODE_FLAVOR);
                    Object newParentNode = pathTarget.getLastPathComponent();
                    if(controller.executeDrop(tree, node, newParentNode, action)) {
                        dtde.acceptDrop(action);
                        dtde.dropComplete(true);
                        return;
                    }
                }
                dtde.rejectDrop();
                dtde.dropComplete(false);
            catch(Exception e) {
                dtde.rejectDrop();
                dtde.dropComplete(false);
            }
        }

        private final void paintImage(Point pt) {
            tree.paintImmediately(rect2D.getBounds());
            rect2D.setRect((intpt.getX()(intpt.getY(), image.getWidth(),
                    image.getHeight());
            tree.getGraphics().drawImage(image, (intpt.getX(),
                    (intpt.getY(), tree);
        }

        private final void clearImage() {
            tree.paintImmediately(rect2D.getBounds());
        }
    }
    
    public static void configureDragAndDrop(JTree tree, JTreeDragController controller) {
        tree.setAutoscrolls(true);
        new TreeTransferHandler(tree, controller, DnDConstants.ACTION_COPY_OR_MOVE, true);
    }

    private static void autoscroll(JTree tree, Point cursorLocation) {
        Insets insets = DEFAULT_INSETS;
        Rectangle outer = tree.getVisibleRect();
        Rectangle inner = new Rectangle(outer.x + insets.left, outer.y
                + insets.top, outer.width - (insets.left + insets.right),
                outer.height - (insets.top + insets.bottom));
        if(!inner.contains(cursorLocation)) {
            Rectangle scrollRect = new Rectangle(cursorLocation.x
                    - insets.left, cursorLocation.y - insets.top,
                    insets.left + insets.right, insets.top + insets.bottom);
            tree.scrollRectToVisible(scrollRect);
        }
    }
}
/* Copyright (c) 2006, 2009, Carl Burch. License information is located in the
 * com.cburch.logisim.Main source code and at www.cburch.com/logisim/. */
 


/* This comes from "Denis" at http://forum.java.sun.com/thread.jspa?forumID=57&threadID=296255 */

/*
 * My program use 4 classes. The application displays two trees.
 * You can drag (move by default or copy with ctrl pressed) a node from the left tree to the right one, from the right to the left and inside the same tree.
 * The rules for moving are :
 *   - you can't move the root
 *   - you can't move the selected node to its subtree (in the same tree).
 *   - you can't move the selected node to itself (in the same tree).
 *   - you can't move the selected node to its parent (in the same tree).
 *   - you can move a node to anywhere you want according to the 4 previous rules.
 *  The rules for copying are :
 *   - you can copy a node to anywhere you want.
 *
 * In the implementation I used DnD version of Java 1.3 because in 1.4 the DnD is too restrictive :
 * you can't do what you want (displaying the image of the node while dragging, changing the cursor
 * according to where you are dragging, etc...). In 1.4, the DnD is based on the 1.3 version but
 * it is too encapsulated.
 */

interface JTreeDragController {
    public boolean canPerformAction(JTree target, Object draggedNode,
            int action, Point location);

    public boolean executeDrop(JTree tree, Object draggedNode,
            Object newParentNode, int action);
}

   
    
    
  
Related examples in the same category
1. Build a tree based on DefaultMutableTreeNodeBuild a tree based on DefaultMutableTreeNode
2. Add Tree to JScrollPaneAdd Tree to JScrollPane
3. Genealogy TreeGenealogy Tree
4. Tree LinesTree Lines
5. DefaultMutableTreeNode Node Tree SampleDefaultMutableTreeNode Node Tree Sample
6. Display a file system in a JTree viewDisplay a file system in a JTree view
7. JTree based Class BrowserJTree based Class Browser
8. Display Class in a TreeDisplay Class in a Tree
9. Edit a TreeEdit a Tree
10. implements TreeSelectionListener to create your own listenerimplements TreeSelectionListener  to create your own listener
11. File folder Tree with iconsFile folder Tree with icons
12. File Tree with Popup MenuFile Tree with Popup Menu
13. File Tree with TooltipsFile Tree with Tooltips
14. Ancestor Tree with IconsAncestor Tree with Icons
15. Tree Icon DemoTree Icon Demo
16. DefaultMutableTreeNode and user objectDefaultMutableTreeNode and user object
17. Display user object in a treeDisplay user object in a tree
18. Tree Expand Event DemoTree Expand Event Demo
19. Tree: Drag and DropTree: Drag and Drop
20. Tree open IconTree open Icon
21. Traverse TreeTraverse Tree
22. Tree based on Array structureTree based on Array structure
23. Tree will Expand event and listenerTree will Expand event and listener
24. Set the Tree LineSet the Tree Line
25. Tree Selection RowTree Selection Row
26. JTree.DynamicUtilTreeNode.createChildrenJTree.DynamicUtilTreeNode.createChildren
27. Install ToolTips for Tree (JTree)Install ToolTips for Tree (JTree)
28. Tree Expand Event Demo 2Tree Expand Event Demo 2
29. A tree with componentA tree with component
30. A sample component for dragging and dropping a collection of files into a tree.A sample component for dragging and dropping a collection of files into a tree.
31. DnD (drag and drop)JTree code DnD (drag and drop)JTree code
32. Build a tree and populate it from hashtablesBuild a tree and populate it from hashtables
33. A simple test to see how we can build a tree and populate itA simple test to see how we can build a tree and populate it
34. Installs custom iconsInstalls custom icons
35. Build a tree and customize its iconsBuild a tree and customize its icons
36. Displaying Hierarchical Data within a JTreeDisplaying Hierarchical Data within a JTree
37. Add and remove tree Node and expand the tree node
38. File System Tree
39. TreeExpansionListener and TreeExpansionEventTreeExpansionListener and TreeExpansionEvent
40. Enabling and Disabling Multiple Selections in a JTree Component
41. Allow only a single node to be selected (default)
42. Allow selection to span one vertical contiguous set of visible nodes
43. Allow multiple selections of visible nodes
44. Setting the Row Height of a JTree
45. All rows will be given 15 pixels of height
46. Have the row height for each row computed individually
47. Flush the internal cache of Row height
48. Preventing Expansion or Collapse of a Node in a JTree: override JTree.setExpandedState()
49. Removing a Node to a JTree Component
50. JTree root cannot be removed with removeNodeFromParent(), use DefaultTreeModel.setRoot() to remove the root
51. Listening for Expansion and Collapse Events in a JTree Component
52. Expansion and Collapse Events in a JTree are fired before a node is expanded or collapsed can be vetoed, thereby preventing the operation.
53. Creating a JTree Component
54. Changing and Removing the Default Icons in a JTree Component
55. Use UIManager to change the default icon for JTree
56. Getting the Selected Nodes in a JTree Component
57. Visiting All the Nodes in a JTree Component
58. Traverse all expanded nodes in tree
59. Finding a Node in a JTree Component
60. Search backward from last visible row looking for any visible node whose name starts with prefix.
61. Find the path regardless of visibility that matches the specified sequence of names
62. Adding a Node to a JTree Component
63. Returns a TreePath containing the specified node.
64. Converting All Nodes in a JTree Component to a TreePath Array
65. Get path for all expanded or not expanded tree pathes
66. Expanding or Collapsing All Nodes in a JTree Component
67. Preventing the Expansion or Collapse of a Node in a JTree Component
68. Listening for Selection Events in a JTree Component
69. Have a popup attached to a JTree
70. Deleting nodes from JTree
71. Adding editable nodes to JTree
72. Searching node in a JTree
73. Drag and drop of a group of files into a tree
74. Expand All for a tree path
75. Get tree path from TreeNode
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.