• 追加された行はこの色です。
  • 削除された行はこの色です。
TITLE:JTextFieldに透かし画像を表示する
#navi(../)
RIGHT:Posted by &author(aterai); at 2009-10-26
*JTextFieldに透かし画像を表示する [#l4413cba]
JTextFieldの文字列が空でフォーカスがない場合、透かし画像を表示するように設定します。
---
category: swing
folder: WatermarkInTextField
title: JTextFieldに透かし画像を表示する
tags: [JTextField, Focus, ImageIcon]
author: aterai
pubdate: 2009-10-26T13:04:26+09:00
description: JTextFieldの文字列が空でフォーカスがない場合、透かし画像を表示するように設定します。
image: https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTWh1Qjh4I/AAAAAAAAApY/bLarzjLy7-8/s800/WatermarkInTextField.png
---
* 概要 [#summary]
`JTextField`の文字列が空でフォーカスがない場合、透かし画像を表示するように設定します。

-&jnlp;
-&jar;
-&zip;
#download(https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTWh1Qjh4I/AAAAAAAAApY/bLarzjLy7-8/s800/WatermarkInTextField.png)

//#screenshot
#ref(http://lh3.ggpht.com/_9Z4BYR88imo/TQTWh1Qjh4I/AAAAAAAAApY/bLarzjLy7-8/s800/WatermarkInTextField.png)

**サンプルコード [#bef878a0]
#code{{
* サンプルコード [#sourcecode]
#code(link){{
class WatermarkTextField extends JTextField implements FocusListener {
  private final ImageIcon image;
  private boolean showWatermark = true;
  public WatermarkTextField() {
    super();
    image = new ImageIcon(getClass().getResource("watermark.png"));
    addFocusListener(this);
  }
  @Override public void paintComponent(Graphics g) {

  @Override protected void paintComponent(Graphics g) {
    super.paintComponent(g);
    if(showWatermark) {
      Graphics2D g2d = (Graphics2D)g;
      //Insets i = getMargin();
    if (showWatermark) {
      Graphics2D g2 = (Graphics2D) g.create();
      // Insets i = getMargin();
      Insets i = getInsets();
      int yy = (getHeight()-image.getIconHeight())/2;
      g2d.drawImage(image.getImage(), i.left, yy, this);
      int yy = (getHeight() - image.getIconHeight()) / 2;
      g2.drawImage(image.getImage(), i.left, yy, this);
      g2.dispose();
    }
  }

  @Override public void focusGained(FocusEvent e) {
    showWatermark = false;
    repaint();
  }

  @Override public void focusLost(FocusEvent e) {
    showWatermark = "".equals(getText().trim());
    repaint();
  }
}
}}

**解説 [#kcbc0705]
-上
--[[JTextFieldにフォーカスと文字列が無い場合の表示>Swing/GhostText]]
-下
--JTextFieldの文字列が空で、フォーカスも無い場合、上記のように文字列ではなく、画像を表示します。
* 解説 [#explanation]
- 上
-- [[JTextFieldにフォーカスと文字列が無い場合の表示>Swing/GhostText]]
- 下
-- `JTextField`の文字列が空でフォーカスも無い場合は文字列ではなく画像を表示

**参考リンク [#w2323b40]
-[[JTextFieldにフォーカスと文字列が無い場合の表示>Swing/GhostText]]
* 参考リンク [#reference]
- [[JTextFieldにフォーカスと文字列が無い場合の表示>Swing/GhostText]]
- [[JPasswordFieldにヒント文字列を描画する>Swing/InputHintPasswordField]]
-- [[JTextFieldにフォーカスと文字列が無い場合の表示>Swing/GhostText]]の方法は`JPasswordField`に応用できないので、`JLabel`を配置することでヒント文字列を表示
- [[JComboBoxでアイテムが選択されていない場合のプレースホルダ文字列を設定する>Swing/ComboBoxPlaceholder]]

**コメント [#rbb7650a]
- 右上のgoogle カスタム検索のような %%…と書こうと思ったら透かし画像が消えている?%% FireFox では問題なし。Opera10.10だと表示されない。キャッシュが壊れているだけかも。 -- [[aterai]] &new{2009-10-26 (月) 13:04:26};

* コメント [#comment]
#comment
#comment