我试图弄清楚如何制作不可编辑的文本(不是JTextField),当鼠标悬停在其上时,其背景颜色会改变。我尝试使用实现ActionListener的JButton并隐藏元素以使按钮看起来像是文本,但是它只允许我在鼠标悬停时更改图标并检测单击按钮的时间。另一个想法是使用MouseListener并在文本周围声明一个矩形的特定坐标,在mouseMoved上它可以启动突出显示。但是w /改变字符串长度和自动换行等存在问题。什么是最好的对象,以及侦听器组合才能在鼠标悬停时实现突出显示的文本字段的效果?

最佳答案

嗯,也许可以使用foucs侦听器,当字段获得foucs时,请选择所有文本?

import java.awt.*;
import java.awt.event.*;
import javax.swing.*;

public class TextField extends JTextField {


public TextField(String text) {
    super(text);

    addFocusListener(new FocusAdapter() {

        @Override
        public void focusGained(FocusEvent fe) {
             selectAll();
        }
    });
}

public static void main(String[] args) {
    EventQueue.invokeLater(new Runnable() {

        public void run() {
            JFrame f = new JFrame();
            f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

            JTextField tf = new JTextField("normal field");
            f.add(tf, BorderLayout.CENTER);

            TextField ftf =
                    new TextField("funny text field");
            f.add(ftf, BorderLayout.SOUTH);

            f.pack();
            f.setVisible(true);
        }
    });
}
}


编辑:

嗯,实际上使用上述方法找到了一种更好的方法,您必须单击文本字段来获得焦点,现在我使用了一个线程来检查鼠标何时位于组件坐标上,然后突出显示该字段,我使用布尔值来控制突出显示,因为持续突出显示会引发错误。希望这是您想要的:

import java.awt.*;
import javax.swing.*;

public class TextFieldHighlight extends JTextField {

    static JTextField ftf;

    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {

            public void run() {
                JFrame f = new JFrame();
                f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);


                ftf = new JTextField("Highlight");
                ftf.setEditable(false);
                f.add(ftf, BorderLayout.CENTER);
                f.pack();
                f.setVisible(true);
                Thread thread = new Thread(new Runnable() {

                    boolean focused = false;

                    @Override
                    public void run() {
                        while (true) {
                            if (mouseIsOverDisplayPanel()) {
                                if (ftf.hasFocus() && focused == false) {
                                    ftf.selectAll();
                                    focused = true;
                                } else if (!ftf.hasFocus()) {
                                    focused = false;
                                }
                            }
                        }
                    }
                });
                thread.start();
            }
        });

    }

    private static boolean mouseIsOverDisplayPanel() {

        if (MouseInfo.getPointerInfo().getLocation().x >= ftf.getLocationOnScreen().x
                && MouseInfo.getPointerInfo().getLocation().x <= ftf.getLocationOnScreen().x + ftf.getWidth()
                && MouseInfo.getPointerInfo().getLocation().y >= ftf.getLocationOnScreen().y
                && MouseInfo.getPointerInfo().getLocation().y <= ftf.getLocationOnScreen().y + ftf.getHeight()) {

            return true;

        } else {

            return false;

        }
    }
}

10-05 18:55