| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjavax.swing.TransferHandler.TransferSupport
public static final class TransferHandler.TransferSupport
This class encapsulates all relevant details of a clipboard or drag and drop transfer, and also allows for customizing aspects of the drag and drop experience.
The main purpose of this class is to provide the information needed by a developer to determine the suitability of a transfer or to import the data contained within. But it also doubles as a controller for customizing properties during drag and drop, such as whether or not to show the drop location, and which drop action to use.
 Developers typically need not create instances of this
 class. Instead, they are something provided by the DnD
 implementation to certain methods in TransferHandler.
TransferHandler.canImport(TransferHandler.TransferSupport), 
TransferHandler.importData(TransferHandler.TransferSupport)| Constructor Summary | |
|---|---|
| TransferHandler.TransferSupport(Component component,
                                Transferable transferable)Create a TransferSupportwithisDrop()falsefor the given component andTransferable. | |
| Method Summary | |
|---|---|
|  Component | getComponent()Returns the target component of this transfer. | 
|  DataFlavor[] | getDataFlavors()Returns the data flavors for this transfer. | 
|  int | getDropAction()Returns the action chosen for the drop, when this TransferSupportrepresents a drop. | 
|  TransferHandler.DropLocation | getDropLocation()Returns the current (non- null) drop location for the component,
 when thisTransferSupportrepresents a drop. | 
|  int | getSourceDropActions()Returns the drag source's supported drop actions, when this TransferSupportrepresents a drop. | 
|  Transferable | getTransferable()Returns the Transferableassociated with this transfer. | 
|  int | getUserDropAction()Returns the user drop action for the drop, when this TransferSupportrepresents a drop. | 
|  boolean | isDataFlavorSupported(DataFlavor df)Returns whether or not the given data flavor is supported. | 
|  boolean | isDrop()Returns whether or not this TransferSupportrepresents a drop operation. | 
|  void | setDropAction(int dropAction)Sets the drop action for the transfer - which must represent a drop - to the given action, instead of the default user drop action. | 
|  void | setShowDropLocation(boolean showDropLocation)Sets whether or not the drop location should be visually indicated for the transfer - which must represent a drop. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public TransferHandler.TransferSupport(Component component,
                                       Transferable transferable)
TransferSupport with isDrop()
 false for the given component and
 Transferable.
component - the target componenttransferable - the transferable
NullPointerException - if either parameter
         is null| Method Detail | 
|---|
public boolean isDrop()
TransferSupport
 represents a drop operation.
true if this is a drop operation,
         false otherwise.public Component getComponent()
public TransferHandler.DropLocation getDropLocation()
null) drop location for the component,
 when this TransferSupport represents a drop.
 
 Note: For components with built-in drop support, this location
 will be a subclass of DropLocation of the same type
 returned by that component's getDropLocation method.
 
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
IllegalStateException - if this is not a dropisDroppublic void setShowDropLocation(boolean showDropLocation)
TransferHandler has said it can accept the import represented
 by this TransferSupport. With this method you can force the
 drop location to always be shown, or always not be shown.
 
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
showDropLocation - whether or not to indicate the drop location
IllegalStateException - if this is not a dropisDroppublic void setDropAction(int dropAction)
COPY, MOVE or LINK.
 
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
dropAction - the drop action
IllegalStateException - if this is not a drop
IllegalArgumentException - if an invalid action is specifiedgetDropAction(), 
getUserDropAction(), 
getSourceDropActions(), 
isDroppublic int getDropAction()
TransferSupport represents a drop.
 
 Unless explicitly chosen by way of setDropAction,
 this returns the user drop action provided by
 getUserDropAction.
 
 You may wish to query this in TransferHandler's
 importData method to customize processing based
 on the action.
 
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
IllegalStateException - if this is not a dropsetDropAction(int), 
getUserDropAction(), 
isDroppublic int getUserDropAction()
TransferSupport represents a drop.
 
 The user drop action is chosen for a drop as described in the
 documentation for DropTargetDragEvent and
 DropTargetDropEvent. A different action
 may be chosen as the drop action by way of the setDropAction
 method.
 
 You may wish to query this in TransferHandler's
 canImport method when determining the suitability of a
 drop or when deciding on a drop action to explicitly choose.
 
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
IllegalStateException - if this is not a dropsetDropAction(int), 
getDropAction(), 
isDroppublic int getSourceDropActions()
TransferSupport represents a drop.
 
 The source actions represent the set of actions supported by the
 source of this transfer, and are represented as some bitwise-OR
 combination of COPY, MOVE and LINK.
 You may wish to query this in TransferHandler's
 canImport method when determining the suitability of a drop
 or when deciding on a drop action to explicitly choose. To determine
 if a particular action is supported by the source, bitwise-AND
 the action with the source drop actions, and then compare the result
 against the original action. For example:
 
boolean copySupported = (COPY & getSourceDropActions()) == COPY;
 This method is only for use with drag and drop transfers.
 Calling it when isDrop() is false results
 in an IllegalStateException.
IllegalStateException - if this is not a dropisDroppublic DataFlavor[] getDataFlavors()
public boolean isDataFlavorSupported(DataFlavor df)
df - the DataFlavor to test
public Transferable getTransferable()
Transferable associated with this transfer.
 
 Note: Unless it is necessary to fetch the Transferable
 directly, use one of the other methods on this class to inquire about
 the transfer. This may perform better than fetching the
 Transferable and asking it directly.
Transferable associated with this transfer| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
Copyright 2006 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.