- java.lang.Object
-
- com.iamsoft.util.ui.swing.FileDrop
-
public class FileDrop extends Object
This class makes it easy to drag and drop files from the operating system to a Java program. Any java.awt.Component can be dropped onto, but only javax.swing.JComponents will indicate the drop event with a changed border.
To use this class, construct a new FileDrop by passing it the target component and a Listener to receive notification when file(s) have been dropped. Here is an example:
JPanel myPanel = new JPanel(); new FileDrop( myPanel, new FileDrop.Listener() { public void filesDropped( java.io.File[] files ) { // handle file drop ... } // end filesDropped }); // end FileDrop.Listener
You can specify the border that will appear when files are being dragged by calling the constructor with a javax.swing.border.Border. Only JComponents will show any indication with a border.
You can turn on some debugging features by passing a PrintStream object (such as System.out) into the full constructor. A null value will result in no extra debugging information being output.
I'm releasing this code into the Public Domain. Enjoy.
Original author: Robert Harder, rharder@usa.net
2007-09-12 Nathan Blomquist -- Linux (KDE/Gnome) support added.
- Version:
- 1.0.1
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
FileDrop.Event
This is the event that is passed to the FileDropListener#filesDropped filesDropped(...) method in yourFileDropListener
when files are dropped onto a registered drop target.static interface
FileDrop.Listener
Implement this inner interface to listen for when files are dropped.static class
FileDrop.TransferableObject
At last an easy way to encapsulate your custom objects for dragging and dropping in your Java programs! When you need to create aTransferable
object, use this class to wrap your object.
-
Constructor Summary
Constructors Constructor Description FileDrop(Component pC, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a default border and the option to recursively set drop targets.FileDrop(Component pC, FileDrop.Listener pListener)
FileDrop(Component pC, Border pDragBorder, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a specified border and the option to recursively set drop targets.FileDrop(Component pC, Border pDragBorder, FileDrop.Listener pListener)
Constructor with a specified border.FileDrop(PrintStream pOut, Component pC, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a default border, debugging optionally turned on and the option to recursively set drop targets.FileDrop(PrintStream pOut, Component pC, FileDrop.Listener pListener)
Constructor with a default border and debugging optionally turned on.FileDrop(PrintStream pOut, Component pC, Border pDragBorder, boolean pRecursive, FileDrop.Listener pListener)
Full constructor with a specified border and debugging optionally turned on.FileDrop(PrintStream pOut, Component pC, Border pDragBorder, FileDrop.Listener pListener)
Constructor with a specified border and debugging optionally turned on.
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static boolean
remove(Component pC)
Removes the drag-and-drop hooks from the component and optionally from the all children.static boolean
remove(PrintStream pOut, Component pC, boolean pRecursive)
Removes the drag-and-drop hooks from the component and optionally from the all children.
-
-
-
Constructor Detail
-
FileDrop
public FileDrop(Component pC, FileDrop.Listener pListener)
Constructs aFileDrop
with a default light-blue border and, ifpC
is aContainer
, recursively sets all elements contained within as drop targets, though only the top level container will change borders.- Parameters:
pC
- Component on which files will be dropped.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(Component pC, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a default border and the option to recursively set drop targets. If your component is a java.awt.Container, then each of its children components will also listen for drops, though only the parent will change borders.- Parameters:
pC
- Component on which files will be dropped.pRecursive
- Recursively set children as drop targets.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(PrintStream pOut, Component pC, FileDrop.Listener pListener)
Constructor with a default border and debugging optionally turned on. With Debugging turned on, more status messages will be displayed to out. A common way to use this constructor is with System.out or System.err. A null value for the parameter out will result in no debugging output.- Parameters:
pOut
- PrintStream to record debugging info or null for no debugging.pC
- Component on which files will be dropped.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(PrintStream pOut, Component pC, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a default border, debugging optionally turned on and the option to recursively set drop targets. If your component is a java.awt.Container, then each of its children components will also listen for drops, though only the parent will change borders. With Debugging turned on, more status messages will be displayed to out. A common way to use this constructor is with System.out or System.err. A null value for the parameter out will result in no debugging output.- Parameters:
pOut
- PrintStream to record debugging info or null for no debugging.pC
- Component on which files will be dropped.pRecursive
- Recursively set children as drop targets.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(Component pC, Border pDragBorder, FileDrop.Listener pListener)
Constructor with a specified border.- Parameters:
pC
- Component on which files will be dropped.pDragBorder
- Border to use on JComponent when dragging occurs.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(Component pC, Border pDragBorder, boolean pRecursive, FileDrop.Listener pListener)
Constructor with a specified border and the option to recursively set drop targets. If your component is a java.awt.Container, then each of its children components will also listen for drops, though only the parent will change borders.- Parameters:
pC
- Component on which files will be dropped.pDragBorder
- Border to use on JComponent when dragging occurs.pRecursive
- Recursively set children as drop targets.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(PrintStream pOut, Component pC, Border pDragBorder, FileDrop.Listener pListener)
Constructor with a specified border and debugging optionally turned on. With Debugging turned on, more status messages will be displayed to out. A common way to use this constructor is with System.out or System.err. A null value for the parameter out will result in no debugging output.- Parameters:
pOut
- PrintStream to record debugging info or null for no debugging.pC
- Component on which files will be dropped.pDragBorder
- Border to use on JComponent when dragging occurs.pListener
- Listens for filesDropped.- Since:
- 1.0
-
FileDrop
public FileDrop(PrintStream pOut, Component pC, Border pDragBorder, boolean pRecursive, FileDrop.Listener pListener)
Full constructor with a specified border and debugging optionally turned on. With Debugging turned on, more status messages will be displayed to out. A common way to use this constructor is with System.out or System.err. A null value for the parameter out will result in no debugging output.- Parameters:
pOut
- PrintStream to record debugging info or null for no debugging.pC
- Component on which files will be dropped.pDragBorder
- Border to use on JComponent when dragging occurs.pRecursive
- Recursively set children as drop targets.pListener
- Listens for filesDropped.- Since:
- 1.0
-
-
Method Detail
-
remove
public static boolean remove(Component pC)
Removes the drag-and-drop hooks from the component and optionally from the all children. You should call this if you add and remove components after you've set up the drag-and-drop. This will recursively unregister all components contained withinpC
ifpC
is aContainer
.- Parameters:
pC
- The component to unregister as a drop target- Since:
- 1.0
-
remove
public static boolean remove(PrintStream pOut, Component pC, boolean pRecursive)
Removes the drag-and-drop hooks from the component and optionally from the all children. You should call this if you add and remove components after you've set up the drag-and-drop.- Parameters:
pOut
- OptionalPrintStream
for logging drag and drop messagespC
- The component to unregisterpRecursive
- Recursively unregister components within a container- Since:
- 1.0
-
-