我在JPanel
点击时将JFrame
添加到JButton
。它将JPanel
添加到框架中。该按钮将继续在点击事件中添加JPanel
到JFrame
。没有限制。单击按钮时,我也会将JPanels
添加到List
。我这样做是因为添加MouseMotionListener
使用for循环来处理拖动JPanel的。
我现在面临的问题是阻力。当我通过单击添加第一个JPanel
并且如果我拖动它时,它正确地跟随鼠标光标坐标。当我添加第二个JPanel
时,它也完全跟随鼠标。添加第二个后,如果尝试拖动第一个JPanel,第一个JPanel似乎遵循不同的坐标,初始位置将更改为其他位置。我不知道我在哪里犯了这个错误。请帮我解决这个问题。请仔细阅读以下代码。
import java.awt.Color;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseMotionAdapter;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;
public class MyFrame extends JFrame {
JButton jb;
List<JPanel> mypanels = new ArrayList<JPanel>();
public MyFrame() {
jb = new JButton("Add Panel");
jb.setBounds(10, 10, 100, 50);
setSize(new Dimension(1000, 600));
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setLayout(null);
add(jb);
setVisible(true);
initialize();
}
public void initialize() {
jb.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent arg0) {
// TODO Auto-generated method stub
JPanel panel = new JPanel();
panel.setBounds(150,150,200,200);
panel.setBackground(Color.black);
mypanels.add(panel);
add(panel);
repaint();
handleDrag();
}
});
}
public void handleDrag(){
for(int i=0;i<mypanels.size();i++) {
final int j = i;
mypanels.get(i).addMouseMotionListener(new MouseMotionAdapter() {
@Override
public void mouseDragged(MouseEvent me) {
me.translatePoint(me.getComponent().getLocation().x, me.getComponent().getLocation().y);
mypanels.get(j).setLocation(me.getX(), me.getY());
}
});
}
}
public static void main(String args[]) {
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
new MyFrame();
}
});
}
}
答案 0 :(得分:7)
当只有一个JPanel添加到List时,看起来你的handleDrag方法正在为每个JPanel添加一个新的匿名监听器。只需添加一次监听器,如果添加多个监听器,行为将变得奇怪。
这是一个更新的handleDrag方法
public void handleDrag(JPanel panel){
final JPanel p = panel;
panel.addMouseMotionListener(new MouseMotionAdapter() {
@Override
public void mouseDragged(MouseEvent me) {
me.translatePoint(me.getComponent().getLocation().x, me.getComponent().getLocation().y);
p.setLocation(me.getX(), me.getY());
}
});
}
答案 1 :(得分:5)
Joe是对的,这是我在项目中使用handleDrag方法的原因:
public void handleDrag(final JPanel panel){
panel.addMouseListener(new MouseAdapter() {
@Override
public void mousePressed(MouseEvent me) {
x = me.getX();
y = me.getY();
}
});
panel.addMouseMotionListener(new MouseMotionAdapter() {
@Override
public void mouseDragged(MouseEvent me) {
me.translatePoint(me.getComponent().getLocation().x-x, me.getComponent().getLocation().y-y);
panel.setLocation(me.getX(), me.getY());
}
});
}
这样,当点击它时,面板不会进行初始“跳跃”。
答案 2 :(得分:2)
不要在同一时间将ComponentMover
与ComponentResizer
合并