【问题标题】:JButton with background Image changing on mouse hover带有背景图像的 JButton 在鼠标悬停时更改
【发布时间】:2013-09-05 15:08:40
【问题描述】:

我正在尝试显示一个带有图像的 JButton,但我不知道如何让 Mousehover 处理它。图像的正常显示工作,艰难。 如果按钮上绘制的文本可以居中,那就太好了。

import java.awt.*;
import java.io.IOException;
import java.net.URL;
import javax.imageio.ImageIO;
import javax.swing.JButton;
import javax.swing.JFrame;

public class ImageButtonTest {

    private static JButton imageButton;

    public static void main(String[] args) throws IOException {
        JFrame frm = new JFrame();
        frm.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frm.setSize(90, 27);
        frm.setLocation(50, 50);
        Image image = ImageIO.read(new URL("http://i.imgur.com/bitgM6l.png"));
        Image imageHover = ImageIO.read(new URL("http://i.imgur.com/dt81BWk.png"));
        imageButton = new ImageButton(image, imageHover);
        imageButton.setText("Download");
        frm.add(imageButton);
        frm.pack();
        frm.setVisible(true);
    }

    static class ImageButton extends JButton {
        private Image image, imageHover;
        private boolean hover;

        ImageButton(Image image, Image imageHover) {
            this.image = image;
            this.hover = false;


            addMouseListener(new java.awt.event.MouseAdapter() {  
                @Override
                public void mouseEntered(java.awt.event.MouseEvent evt) {
                    hover = true;
                    repaint();
                }

                @Override
                public void mouseExited(java.awt.event.MouseEvent evt) {
                    hover = false;
                    repaint();
                }
            });
        };

        @Override
        protected void paintComponent(Graphics g) {

            if(isEnabled()) {
                Graphics2D g2 = (Graphics2D) g.create();
                g2.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON);
                g2.setFont(new Font("Arial", Font.PLAIN, 12));
                g2.setColor(Color.WHITE);

                if(hover) {
                    g2.drawImage(imageHover, 0, 0, getWidth(), getHeight(), this);
                } else {
                    g2.drawImage(image, 0, 0, getWidth(), getHeight(), this);
                }
                g2.drawString(getText(), 20, getHeight() / 2 + 5);

                g2.dispose();
            } else {
                super.paintComponent(g);
            }

        }

    }

}

【问题讨论】:

标签: java swing jbutton


【解决方案1】:

Image image = ImageIO.read(new URL("http://i.imgur.com/bitgM6l.png")); 图片 imageHover = ImageIO.read(new 网址("http://i.imgur.com/dt81BWk.png"));

您可以使用实现的标准方法

JButton API

//button.setBorderPainted(false);
//button.setBorder(null);
//button.setFocusable(false);
//button.setMargin(new Insets(0, 0, 0, 0));
button.setContentAreaFilled(false);
button.setIcon(icon());
button.setRolloverIcon(iconA());
button.setPressedIcon(iconB());
button.setDisabledIcon(iconC());

JButton.getModel().addChangeListener()

    JButton.getModel().addChangeListener(new ChangeListener() {
        @Override
        public void stateChanged(ChangeEvent e) {
            ButtonModel model = (ButtonModel) e.getSource();
            if (model.isRollover()) {
                button.setIcon(icon());
            } else {
                button.setIcon(iconA());
            } etc ...//  if (model.isPressed()) {
         }
    });

【讨论】:

  • 我需要在 X 轴上重复背景。这可能吗?
  • 将图标放入队列,不知道background to be repeated on the X-Axis是什么@
  • 我需要图标在我的按钮上重复/拉伸。我必须在应用之前编辑图标吗?
  • 你在谈论如何使用 JButton 调整图标大小,是的,可能没有问题
  • 这种方法有点问题,因为当鼠标光标最初悬停在按钮上时,它不会应用悬停效果。我建议改用 addMouseListener + mouseEntered() + mouseExited()。
猜你喜欢
  • 2010-11-25
  • 2018-07-07
  • 1970-01-01
  • 2011-03-06
  • 1970-01-01
  • 2016-01-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多