2013-06-21 188 views
1

我使用类似于下面的触摸界面的逻辑,所以我希望能够使用mousePressed启动拖动,但同时能够使用mouseClicked或mouseReleased如果用户没有拖动。Java拖放和鼠标监听器

在mousePressed上,我开始拖动。上的mouseClicked,我希望它打印出“的mouseClicked”,并就“的mouseReleased”打印的mouseReleased,但由于某些原因,

dropLabel.getTransferHandler().exportAsDrag(dropLabel, e, 
      TransferHandler.COPY); 

燕子引起的mouseClicked事件和时的mouseReleased我也不事件不会甚至被解雇移动鼠标。请注意,注释掉该行会导致所有侦听器被触发(但显然拖动未启动)。

如何以我想要的方式获得所有鼠标事件,特别是mouseClicked/mouseReleased,当用户不做任何拖动时,如果用户确实拖动,仍然能够导出AsDragged?任何黑客/裂缝/反射解决方案都是受欢迎的。

这里是我与工作的一些示例代码说明了我的实际问题:

import java.awt.Color; 
import java.awt.Dimension; 
import java.awt.GridLayout; 
import java.awt.event.MouseEvent; 
import java.awt.event.MouseListener; 
import java.awt.event.MouseMotionListener; 

import javax.swing.BorderFactory; 
import javax.swing.JFrame; 
import javax.swing.JLabel; 
import javax.swing.JPanel; 
import javax.swing.JTextArea; 
import javax.swing.TransferHandler; 

public class DragTest extends JFrame implements MouseMotionListener, 
     MouseListener { 

    private JPanel leftPanel = new JPanel(null); 
    private JPanel rightPanel = new JPanel(null); 
    JLabel dropLabel; 

    public DragTest() { 
     this.setLayout(new GridLayout(1, 2)); 

     leftPanel.setBorder(BorderFactory.createLineBorder(Color.black)); 
     rightPanel.setBorder(BorderFactory.createLineBorder(Color.black)); 
     this.add(leftPanel); 
     this.add(rightPanel); 
     leftPanel.addMouseListener(this); 
     leftPanel.addMouseMotionListener(this); 

     JTextArea area = new JTextArea(); 

     rightPanel.setLayout(new GridLayout(1, 1)); 
     rightPanel.add(area); 

     dropLabel = new JLabel("drop"); 
     dropLabel.setTransferHandler(new TransferHandler("text")); 

    } 

    @Override 
    public void mousePressed(MouseEvent e) { 
     System.out.println("mousePressed"); 


     Dimension labelSize = dropLabel.getPreferredSize(); 
     dropLabel.setSize(labelSize); 
     int x = e.getX() - labelSize.width/2; 
     int y = e.getY() - labelSize.height/2; 
     dropLabel.setLocation(x, y); 
     leftPanel.add(dropLabel); 


     dropLabel.getTransferHandler().exportAsDrag(dropLabel, e, 
       TransferHandler.COPY); 

     repaint(); 

    } 

    @Override 
    public void mouseDragged(MouseEvent me) { 
     System.out.println("mouseDragged"); 
    } 

    @Override 
    public void mouseMoved(MouseEvent e) { 

    } 

    @Override 
    public void mouseClicked(MouseEvent e) { 
     System.out.println("mouseClicked"); 
    } 

    @Override 
    public void mouseReleased(MouseEvent e) { 

     System.out.println("mouseReleased"); 

    } 

    @Override 
    public void mouseEntered(MouseEvent e) { 

    } 

    @Override 
    public void mouseExited(MouseEvent e) { 

    } 

    public static void main(String[] args) { 

     DragTest frame = new DragTest(); 
     frame.setVisible(true); 
     frame.setSize(600, 400); 
     frame.setResizable(false); 
     frame.setLocationRelativeTo(null); 
     frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
    } 
} 
+0

按照定义,mouseClicked事件只会发生在mousePresses和mouseReleased相同的地方。尝试使用mouseReleased代替。您可能不应该在点击事件中安装传输处理程序,而应该将其作为正常初始化过程的一部分来建立 – MadProgrammer

+0

同意 - 但不会调用mouseReleased。我更新了代码以匹配您的一些反馈。 – systemoutprintln

+0

我怎么不''TransferHandler' API:P – MadProgrammer

回答

5

你真的需要到的mouseReleased火还是什么?我认为这应该很好地工作:

import java.awt.Color; 
import java.awt.Dimension; 
import java.awt.GridLayout; 
import java.awt.event.MouseEvent; 
import java.awt.event.MouseListener; 
import java.awt.event.MouseMotionListener; 

import javax.swing.BorderFactory; 
import javax.swing.JFrame; 
import javax.swing.JLabel; 
import javax.swing.JPanel; 
import javax.swing.JTextArea; 
import javax.swing.TransferHandler; 

public class DragTest extends JFrame implements MouseMotionListener, 
     MouseListener { 

    private JPanel leftPanel = new JPanel(null); 
    private JPanel rightPanel = new JPanel(null); 
    JLabel dropLabel; 

    public DragTest() { 
     this.setLayout(new GridLayout(1, 2)); 

     leftPanel.setBorder(BorderFactory.createLineBorder(Color.black)); 
     rightPanel.setBorder(BorderFactory.createLineBorder(Color.black)); 
     this.add(leftPanel); 
     this.add(rightPanel); 
     leftPanel.addMouseListener(this); 
     leftPanel.addMouseMotionListener(this); 

     JTextArea area = new JTextArea(); 

     rightPanel.setLayout(new GridLayout(1, 1)); 
     rightPanel.add(area); 

     dropLabel = new JLabel("drop"); 
     dropLabel.setTransferHandler(new TransferHandler("text")); 

    } 
    @Override 
    public void mousePressed(MouseEvent e) { 
     System.out.println("mousePressed"); 
     Dimension labelSize = dropLabel.getPreferredSize(); 
     dropLabel.setSize(labelSize); 
     int x = e.getX() - labelSize.width/2; 
     int y = e.getY() - labelSize.height/2; 
     dropLabel.setLocation(x, y); 
     leftPanel.add(dropLabel); 



     repaint(); 

    } 

    @Override 
    public void mouseDragged(MouseEvent me) { 
     System.out.println("mouseDragged"); 
      dropLabel.getTransferHandler().exportAsDrag(dropLabel, me, 
        TransferHandler.COPY); 
    } 

    @Override 
    public void mouseMoved(MouseEvent e) { 
    } 

    @Override 
    public void mouseClicked(MouseEvent e) { 
     System.out.println("mouseClicked"); 
    } 

    @Override 
    public void mouseReleased(MouseEvent e) { 
     System.out.println("mouseReleased"); 

    } 

    @Override 
    public void mouseEntered(MouseEvent e) { 

    } 

    @Override 
    public void mouseExited(MouseEvent e) { 

    } 

    public static void main(String[] args) { 

     DragTest frame = new DragTest(); 
     frame.setVisible(true); 
     frame.setSize(600, 400); 
     frame.setResizable(false); 
     frame.setLocationRelativeTo(null); 
     frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
    } 
} 

我刚搬到调用开始拖动事件进入的mouseDragged通话,这样一来,如果你只需点击鼠标那么一切正常通话。但是,如果您拖动鼠标,它将触发拖放呼叫,该呼叫仍会阻止其他呼叫,但只有在您拖动时才会再次阻止其他呼叫。如果你只是点击,它一切正常。