Swing/ColorComboBox のバックアップの現在との差分(No.3)
- バックアップ一覧
- 差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- バックアップ を表示
- Swing/ColorComboBox へ行く。
- 1 (2005-04-28 (木) 04:33:03)
- 2 (2005-09-08 (木) 12:49:01)
- 3 (2005-11-20 (日) 19:47:12)
- 4 (2005-11-24 (木) 11:37:05)
- 5 (2006-02-27 (月) 15:34:01)
- 6 (2006-04-12 (水) 19:37:51)
- 7 (2006-09-09 (土) 21:30:37)
- 8 (2006-10-10 (火) 18:51:38)
- 9 (2006-10-10 (火) 19:58:51)
- 10 (2006-10-12 (木) 13:01:09)
- 11 (2007-04-20 (金) 13:43:41)
- 12 (2007-12-13 (木) 15:43:10)
- 13 (2008-10-21 (火) 10:41:38)
- 14 (2008-10-21 (火) 15:41:21)
- 15 (2008-10-24 (金) 11:28:10)
- 16 (2009-06-09 (火) 20:36:08)
- 17 (2011-02-14 (月) 15:24:58)
- 18 (2013-03-31 (日) 20:11:16)
- 19 (2013-04-10 (水) 16:19:23)
- 20 (2014-03-19 (水) 17:12:42)
- 21 (2014-11-01 (土) 00:46:09)
- 22 (2014-11-30 (日) 00:46:41)
- 23 (2015-01-25 (日) 18:30:05)
- 24 (2016-04-24 (日) 21:09:29)
- 25 (2016-06-04 (土) 19:23:58)
- 26 (2016-09-08 (木) 18:02:40)
- 27 (2017-03-28 (火) 15:19:53)
- 28 (2017-11-02 (木) 15:34:40)
- 29 (2018-02-02 (金) 17:54:28)
- 30 (2018-02-24 (土) 19:51:30)
- 31 (2020-01-30 (木) 17:05:21)
- 32 (2021-07-28 (水) 05:11:40)
- 33 (2021-11-17 (水) 04:12:37)
- 34 (2022-08-20 (土) 22:15:25)
- 追加された行はこの色です。
- 削除された行はこの色です。
#navi(../) *JComboBoxの色を変更 [#jce4ead6] >編集者:[[Terai Atsuhiro>terai]]~ 作成日:2005-01-10~ 更新日:&lastmod; --- category: swing folder: ColorComboBox title: JComboBoxの色を変更 tags: [JComboBox, ListCellRenderer, JTextField] author: aterai pubdate: 2005-01-10T01:48:08+09:00 description: JComboBoxのEditor部分と、List部分の色を変更します。 image: https://lh4.googleusercontent.com/_9Z4BYR88imo/TQTJhY0CAaI/AAAAAAAAAUg/J70FCr-EUlI/s800/ColorComboBox.png hreflang: href: https://java-swing-tips.blogspot.com/2009/06/color-jcombobox.html lang: en --- * 概要 [#summary] `JComboBox`の`Editor`部分と、`List`部分の色を変更します。 #contents **概要 [#x42ac8da] JComboBoxのEditor部分と、List部分の色を変更します。 #download(https://lh4.googleusercontent.com/_9Z4BYR88imo/TQTJhY0CAaI/AAAAAAAAAUg/J70FCr-EUlI/s800/ColorComboBox.png) http://terai.xrea.jp/swing/colorcombobox/screenshot.png * サンプルコード [#sourcecode] #code(link){{ class AlternateRowColorComboBox<E> extends JComboBox<E> { private static final Color EVEN_BGC = new Color(0xE1_FF_E1); private static final Color ODD_BGC = Color.WHITE; private transient ItemListener itemColorListener; **サンプルコード [#b2f19a3d] JTextField field = (JTextField)combo.getEditor().getEditorComponent(); field.setOpaque(true); field.setBackground(new Color(225,255,225)); protected AlternateRowColorComboBox(ComboBoxModel<E> model) { super(model); } -[[サンプルを起動>http://terai.xrea.jp/swing/colorcombobox/sample.jnlp]] -[[jarファイル>http://terai.xrea.jp/swing/colorcombobox/sample.jar]] -[[ソース>http://terai.xrea.jp/swing/colorcombobox/src.zip]] @Override public void setEditable(boolean flag) { super.setEditable(flag); Component field = getEditor().getEditorComponent(); if (flag && field instanceof JComponent) { ((JComponent) field).setOpaque(true); field.setBackground(getAlternateRowColor(getSelectedIndex())); } } **解説 [#bbe45ca3] JComboBoxを編集可にした状態で、List部分、Editor部分に背景色を設定します。 @Override public void updateUI() { removeItemListener(itemColorListener); super.updateUI(); ListCellRenderer<? super E> r = getRenderer(); setRenderer((list, value, index, isSelected, cellHasFocus) -> { Component c = r.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus); if (index >= 0 && c instanceof JComponent) { ((JComponent) c).setOpaque(true); } if (!isSelected) { c.setBackground(getAlternateRowColor(index)); } return c; }); itemColorListener = e -> { if (e.getStateChange() != ItemEvent.SELECTED) { return; } JComboBox<?> cb = (JComboBox<?>) e.getItemSelectable(); Color rc = getAlternateRowColor(cb.getSelectedIndex()); if (cb.isEditable()) { cb.getEditor().getEditorComponent().setBackground(rc); } else { cb.setBackground(rc); } }; addItemListener(itemColorListener); EventQueue.invokeLater(() -> { Component c = getEditor().getEditorComponent(); c.setBackground(getAlternateRowColor(getSelectedIndex())); if (c instanceof JComponent) { ((JComponent) c).setOpaque(true); } }); } -List部分 --ListCellRendererを使用することで背景色の変更を行っています。 protected static Color getAlternateRowColor(int index) { return index % 2 == 0 ? EVEN_BGC : ODD_BGC; } } }} -Editor部分 --getEditor().getEditorComponent()で取得したJTextFieldオブジェクトの背景色を変更することで行っています。 * 解説 [#explanation] 上記のサンプルでは、`JComboBox`を編集可にした状態で以下のように`List`部分、`Editor`部分に行の奇数偶数で背景色を変更しています。 //**参考リンク **コメント [#i79a7ae9] - `List`部分 -- `ListCellRenderer`を使用することで背景色を変更 - `Editor`部分 -- `getEditor().getEditorComponent()`で`JTextField`オブジェクトを取得して背景色を変更 ---- - `GTKLookAndFeel`などで`Box`(`Editor`)部分の色を変更できない場合がある #ref(https://lh3.googleusercontent.com/_9Z4BYR88imo/TQTJj4vDxSI/AAAAAAAAAUk/ZZtKylfc0k8/s800/ColorComboBox1.png) * 参考リンク [#reference] - [[JComboBoxの文字色を変更する>Swing/ComboBoxForegroundColor]] * コメント [#comment] #comment - `JComboBox#setEditable(true)`は必須のようです。編集不可にするには`Editor`部分の`JTextField`に対して`setEditable(false)` -- &user(Y); &new{2006-10-10 (火) 18:51:38}; -- ご指摘ありがとうございます。せっかく`JComboBox`を上下に並べているので、編集可の場合と不可の場合のサンプルにすればよかったですね。編集不可の場合(`JComboBox#setEditable(false)`)に色を着けるには、上記の方法と、以下のように`JComboBox#setBackground(Color)`メソッドを使う方法があるようです。 %%編集不可の場合は、この部分の色もレンダラーが勝手にやってくれてたような気がするのですが、勘違いだったのかも。%% バージョンや`LookAndFeel`で異なる?ようです。 -- &user(aterai); &new{2006-10-10 (火) 19:58:51}; #code{{ final JComboBox c = new JComboBox(); c.addItemListener(new ItemListener() { @Override public void itemStateChanged(ItemEvent e) { if (e.getStateChange() != ItemEvent.SELECTED) { return; } c.setBackground((c.getSelectedIndex() % 2 == 0) ? evenBGColor : oddBGColor); } }); }} -- せっかくなので、上の`JComboBox`は編集不可、下は編集可の場合で、色を着けるサンプルに変更しました。 -- &user(aterai); &new{2006-10-10 (火) 20:31:03}; - メモ: [https://bugs.openjdk.org/browse/JDK-6367601 Windows/Motif L&F: Changing the JComboBox background does not change the popup of the JCombobox] -- &user(aterai); &new{2007-12-13 (木) 15:43:50}; - サンプルソースの`LookAndFeel`を設定しないようにすると、編集不可コンボはボタン部分も背景色になってしまう・・ -- &user(han); &new{2008-10-21 (火) 10:41:38}; -- `MetalLookAndFeel`などは、コンボボックスの背景色を変更すると矢印ボタンの色まで変更してしまう仕様?みたいですね。回避するなら、以下のように`UI`で使っている`PropertyChangeListener`をオーバーライドしてしまうのはどうでしょう。 -- &user(aterai); &new{2008-10-21 (火) 15:41:21}; #code{{ combo01.setUI(new MetalComboBoxUI() { @Override public PropertyChangeListener createPropertyChangeListener() { return new MetalPropertyChangeListener() { @Override public void propertyChange(PropertyChangeEvent e) { String propertyName = e.getPropertyName(); if (propertyName == "background") { Color color = (Color) e.getNewValue(); //arrowButton.setBackground(color); listBox.setBackground(color); } else { super.propertyChange( e ); } } }; } }); combo01.setModel(makeModel()); combo01.setRenderer(new MyListCellRenderer(combo01.getRenderer())); combo01.addItemListener(new ItemListener() { @Override public void itemStateChanged(ItemEvent e) { if (e.getStateChange() != ItemEvent.SELECTED) { return; } combo01.setBackground(getOEColor(combo01.getSelectedIndex())); } }); combo01.setSelectedIndex(0); combo01.setBackground(evenBGColor); }} - ありがとうございます。動作確認してませんが`UI`をさわればいろんなことができそうですね。で`UIManager`でなんとかできないか気になったので試すと、`UIManager.put("ComboBox.background", new ColorUIResource(Color.white));`で全てのコンボボックスの背景色を設定できました(リストの色分けはできないですが) -- &user(han); &new{2008-10-24 (金) 11:28:10}; #comment