Module java.desktop
Package java.awt.dnd

Class DropTargetDragEvent

All Implemented Interfaces:
Serializable

public class DropTargetDragEvent
extends DropTargetEvent
The DropTargetDragEvent is delivered to a DropTargetListener via its dragEnter() and dragOver() methods.

The DropTargetDragEvent reports the source drop actions and the user drop action that reflect the current state of the drag operation.

Source drop actions is a bitwise mask of DnDConstants that represents the set of drop actions supported by the drag source for this drag operation.

User drop action depends on the drop actions supported by the drag source and the drop action selected by the user. The user can select a drop action by pressing modifier keys during the drag operation:

   Ctrl + Shift -> ACTION_LINK
   Ctrl         -> ACTION_COPY
   Shift        -> ACTION_MOVE
 
If the user selects a drop action, the user drop action is one of DnDConstants that represents the selected drop action if this drop action is supported by the drag source or DnDConstants.ACTION_NONE if this drop action is not supported by the drag source.

If the user doesn't select a drop action, the set of DnDConstants that represents the set of drop actions supported by the drag source is searched for DnDConstants.ACTION_MOVE, then for DnDConstants.ACTION_COPY, then for DnDConstants.ACTION_LINK and the user drop action is the first constant found. If no constant is found the user drop action is DnDConstants.ACTION_NONE.

Since:
1.2
See Also:
Serialized Form
  • Constructor Details

    • DropTargetDragEvent

      public DropTargetDragEvent​(DropTargetContext dtc, Point cursorLocn, int dropAction, int srcActions)
      Construct a DropTargetDragEvent given the DropTargetContext for this operation, the location of the "Drag" Cursor's hotspot in the Component's coordinates, the user drop action, and the source drop actions.
      Parameters:
      dtc - The DropTargetContext for this operation
      cursorLocn - The location of the "Drag" Cursor's hotspot in Component coordinates
      dropAction - The user drop action
      srcActions - The source drop actions
      Throws:
      NullPointerException - if cursorLocn is null
      IllegalArgumentException - if dropAction is not one of DnDConstants.
      IllegalArgumentException - if srcActions is not a bitwise mask of DnDConstants.
      IllegalArgumentException - if dtc is null.
  • Method Details

    • getLocation

      public Point getLocation()
      This method returns a Point indicating the Cursor's current location within the Component's coordinates.
      Returns:
      the current cursor location in Component's coords.
    • getCurrentDataFlavors

      public DataFlavor[] getCurrentDataFlavors()
      This method returns the current DataFlavors from the DropTargetContext.
      Returns:
      current DataFlavors from the DropTargetContext
    • getCurrentDataFlavorsAsList

      public List<DataFlavor> getCurrentDataFlavorsAsList()
      This method returns the current DataFlavors as a java.util.List
      Returns:
      a java.util.List of the Current DataFlavors
    • isDataFlavorSupported

      public boolean isDataFlavorSupported​(DataFlavor df)
      This method returns a boolean indicating if the specified DataFlavor is supported.
      Parameters:
      df - the DataFlavor to test
      Returns:
      if a particular DataFlavor is supported
    • getSourceActions

      public int getSourceActions()
      This method returns the source drop actions.
      Returns:
      the source drop actions
    • getDropAction

      public int getDropAction()
      This method returns the user drop action.
      Returns:
      the user drop action
    • getTransferable

      public Transferable getTransferable()
      This method returns the Transferable object that represents the data associated with the current drag operation.
      Returns:
      the Transferable associated with the drag operation
      Throws:
      InvalidDnDOperationException - if the data associated with the drag operation is not available
      Since:
      1.5
    • acceptDrag

      public void acceptDrag​(int dragOperation)
      Accepts the drag. This method should be called from a DropTargetListeners dragEnter, dragOver, and dropActionChanged methods if the implementation wishes to accept an operation from the srcActions other than the one selected by the user as represented by the dropAction.
      Parameters:
      dragOperation - the operation accepted by the target
    • rejectDrag

      public void rejectDrag()
      Rejects the drag as a result of examining either the dropAction or the available DataFlavor types.