JTextField 中的 Fantom-text.如何



我们遇到了一些流行的网站登录屏幕,其中用户名文本框中写着一个淡淡的灰色用户名。我想知道这可以在 java swings 中实现吗?

我有理论,通过鼠标事件实现。不知道该怎么做。

单程:

  • 创建一个在启动时提供 JTextField 幻像文本的类
  • 将文本的前景色设置为浅色
  • 使用 FocusListener,该侦听器将选择所有幻像文本,并将前景更改为默认颜色(设置为 null(。

例如:

import java.awt.Color;
import java.awt.GridLayout;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusEvent;
import javax.swing.*;
@SuppressWarnings("serial")
public class FantomTextFieldTest extends JPanel {
    FantomTextField fantomTextField = new FantomTextField("Fantom Text");
    public FantomTextFieldTest() {
        setLayout(new GridLayout(1, 0, 5, 0));
        add(new JTextField(20));
        add(fantomTextField.getTextField());
    }
    public static void main(String[] args) {
        SwingUtilities.invokeLater(() -> createAndShowGui());
    }
    private static void createAndShowGui() {
        FantomTextFieldTest mainPanel = new FantomTextFieldTest();
        JFrame frame = new JFrame("FantomTextFieldTest");
        frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
        frame.add(mainPanel);
        frame.pack();
        frame.setLocationByPlatform(true);
        frame.setVisible(true);
    }
}
class FantomTextField {
    private static final Color FANTOM_FG = new Color(150, 150, 150, 150);
    private JTextField textField;
    private String fantomText;
    private boolean showFantomText = true;
    public FantomTextField(String fantomText) {
        this.fantomText = fantomText;
        textField = new JTextField();
        textField.setText(fantomText);
        textField.setForeground(FANTOM_FG);
        textField.addFocusListener(new FtfFocusListener());
    }
    public FantomTextField(String fantomText, int columns) {
        this(fantomText);
        textField.setColumns(columns);
    }
    public JTextField getTextField() {
        return textField;
    }
    public String getFantomText() {
        return fantomText;
    }
    public void setFantomText(String fantomText) {
        this.fantomText = fantomText;
        textField.setText(fantomText);
        textField.setForeground(FANTOM_FG);
        showFantomText = true;
    }
    private class FtfFocusListener extends FocusAdapter {
        @Override
        public void focusGained(FocusEvent e) {
            if (showFantomText) {
                textField.selectAll();
                textField.setForeground(null);
                showFantomText = false;
            }
        }
    }       
}

查看文本提示。

它允许您显示文本和/或图标作为使用文本字段的提示。一旦在文本字段中输入任何字符,提示将被删除。

您还可以控制何时显示提示:

  1. ALWAYS – 无论文本字段是否具有焦点,都会显示提示。
  2. FOCUS_GAINED – 当文本字段获得焦点时显示提示(当焦点丢失时隐藏(
  3. FOCUS_LOST – 当文本字段失去焦点时显示提示(并在获得焦点时隐藏(

相关内容

  • 没有找到相关文章

最新更新