2

我正在尝试创建一个 JFrame,它将文件路径中的图像显示到 JFrame 上的特定位置。稍后(单击按钮时),我希望图像向左移动位置,例如 50 个像素。如果需要布局管理器,我想使用空布局,因为这是我自己的项目,我还没有准备好学习如何编写自己的布局管理器。

到目前为止,我已经设法在一个框架中显示一个 BufferedImage,但我不知道如何指定它的位置。

使用 BufferedImage 甚至是正确的方法吗?这样做的最佳方法是什么?

更新:我尝试遵循您使用 mouselistener 的建议,结果如下:

class ImgComponent extends JComponent  implements ChangeListener, MouseListener  {

MovableImage mi;

public ImgComponent(MovableImage mi) {
    this.mi = mi;
    mi.addListener(this);
      mi.addListener1(this);
}

@Override
protected void paintComponent(Graphics g) {
    super.paintComponent(g);
    g.drawImage(mi.i, mi.getX(), mi.getY(), null);
}

@Override
public void stateChanged(ChangeEvent e) {
    repaint();

}
@Override
public void mouseClicked(MouseEvent e) {
        mi.setPos(100, 100);
        System.out.println("yay");
}

}

但不幸的是,mouseClicked 事件永远不会触发。我只是想让那个该死的图像移动,哈哈。

4

1 回答 1

3

这是一个使用模型/视图/控制器模式的完整示例。(只需在一个 .java 文件中一个接一个地转储所有片段。)

import java.awt.*;
import java.awt.event.ActionEvent;
import java.util.*;
import java.util.List;

import javax.swing.*;
import javax.swing.event.*;


// A class encapsulating an image and a x-coordinate (a "model")
class MovableImage {
    Image i = new ImageIcon("duke.png").getImage();
    private int x = 0;

    // Observers that are interested in movements.
    List<ChangeListener> listeners = new ArrayList<ChangeListener>();

    public void addListener(ChangeListener cl) {
        listeners.add(cl);
    }

    public int getX() {
        return x;
    }

    public void incrementX() {
        x += 10;

        // Notify those interested.
        for (ChangeListener cl : listeners)
            cl.stateChanged(null);
    }
}

 

// A graphical component displaying the model.
// Object of this class are interested in movement because when the image moves,
// this component needs to be repainted.
class ImgComponent extends JComponent implements ChangeListener {

    // The movable image to present.
    MovableImage mi;

    public ImgComponent(MovableImage mi) {
        this.mi = mi;
        mi.addListener(this);
    }

    @Override
    protected void paintComponent(Graphics g) {
        super.paintComponent(g);
        g.drawImage(mi.i, mi.getX(), 10, null);
    }

    // This method is called from MovableImage when the position changes.
    @Override
    public void stateChanged(ChangeEvent e) {
        repaint();
    }
}

 

// Main class.
public class FrameTestBase extends JFrame {

    public static void main(String args[]) {

        // Create the "model".
        final MovableImage mi = new MovableImage();

        FrameTestBase t = new FrameTestBase();
        t.setLayout(new BorderLayout());

        // Add a component presenting the model.
        t.add(new ImgComponent(mi), BorderLayout.CENTER);

        // Create a button which increments x when clicked on.
        t.add(new JButton(new AbstractAction("Move right") {
            @Override
            public void actionPerformed(ActionEvent e) {
                mi.incrementX();
            }
        }), BorderLayout.SOUTH);

        // Show it.
        t.setDefaultCloseOperation(EXIT_ON_CLOSE);
        t.setSize(400, 400);
        t.setVisible(true);
    }
}

在此处输入图像描述


关于您的编辑:

您还需要添加鼠标侦听器。在构造函数中:

public ImgComponent(MovableImage mi) {
    this.mi = mi;
    mi.addListener(this);
    mi.addListener1(this);
}

在底部添加以下行:

    addMouseListener(this);
于 2012-05-10T06:53:22.117 回答