围绕圆形JLabel图像创建可单击区域

时间:2016-08-23 16:18:30

标签: java button jlabel

我正在尝试创建一个椭圆形图像的JLabel,就像这样。

enter image description here

我的代码如下:

import java.awt.Color;
import java.awt.Dimension;
import java.awt.Image;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.image.BufferedImage;
import java.io.IOException;

import javax.imageio.ImageIO;
import javax.swing.BorderFactory;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingUtilities;

public final class RoundedButtonDemo {
    private static Image bi;

    public static void main(String[] args) {
        try {
            loadImage();

            SwingUtilities.invokeLater(new Runnable() {
                @Override
                public void run() {
                    createAndShowGUI();
                }
            });
        } catch (IOException e) {
            // handle exception
        }
    }

    private static void loadImage() throws IOException {
        int newWidth = 80;
        int newHeight = 40;
        bi = ImageIO.read(RoundedButtonDemo.class.getResource("/resources/login.png"));
        bi = bi.getScaledInstance(newWidth, newHeight, Image.SCALE_DEFAULT);

    }

    private static void createAndShowGUI() {
        final JFrame frame = new JFrame();
        frame.setSize(400, 400);
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        final JLabel label = new JLabel();
        label.setSize(new Dimension(5, 5));
        label.setIcon(new ImageIcon(bi));
        label.setText("Hello World");
        label.setHorizontalTextPosition(JLabel.CENTER);
        // label.setBorder(BorderFactory.createLineBorder(Color.BLACK));

        label.addMouseListener(new MouseListener() {

            private int count = 0;

            @Override
            public void mouseClicked(MouseEvent e) {
                if (e.getSource() == label) {
                    if (count % 2 == 0) {
                        label.setText("Bye");
                    } else {
                        label.setText("Hello World");
                    }

                    count++;
                }
            }

            @Override
            public void mouseEntered(MouseEvent e) {
                // TODO Auto-generated method stub

            }

            @Override
            public void mouseExited(MouseEvent e) {
                // TODO Auto-generated method stub

            }

            @Override
            public void mousePressed(MouseEvent e) {
                // TODO Auto-generated method stub

            }

            @Override
            public void mouseReleased(MouseEvent e) {
                // TODO Auto-generated method stub

            }
        });

        frame.add(label);
        frame.setLocationRelativeTo(null);
        frame.setVisible(true);
    }
}

此代码会创建一个包含上述图像的JLabel。根据添加到JLabel的{​​{1}},每次点击按钮时,MouseListener的文字都应该互换。

我面临的问题是,即使我在图像外部(也在JLabel之外)点击,JLabel也会被触发,文字会交替出现。

我想要实现的目标是:  一个圆形按钮,只要在其表面的任何位置单击它,就会响应MouseListener

1 个答案:

答案 0 :(得分:3)

我尝试了你的代码。您收到此行为是因为您的JLabel实际上正在填充整个框架。您需要为框架设置布局;像这样的东西:

// ...
frame.setSize(400, 400);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setLayout(new FlowLayout());             // <-- you need this

final JLabel label = new JLabel();
label.setPreferredSize(new Dimension(80, 40)); // <-- also this
label.setIcon(new ImageIcon(bi));
label.setText("Hello World");
// ...

FlowLayout是最简单的布局管理器之一,其中有很多布局管理器。你可以在这里阅读它们:https://docs.oracle.com/javase/tutorial/uiswing/layout/visual.html

希望这有帮助。

PS:你有一个好主意试图调试这个问题,添加这样的边框:

// label.setBorder(BorderFactory.createLineBorder(Color.BLACK));

不确定你为什么评论它。也许你没注意到整个框架区域周围都有黑色边框。尝试将颜色设置为Color.RED或更明显的颜色。