javax.swing
Class TransferHandler
- Serializable
clone , equals , extends Object> getClass , finalize , hashCode , notify , notifyAll , toString , wait , wait , wait |
COPY
public static final int COPY
MOVE
public static final int MOVE
NONE
public static final int NONE
canImport
public boolean canImport(JComponent c,
DataFlavor[] flavors)
Returns
true
if the data in this TransferHandler can be
imported into the specified component. This will be the case when:
- The component has a readable and writable property with the property
name specified in the TransferHandler constructor.
- There is a dataflavor with a mime type of
application/x-java-jvm-local-object-ref
. - The dataflavor's representation class matches the class of the
property in the component.
c
- the component to checkflavors
- the possible data flavors
true
if the data in this TransferHandler can be
imported into the specified component, false
otherwise
createTransferable
protected Transferable createTransferable(JComponent c)
Creates a
Transferable
that can be used to export data
from the specified component.
This method returns
null
when the specified component
doesn't have a readable property that matches the property name
specified in the
TransferHandler
constructor.
c
- the component to create a transferable for
- a
Transferable
that can be used to export data
from the specified component, or null if the component doesn't
have a readable property like the transfer handler
exportDone
protected void exportDone(JComponent c,
Transferable data,
int action)
This method is invoked after data has been exported.
Subclasses should implement this method to remove the data that has been
transferred when the action was MOVE
.
The default implementation does nothing because MOVE is not supported.
c
- the source componentdata
- the data that has been transferred or null
when the action is NONEaction
- the action that has been performed
exportToClipboard
public void exportToClipboard(JComponent c,
Clipboard clip,
int action)
throws IllegalStateException
Exports the property of the component
c
that was
specified for this TransferHandler to the clipboard, performing
the specified action.
This will check if the action is allowed by calling
getSourceActions(JComponent)
. If the action is not allowed,
then no export is performed.
In either case the method
exportDone(JComponent,Transferable,int)
will be called with
the action that has been performed, or
NONE
if the action
was not allowed or could otherwise not be completed.
Any IllegalStateException that is thrown by the Clipboard due to
beeing unavailable will be propagated through this method.
c
- the component from which to exportclip
- the clipboard to which the data will be exportedaction
- the action to perform
importData
public boolean importData(JComponent c,
Transferable t)
Imports the transfer data represented by t
into the specified
component c
by setting the property of this TransferHandler
on that component. If this succeeds, this method returns
true
, otherwise false
.
c
- the component to import intot
- the transfer data to import
true
if the transfer succeeds, false
otherwise
TransferHandler.java --
Copyright (C) 2004, 2005, 2006, Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version.