TransferHandler subclass wraps another TransferHandler and delegates most of its operations to the wrapped handler : 拖放 « 图形用户界面 « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » 图形用户界面 » 拖放屏幕截图 
TransferHandler subclass wraps another TransferHandler and delegates most of its operations to the wrapped handler
 
 
/*
 * Copyright (c) 2004 David Flanagan.  All rights reserved.
 * This code is from the book Java Examples in a Nutshell, 3nd Edition.
 * It is provided AS-IS, WITHOUT ANY WARRANTY either expressed or implied.
 * You may study, use, and modify it for any non-commercial purpose,
 * including teaching and use in open-source projects.
 * You may distribute it non-commercially as long as you retain this notice.
 * For a commercial use license, or to purchase the book, 
 * please visit http://www.davidflanagan.com/javaexamples3.
 */

import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.StringSelection;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.awt.event.InputEvent;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;
import java.util.List;

import javax.swing.Icon;
import javax.swing.JComponent;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import javax.swing.TransferHandler;

/**
 * This TransferHandler subclass wraps another TransferHandler and delegates
 * most of its operations to the wrapped handler. It adds the ability to to drop
 * or paste files using the predefined DataFlavor.javaFileListFlavor. When a
 * file list is pasted or dropped, it assumes the files are text, reads them in
 * order, concatenates their contents, and then passes the resulting string to
 * the wrapped handler for insertion.
 */
public class FileTransferHandler extends TransferHandler {
  TransferHandler wrappedHandler; // The handler that we wrap

  // We use this array to test the wrapped handler
  static DataFlavor[] stringFlavorArray = new DataFlavor[] { DataFlavor.stringFlavor };

