- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 JTree,我想将一些文件从 JTree 导出到资源管理器。为此,我使用了 TransferHandler
和 flavor:DataFlavor.javaFileListFlavor
。这样,资源管理器就可以导入拖动的文件。问题是我的文件在服务器上,当可传输对象放在资源管理器上时我需要下载它们。
当文件放在资源管理器上时,如何启动我的下载方法?我如何知道我放置的文件的目标文件夹?
这里是一个示例:
import java.awt.BorderLayout;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import javax.swing.BorderFactory;
import javax.swing.DropMode;
import javax.swing.JComponent;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import javax.swing.TransferHandler;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.TreePath;
import javax.swing.tree.TreeSelectionModel;
public class JTreeDnDSample extends JFrame
{
protected JTree _tree;
private DefaultTreeModel treeModel;
private DefaultMutableTreeNode rootNode;
private JScrollPane border;
public static void main(String[] args)
{
new JTreeDnDSample().setVisible(true);
}
public JTreeDnDSample()
{
super("Dnd");
initializeTree();
this.setLayout(new BorderLayout());
border = new JScrollPane(this._tree);
border.setBorder(BorderFactory.createTitledBorder("Tree"));
this.add(border, BorderLayout.CENTER);
this.setSize(400, 800);
}
protected void initializeTree()
{
this.rootNode = new DefaultMutableTreeNode("Root folder");
this.treeModel = new DefaultTreeModel(rootNode);
_tree = new JTree(treeModel);
_tree.setName("TREE");
_tree.setDragEnabled(true);
_tree.setDropMode(DropMode.ON_OR_INSERT);
_tree.setTransferHandler(new TreeTransferHandler());
_tree.setShowsRootHandles(true);
_tree.getSelectionModel().setSelectionMode(TreeSelectionModel.DISCONTIGUOUS_TREE_SELECTION);
_tree.setRowHeight(26);
//tree creation
DefaultMutableTreeNode folder = new DefaultMutableTreeNode("folder1");
DefaultMutableTreeNode file = new DefaultMutableTreeNode("file1.txt");
folder.add(file);
file = new DefaultMutableTreeNode("file2.txt");
folder.add(file);
rootNode.add(folder);
folder = new DefaultMutableTreeNode("folder2");
file = new DefaultMutableTreeNode("file1.txt");
folder.add(file);
file = new DefaultMutableTreeNode("file2.txt");
folder.add(file);
file = new DefaultMutableTreeNode("file3.txt");
folder.add(file);
rootNode.add(folder);
}
public void setTitle(String title)
{
border.setBorder(BorderFactory.createTitledBorder(title));
}
}
class TreeTransferHandler extends TransferHandler
{
private DataFlavor nodesFlavor;
private DataFlavor[] flavors = new DataFlavor[1];
private DefaultMutableTreeNode[] nodesToRemove;
public TreeTransferHandler()
{
super();
try
{
String mimeType = DataFlavor.javaJVMLocalObjectMimeType +
";class=\"" +
DefaultMutableTreeNode[].class.getName() +
"\"";
nodesFlavor = new DataFlavor(mimeType);
flavors[0] = nodesFlavor;
}
catch(ClassNotFoundException e)
{
System.out.println("ClassNotFound: " + e.getMessage());
}
}
public boolean importData(TransferHandler.TransferSupport support)
{
Transferable data = support.getTransferable();
if(!canImport(support))
{
return false;
}
// Extract transfer data.
List<DefaultMutableTreeNode> nodes = new ArrayList<DefaultMutableTreeNode>();
try
{
System.out.println("IMPORT DATA");
nodes = (List<DefaultMutableTreeNode>) data.getTransferData(nodesFlavor);
/*List<File> files = (List<File>)data.getTransferData(DataFlavor.javaFileListFlavor);
System.out.println("File size: " + nodes.size());
for(File f : files)
{
System.out.println("File: "+f.getName());
}*/
}
catch(UnsupportedFlavorException ufe)
{
System.out.println("UnsupportedFlavor: " + ufe.getMessage());
}
catch(java.io.IOException ioe)
{
System.out.println("I/O error: " + ioe.getMessage());
}
catch(Exception e)
{
e.printStackTrace();
}
// Get drop location info inside the tree.
JTree.DropLocation dl =
(JTree.DropLocation)support.getDropLocation();
int childIndex = dl.getChildIndex();
TreePath dest = dl.getPath();
DefaultMutableTreeNode parent = (DefaultMutableTreeNode)dest.getLastPathComponent();
JTree tree = (JTree)support.getComponent();
DefaultTreeModel model = (DefaultTreeModel)tree.getModel();
// Configure for drop mode.
int index = childIndex; // DropMode.INSERT
if(childIndex == -1) // DropMode.ON
index = parent.getChildCount();
// Add data to model.
for(int i = 0; i < nodes.size(); i++)
{
model.insertNodeInto(nodes.get(i), parent, index++);
}
// Remove nodes saved in nodesToRemove in createTransferable.
for(int i = 0; i < nodesToRemove.length; i++)
{
model.removeNodeFromParent(nodesToRemove[i]);
}
return true;
}
public boolean canImport(TransferHandler.TransferSupport support)
{
if(!support.isDrop())
return false;
support.setShowDropLocation(true);
if(!support.isDataFlavorSupported(DataFlavor.javaFileListFlavor)
&& !support.isDataFlavorSupported(nodesFlavor))
return false;
// Do not allow a drop on the drag source selections.
JTree.DropLocation dl = (JTree.DropLocation)support.getDropLocation();
JTree tree = (JTree)support.getComponent();
int dropRow = tree.getRowForPath(dl.getPath());
int[] selRows = tree.getSelectionRows();
if(selRows != null)
{
for(int i = 0; i < selRows.length; i++)
{
if(selRows[i] == dropRow)
return false;
}
}
//Do not allow a drop on a File (leaf)
try
{
TreePath targetPath = tree.getDropLocation().getPath();
DefaultMutableTreeNode node = (DefaultMutableTreeNode) targetPath.getLastPathComponent();
if(node.isLeaf())
{
return false;
}
}
catch(Exception ex)
{
System.out.println(ex.getMessage());
return false;
}
// Do not allow a non-leaf node to be copied to a level
// which is less than its source level.
TreePath dest = dl.getPath();
DefaultMutableTreeNode target = (DefaultMutableTreeNode)dest.getLastPathComponent();
TreePath path = tree.getPathForRow(selRows[0]);
DefaultMutableTreeNode firstNode = (DefaultMutableTreeNode)path.getLastPathComponent();
if(firstNode.getChildCount() > 0 && target.getLevel() < firstNode.getLevel())
{
return false;
}
return true;
}
//Do i have to use exportDone ?
protected void exportDone(JComponent source, Transferable data, int action)
{
if((action & MOVE) == MOVE)
{
//GET THE FILE DESTINATION FOLDER
//LAUNCH THE DOWNLOAD FILE PROCESS
}
}
protected Transferable createTransferable(JComponent c)
{
JTree tree = (JTree)c;
TreePath[] paths = tree.getSelectionPaths();
if(paths != null)
{
// Make up a node array of copies for transfer and
// another for/of the nodes that will be removed in
// exportDone after a successful drop.
ArrayList<DefaultMutableTreeNode> copies = new ArrayList<DefaultMutableTreeNode>();
ArrayList<DefaultMutableTreeNode> toRemove = new ArrayList<DefaultMutableTreeNode>();
//Fake files created in order to allow the export on explorer
ArrayList<File> fakeFiles = new ArrayList<File>();
DefaultMutableTreeNode node = (DefaultMutableTreeNode)paths[0].getLastPathComponent();
DefaultMutableTreeNode copy = copy(node);
copies.add(copy);
toRemove.add(node);
for(int i = 1; i < paths.length; i++)
{
DefaultMutableTreeNode next = (DefaultMutableTreeNode)paths[i].getLastPathComponent();
// Do not allow higher level nodes to be added to list.
if(next.getLevel() < node.getLevel())
{
break;
}
else if(next.getLevel() > node.getLevel())
{ // child node
copy.add(copy(next));
// node already contains child
}
else
{ // sibling
copies.add(copy(next));
toRemove.add(next);
}
}
DefaultMutableTreeNode[] nodesToMove = copies.toArray(new DefaultMutableTreeNode[copies.size()]);
for(DefaultMutableTreeNode n : nodesToMove)
{
File f = new File(n.toString());
fakeFiles.add(f);
}
nodesToRemove = toRemove.toArray(new DefaultMutableTreeNode[toRemove.size()]);
return new NodesTransferable(fakeFiles, Arrays.asList(nodesToMove));
}
return null;
}
/** Defensive copy used in createTransferable. */
private DefaultMutableTreeNode copy(DefaultMutableTreeNode node)
{
return new DefaultMutableTreeNode(node);
}
public int getSourceActions(JComponent c)
{
return COPY_OR_MOVE;
}
public class NodesTransferable implements Transferable
{
private List<File> data = null;
private List<DefaultMutableTreeNode> nodes = null;
private DataFlavor[] flavors = new DataFlavor[2];
public NodesTransferable(final List<File> data, final List<DefaultMutableTreeNode> nodes)
{
super();
this.data = data;
this.nodes = nodes;
flavors[0] = DataFlavor.javaFileListFlavor;
flavors[1] = nodesFlavor;
}
public DataFlavor[] getTransferDataFlavors()
{
return flavors;
}
public boolean isDataFlavorSupported(final DataFlavor flavor)
{
return true;
}
public List<?> getTransferData(final DataFlavor flavor) throws UnsupportedFlavorException, IOException
{
if(flavor.equals(DataFlavor.javaFileListFlavor))
return data;
else if(flavor.equals(nodesFlavor))
return nodes;
else
{
System.out.println("Unsuported flavor");
return null;
}
}
}
}
最佳答案
我可能弄错了,但我不认为 Java 客户端无论如何都知道丢弃发生在 JVM 之外。我相信拖放的约定是每个客户端(程序)负责在开始拖放时推出数据,并在发生拖放时拉取数据。您需要查看资源管理器中是否有一个库来通知您这次掉落。
上网查了一下,好像是这个例子:http://www.codeproject.com/Articles/591/Drag-And-Drop-between-JList-and-Windows-Explorer展示了如何在 JList 和资源管理器之间执行此操作。请注意,我还没有机会尝试看看它是否有效。看起来有一个 DataFlavor:
DataFlavor.javaFileListFlavor
这是另一篇描述类似内容的文章:Swing application -> Drag & drop to the desktop / folder
关于java - 拖放 : Operation while dropping a file from a component to the explorer, 取景器等,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8353132/
我想知道是否可以访问放在 tomcat 的 conf 文件夹中的文件。通常我会在这个文件中放置多个 webapp 的配置,在 war 之外。 我想使用类路径独立于文件系统。 我过去使用过 lib 文件
我有一个 PowerShell 脚本,它获取文件列表并移动满足特定条件的文件。为什么即使对象为空,foreach 循环也会运行? 我假设如果 $i 不存在,它就不会运行。但是如果 $filePath
我已将 BasicAccountRule.drl 放置在我的 Web 应用程序中,位置为:C:/workspace/exim_design/src/main/resources/rules/drl/i
我使用 File.open('file.txt').class 和 File.open('file.txt').readlines.class 以及前者进行了检查一个返回 File,后者返回 Arra
我正在尝试使用 FileOutputStream 删除文件,在其中写入内容后。这是我用来编写的代码: private void writeContent(File file, String fileC
我正在尝试使用 flink 和 python 批处理 api 测试 Wordcount 经典示例。我的问题是,将数据源从 env.from_elements() 修改为 env.read_text()
我正在尝试制作一个可以同时处理多个不同文件的程序。我的想法是制作一个包含 20 个 FILE* 的数组,以便在我达到此限制时能够关闭其中一个并打开请求的新文件。 为此,我想到了一个函数,它选择一个选项
我有两个文件A和B文件A: 976464 792992 文件B TimeStamp,Record1,976464,8383,ABCD 我想搜索文件 A 和文件 B 中的每条记录并打印匹配的记录。打印的
我有一些保存在 map 中的属性文件。示例: Map map = new HashMap<>(); map.put("1", "One"); map.put("2", "Two"); map.put(
我正在尝试找出一个脚本文件,该文件接受一个包含文件列表的文件(每一行都是一个文件路径,即 path/to/file)并将它们合并到一个文件中。 例如: list.text -- path/to/fil
为了使用 File.CreateText() 和 File.AppendText() 你必须: 通过调用这些方法之一打开流 写消息 关闭流 处理流 为了使用 File.AppendAllText()
使用rsync时,如何在使用--files-from参数复制时重命名文件?我有大约190,000个文件,在从源复制到目标时,每个文件都需要重命名。我计划将文件列表放在一个文本文件中传递给--files
我在非服务器应用程序中使用 Spring(只需从 Eclipse 中某个类的 main() 编译并运行它)。 我的问题是作为 new FileSystemXmlApplicationContext 的
QNX (Neutrino 6.5.0) 使用 ksh 的开源实现作为其 shell 。许多提供的脚本,包括系统启动脚本,都使用诸如 if ! test /dev/slog -ef /dev/slog
当我尝试打开从我的应用程序下载的 xls 文件时,出现此错误: excel cannot open the file because the file format or file extension
有一些相关的概念,即文件指针、流和文件描述符。 我知道文件指针是指向数据类型 FILE 的指针(在例如 FILE.h 和 struct_FILE.h 中声明)。 我知道文件描述符是 int ,例如成员
好吧,这应该很容易... 我是groovy的新手,我希望实现以下逻辑: def testFiles = findAllTestFiles(); 到目前为止,我想出了下面的代码,该代码可以成功打印所有文
我理解为什么以下内容会截断文件的内容: Get-Content | Out-File 这是因为 Out-File 首先运行,它会在 Get-Content 有机会读取文件之前清空文件。 但是当我尝
您好,我正在尝试将文件位置表示为变量,因为最终脚本将在另一台机器上运行。这是我尝试过的代码,然后是我得到的错误。在我看来,python 是如何添加“\”的,这就是导致问题的原因。如果是这种情况,我如何
我有一个只包含一行的输入文件: $ cat input foo bar 我想在我的脚本中使用这一行,据我所知有 3 种方法: line=$(cat input) line=$( input"...,
我是一名优秀的程序员,十分优秀!