Java 是否用图像替换JTextField?

Java 是否用图像替换JTextField?,java,image,swing,jpanel,jtextfield,Java,Image,Swing,Jpanel,Jtextfield,我一直在寻找用图像替换JTextField的方法&什么都没有出现。是否可以在图像上添加jtextfield或用图像替换 我使用的是JPanel&我试图将JtextField放在下图中: 有几种方法可以实现这一点 最简单的方法可能是使用JLabel,将其布局管理器设置为BorderLayout,然后简单地将文本字段添加到其中 JTextField field = new JTextField(); field.setOpaque(false); JLabel label = new JLabel(

我一直在寻找用图像替换JTextField的方法&什么都没有出现。是否可以在图像上添加jtextfield或用图像替换

我使用的是JPanel&我试图将JtextField放在下图中:
有几种方法可以实现这一点

最简单的方法可能是使用
JLabel
,将其布局管理器设置为
BorderLayout
,然后简单地将文本字段添加到其中

JTextField field = new JTextField();
field.setOpaque(false);
JLabel label = new JLabel();
label.setIcon(...);
label.setLayout(new BorderLayout());
label.add(field);
例如

这将产生

如果希望文本字段透明,可以添加
field.setBackground(新颜色(0,0,0,0)),它生成

如果不需要边框,请添加
field.setboorder(null),它生成

更新了另一个示例…

或者你更喜欢一个独立的类

这有点棘手,因为
paintComponent
不仅可以绘制背景,还可以绘制文本,您需要某种方法将背景插入文本下。为此,我实际上并不调用
super.paintComponent
,而是直接调用
getUI().paint
。这确保了字段的文本被绘制,但允许我们在绘制之前绘制自己的背景

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.JFrame;
import javax.swing.JTextField;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.border.EmptyBorder;

public class BackgroundTextField {

    public static void main(String[] args) {
        new BackgroundTextField();
    }

    public BackgroundTextField() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new TextFieldBackground());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TextFieldBackground extends JTextField {

        private BufferedImage img;

        public TextFieldBackground() {
            setColumns(10);
            setOpaque(false);
            setBorder(new EmptyBorder(2, 2, 2, 2));
            setBackground(new Color(0, 0, 0, 0));
            try {
                img = ImageIO.read(getClass().getResource("/y9yBe.jpg"));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }

        @Override
        public Dimension getPreferredSize() {
            return img == null ? super.getPreferredSize() : new Dimension(img.getWidth(), img.getHeight());
        }

        @Override
        protected void paintComponent(Graphics g) {
            Graphics2D g2d = (Graphics2D) g.create();
            g2d.drawImage(img, 0, 0, this);
            getUI().paint(g2d, this);
            g2d.dispose();
        }

    }

}

这是有限制的,因为图像不会重复,所以字段永远不应该比图像大,但我相信您可以使用
for loop
将一组图像缝合在一起…

有几种方法可以实现这一点

最简单的方法可能是使用
JLabel
,将其布局管理器设置为
BorderLayout
,然后简单地将文本字段添加到其中

JTextField field = new JTextField();
field.setOpaque(false);
JLabel label = new JLabel();
label.setIcon(...);
label.setLayout(new BorderLayout());
label.add(field);
例如

这将产生

如果希望文本字段透明,可以添加
field.setBackground(新颜色(0,0,0,0)),它生成

如果不需要边框,请添加
field.setboorder(null),它生成

更新了另一个示例…

或者你更喜欢一个独立的类

这有点棘手,因为
paintComponent
不仅可以绘制背景,还可以绘制文本,您需要某种方法将背景插入文本下。为此,我实际上并不调用
super.paintComponent
,而是直接调用
getUI().paint
。这确保了字段的文本被绘制,但允许我们在绘制之前绘制自己的背景

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.JFrame;
import javax.swing.JTextField;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.border.EmptyBorder;

public class BackgroundTextField {

    public static void main(String[] args) {
        new BackgroundTextField();
    }

    public BackgroundTextField() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new TextFieldBackground());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TextFieldBackground extends JTextField {

        private BufferedImage img;

        public TextFieldBackground() {
            setColumns(10);
            setOpaque(false);
            setBorder(new EmptyBorder(2, 2, 2, 2));
            setBackground(new Color(0, 0, 0, 0));
            try {
                img = ImageIO.read(getClass().getResource("/y9yBe.jpg"));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }

        @Override
        public Dimension getPreferredSize() {
            return img == null ? super.getPreferredSize() : new Dimension(img.getWidth(), img.getHeight());
        }

        @Override
        protected void paintComponent(Graphics g) {
            Graphics2D g2d = (Graphics2D) g.create();
            g2d.drawImage(img, 0, 0, this);
            getUI().paint(g2d, this);
            g2d.dispose();
        }

    }

}

这是有限制的,因为图像不会重复,所以字段永远不应该比图像大,但我相信您可以使用
for loop
将一组图像缝合在一起…

有几种方法可以实现这一点

最简单的方法可能是使用
JLabel
,将其布局管理器设置为
BorderLayout
,然后简单地将文本字段添加到其中

JTextField field = new JTextField();
field.setOpaque(false);
JLabel label = new JLabel();
label.setIcon(...);
label.setLayout(new BorderLayout());
label.add(field);
例如

这将产生

如果希望文本字段透明,可以添加
field.setBackground(新颜色(0,0,0,0)),它生成

如果不需要边框,请添加
field.setboorder(null),它生成

更新了另一个示例…

或者你更喜欢一个独立的类

这有点棘手,因为
paintComponent
不仅可以绘制背景,还可以绘制文本,您需要某种方法将背景插入文本下。为此,我实际上并不调用
super.paintComponent
,而是直接调用
getUI().paint
。这确保了字段的文本被绘制,但允许我们在绘制之前绘制自己的背景

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.JFrame;
import javax.swing.JTextField;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.border.EmptyBorder;

public class BackgroundTextField {

    public static void main(String[] args) {
        new BackgroundTextField();
    }

    public BackgroundTextField() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new TextFieldBackground());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TextFieldBackground extends JTextField {

        private BufferedImage img;

        public TextFieldBackground() {
            setColumns(10);
            setOpaque(false);
            setBorder(new EmptyBorder(2, 2, 2, 2));
            setBackground(new Color(0, 0, 0, 0));
            try {
                img = ImageIO.read(getClass().getResource("/y9yBe.jpg"));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }

        @Override
        public Dimension getPreferredSize() {
            return img == null ? super.getPreferredSize() : new Dimension(img.getWidth(), img.getHeight());
        }

        @Override
        protected void paintComponent(Graphics g) {
            Graphics2D g2d = (Graphics2D) g.create();
            g2d.drawImage(img, 0, 0, this);
            getUI().paint(g2d, this);
            g2d.dispose();
        }

    }

}

这是有限制的,因为图像不会重复,所以字段永远不应该比图像大,但我相信您可以使用
for loop
将一组图像缝合在一起…

有几种方法可以实现这一点

最简单的方法可能是使用
JLabel
,将其布局管理器设置为
BorderLayout
,然后简单地将文本字段添加到其中

JTextField field = new JTextField();
field.setOpaque(false);
JLabel label = new JLabel();
label.setIcon(...);
label.setLayout(new BorderLayout());
label.add(field);
例如

这将产生

如果希望文本字段透明,可以添加
field.setBackground(新颜色(0,0,0,0)),它生成

如果不需要边框,请添加
field.setboorder(null),它生成

更新了另一个示例…

或者你更喜欢一个独立的类

这有点棘手,因为
paintComponent
不仅可以绘制背景,还可以绘制文本,您需要某种方法将背景插入文本下。为此,我实际上并不调用
super.paintComponent
,而是直接调用
getUI().paint
。这确保了字段的文本被绘制,但允许我们在绘制之前绘制自己的背景

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.JFrame;
import javax.swing.JTextField;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.border.EmptyBorder;

public class BackgroundTextField {

    public static void main(String[] args) {
        new BackgroundTextField();
    }

    public BackgroundTextField() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new TextFieldBackground());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TextFieldBackground extends JTextField {

        private BufferedImage img;

        public TextFieldBackground() {
            setColumns(10);
            setOpaque(false);
            setBorder(new EmptyBorder(2, 2, 2, 2));
            setBackground(new Color(0, 0, 0, 0));
            try {
                img = ImageIO.read(getClass().getResource("/y9yBe.jpg"));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }

        @Override
        public Dimension getPreferredSize() {
            return img == null ? super.getPreferredSize() : new Dimension(img.getWidth(), img.getHeight());
        }

        @Override
        protected void paintComponent(Graphics g) {
            Graphics2D g2d = (Graphics2D) g.create();
            g2d.drawImage(img, 0, 0, this);
            getUI().paint(g2d, this);
            g2d.dispose();
        }

    }

}

这是有限制的,字段不应该比图像大,因为图像不会重复,但我相信您可以使用
for loop
将一组图像缝合在一起…

这并不是我想要的。:/我试图能够键入数据&而不是JTextField的边界。只是闪烁的“|”东西。所以,你需要使用最后三个选项,
setOpaque(false)
setBackground(新颜色(0,0,0,0))
setboorder(null)
,我以为我填写了这三个选项……但这并没有满足我的要求。:/我试图能够键入数据&而不是JTextField的边界。只是闪烁的“|”东西。因此,您需要使用最后三个选项,
setOpaque(false)