  /** Pass an existing TransferHandler to this constructor */
  public FileTransferHandler(TransferHandler wrappedHandler) {
    if (wrappedHandler == null// Fail immediately on null
      throw new NullPointerException();
    this.wrappedHandler = wrappedHandler; // Remember wrapped handler
  }

  /**
   * This method returns true if the TransferHandler knows how to work with one
   * of the specified flavors. This implementation first checks the superclass,
   * then checks for fileListFlavor support
   */
  public boolean canImport(JComponent c, DataFlavor[] flavors) {
    // If the wrapped handler can import it, we're done
    if (wrappedHandler.canImport(c, flavors))
      return true;

    // Otherwise, if the wrapped handler can handle string imports, then
    // see if we are being offered a list of files that we can convert
    // to a string.
    if (wrappedHandler.canImport(c, stringFlavorArray)) {
      for (int i = 0; i < flavors.length; i++)
        if (flavors[i].equals(DataFlavor.javaFileListFlavor))
          return true;
    }

    // Otherwise, we can't import any of the flavors.
    return false;
  }

  /**
   * If the wrapped handler can import strings and the specified Transferable
   * can provide its data as a List of File objects, then we read the files, and
   * pass their contents as a string to the wrapped handler. Otherwise, we offer
   * the Transferable to the wrapped handler to handle on its own.
   */
  public boolean importData(JComponent c, Transferable t) {
    // See if we're offered a java.util.List of java.io.File objects.
    // We handle this case first because the Transferable is likely to
    // also offer the filenames as strings, and we want to import the
    // file contents, not their names!
    if (t.isDataFlavorSupported(DataFlavor.javaFileListFlavor)
        && wrappedHandler.canImport(c, stringFlavorArray)) {
      try {
        List filelist = (Listt.getTransferData(DataFlavor.javaFileListFlavor);

        // Loop through the files to determine total size
        int numfiles = filelist.size();
        int numbytes = 0;
        for (int i = 0; i < numfiles; i++) {
          File f = (Filefilelist.get(i);
          numbytes += (intf.length();
        }

        // There will never be more characters than bytes in the files
        char[] text = new char[numbytes]// to hold file contents
        int p = 0// current position in the text[] array

        // Loop through the files again, reading their content as text
        for (int i = 0; i < numfiles; i++) {
          File f = (Filefilelist.get(i);
          Reader r = new BufferedReader(new FileReader(f));
          p += r.read(text, p, (intf.length());
        }

        // Convert the character array to a string and wrap it
        // in a pre-defined Transferable class for transferring strings
        StringSelection selection = new StringSelection(new String(text, 0, p));

        // Ask the wrapped handler to import the string
        return wrappedHandler.importData(c, selection);
      }
      // If anything goes wrong, just beep to tell the user
      catch (UnsupportedFlavorException e) {
        c.getToolkit().beep()// audible error
        return false// return failure code
      catch (IOException e) {
        c.getToolkit().beep()// audible error
        return false// return failure code
      }
    }

    // Otherwise let the wrapped class handle this transferable itself
    return wrappedHandler.importData(c, t);
  }

  /*
   * The following methods just delegate to the wrapped TransferHandler
   */
  public void exportAsDrag(JComponent c, InputEvent e, int action) {
    wrappedHandler.exportAsDrag(c, e, action);
  }

  public void exportToClipboard(JComponent c, Clipboard clip, int action) {
    wrappedHandler.exportToClipboard(c, clip, action);
  }

  public int getSourceActions(JComponent c) {
    return wrappedHandler.getSourceActions(c);
  }

  public Icon getVisualRepresentation(Transferable t) {
    // This method is not currently (Java 1.4) used by Swing
    return wrappedHandler.getVisualRepresentation(t);
  }

  /**
   * This class demonstrates the FileTransferHandler by installing it on a
   * JTextArea component and providing a JFileChooser to drag and cut files.
   */

  public static void main(String[] args) {
    // Here's the text area. Note how we wrap our TransferHandler
    // around the default handler returned by getTransferHandler()
    JTextArea textarea = new JTextArea();
    TransferHandler defaultHandler = textarea.getTransferHandler();
    textarea.setTransferHandler(new FileTransferHandler(defaultHandler));
    // Here's a JFileChooser, with dragging explicitly enabled.
    JFileChooser filechooser = new JFileChooser();
    filechooser.setDragEnabled(true);

    // Display them both in a window
    JFrame f = new JFrame("File Transfer Handler Test");
    f.getContentPane().add(new JScrollPane(textarea)"Center");
    f.getContentPane().add(filechooser, "South");
    f.setSize(400600);
    f.setVisible(true);
  }

}

   
  
Related examples in the same category
1. 树:拖放树:拖放
2. 拖放拖放
3. 添加图像拖拽行为
4. 拖拽文件拖拽文件
5. 展示各种界面数据传输展示各种界面数据传输
6. DragSource Test DragSource Test
7. DropTarget Test DropTarget Test
8. 图像传输试验图像传输试验
9. MimeClipboard试验MimeClipboard试验
10. 文件树拖拽目标文件树拖拽目标
11. 文件树拖曳来源文件树拖曳来源
12. 编辑器拖曳目标4编辑器拖曳目标4
13. 拖曳树拖曳树
14. JLabel Drag Source JLabel Drag Source
15. 拖拽面板拖拽面板
16. 编辑器拖拽目标3编辑器拖拽目标3
17. 编辑器拖拽目标编辑器拖拽目标
18. 编辑器拖拽目标2编辑器拖拽目标2
19. JTextArea类允许TransferableColor对象JTextArea类允许TransferableColor对象
20. 转让彩色
21. 彩色拖曳来源
22. 组件拖放文件到树组件拖放文件到树
23. 试验DragGesture类和JList试验DragGesture类和JList
24. TransferHandler和JTextAreaTransferHandler和JTextArea
25. 拖放:文本拖放:文本
26. 拖曳:JList拖曳:JList
27. JDK 1.4组件拖放JDK 1.4组件拖放
28. 拖放: JList和列表框拖放: JList和列表框
29. DnD (drag and drop)JTree code DnD (drag and drop)JTree code
30. 下拉:文本下拉:文本
31. 拖放:文本2拖放:文本2
32. Label DnD (Drag and Drop) Label DnD (Drag and Drop)
33. LabelDnD2允许颜色拖拽LabelDnD2允许颜色拖拽
34. Drag List Demo Drag List Demo
35. Drag Picture Demo
36. 拖拽演示拖拽演示
37. 拖动颜色演示拖动颜色演示
38. 拖动文件演示拖动文件演示
39. Drag Picture Demo 2
40. 拖动TextField的颜色演示拖动TextField的颜色演示
41. BasicDnD (拖拽)BasicDnD (拖拽)
42. 拖放图标:使用一个图标属性。
43. 执行拖放功能
44. 在应用程序探测拖动发起的姿态
45. 制作组件拖动
46. 使用和设置文字系统剪贴板
47. 使用拖放以重新排序清单
48. 创建一个拖曳源来拖拽对象。
49. 实施DragGestureListener
50. 逗号分隔的文本将插入到两个或两个以上的列。
51. 在JTextArea设置文本拖放
52. 内置拖放支持:利用TransferHandler类
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.