Swing/ClippedLRComboBox のバックアップの現在との差分(No.11)
TITLE:JComboBoxのItemを左右にクリップして配置
Posted by aterai at 2005-09-12
JComboBoxのItemを左右にクリップして配置
JComboBoxのItemにテキストをクリップして左右に分けて配置します。-
category: swing
folder: ClippedLRComboBox
title: JComboBoxのItemを左右にクリップして配置
tags: [JComboBox, ListCellRenderer, JLabel, JPanel]
author: aterai
pubdate: 2005-09-12T13:00:56+09:00
description: JComboBoxのItem内のレイアウトをメインとサブの二つに分割し、それぞれ適当な長さに省略した文字列を表示します。
image:
hreflang:
href: https://java-swing-tips.blogspot.com/2008/08/multi-column-jcombobox.html lang: en
概要
JComboBox
のItem
内のレイアウトをメインとサブの二つに分割し、それぞれ適当な長さに省略した文字列を表示します。
- &jnlp;
- &jar;
- &zip;
Screenshot
Advertisement
サンプルコード
#spanend
#spanadd
class MultiColumnCellRenderer extends JPanel implements ListCellRenderer {
#spanend
private final JLabel leftLabel = new JLabel();
private final JLabel rightLabel;
#spandel
**サンプルコード [#n26d00a1]
#spanend
#spandel
#code{{
#spanend
#spandel
class LRComboCellRenderer extends JPanel implements ListCellRenderer {
#spanend
private final JLabel leftLabel = new JLabel();
private final JLabel rightLabel = new JLabel();
private final Color cfc = UIManager.getColor("ComboBox.foreground");
private final Color cbc = UIManager.getColor("ComboBox.background");
private final Color csfc = UIManager.getColor("ComboBox.selectionForeground");
private final Color csbc = UIManager.getColor("ComboBox.selectionBackground");
private final Color cdfc = UIManager.getColor("ComboBox.disabledForeground");
private final JComboBox combo;
public LRComboCellRenderer(JComboBox combo, int rightWidth, int labelHeight) {
public MultiColumnCellRenderer(int rightWidth) {
super(new BorderLayout());
this.combo = combo;
this.setBorder(BorderFactory.createEmptyBorder());
this.setOpaque(true);
leftLabel.setOpaque(true);
leftLabel.setBorder(BorderFactory.createEmptyBorder(0,2,0,0));
rightLabel.setOpaque(true);
rightLabel.setBorder(BorderFactory.createEmptyBorder(0,2,0,2));
rightLabel.setPreferredSize(new Dimension(rightWidth, labelHeight));
this.setBorder(BorderFactory.createEmptyBorder(1, 1, 1, 1));
#spanadd
#spanend
leftLabel.setOpaque(false);
leftLabel.setBorder(BorderFactory.createEmptyBorder(0, 2, 0, 0));
#spanadd
#spanend
final Dimension dim = new Dimension(rightWidth, 0);
rightLabel = new JLabel() {
@Override public Dimension getPreferredSize() {
return dim;
}
};
rightLabel.setOpaque(false);
rightLabel.setBorder(BorderFactory.createEmptyBorder(0, 2, 0, 2));
rightLabel.setForeground(Color.GRAY);
rightLabel.setHorizontalAlignment(SwingConstants.RIGHT);
#spanadd
#spanend
this.add(leftLabel);
this.add(rightLabel, BorderLayout.EAST);
}
//@Override
public Component getListCellRendererComponent(JList list, Object value,
int index, boolean isSelected,
boolean cellHasFocus) {
LRItem item = (LRItem)value;
#spanadd
#spanend
@Override public Component getListCellRendererComponent(
JList list, Object value, int index,
boolean isSelected, boolean cellHasFocus) {
LRItem item = (LRItem) value;
leftLabel.setText(item.getLeftText());
rightLabel.setText(item.getRightText());
leftLabel.setBackground(isSelected? csbc:cbc);
rightLabel.setBackground(isSelected? csbc:cbc);
this.setBackground(isSelected? csbc:cbc);
leftLabel.setForeground(isSelected? csfc:cfc);
rightLabel.setForeground(cdfc);
if(index==-1) {
Dimension dim = combo.getSize();
if(dim.width!=oldwidth) {
int count = combo.getItemCount()-1;
Insets i = combo.getInsets();
int w = dim.width-i.left-i.right;
int h = dim.height-i.top-i.bottom;
list.setPreferredSize(new Dimension(w, h*count));
oldwidth = dim.width;
}
leftLabel.setFont(list.getFont());
rightLabel.setFont(list.getFont());
#spanadd
#spanend
if (index < 0) {
leftLabel.setForeground(list.getForeground());
this.setOpaque(false);
} else {
leftLabel.setForeground(
isSelected ? list.getSelectionForeground() : list.getForeground());
this.setBackground(
isSelected ? list.getSelectionBackground() : list.getBackground());
this.setOpaque(true);
}
return this;
}
private int oldwidth = -1;
#spanadd
#spanend
@Override public Dimension getPreferredSize() {
Dimension d = super.getPreferredSize();
return new Dimension(0, d.height);
}
#spanadd
#spanend
@Override public void updateUI() {
super.updateUI();
this.setName("List.cellRenderer");
}
}
View in GitHub: Java, Kotlin解説
上記のサンプルでは、JLabelを二つ並べたJPanelをレンダラーにすることで、Itemに設定した文字列を左右に表示しています。このため文字列が長い場合、JLabelがこれを自動的にクリップしてくれます。解説
-
JPanel
にJLabel
を二つ並べて配置したセルレンダラーを作成し、Item
に設定した文字列を左右のJLabel
に表示 - このため左右の文字列が各
JLabel
の推奨サイズより長い場合は自動的に省略表示になる
参考リンク
- JComboBoxのItemを左右に配置
- こちらはhtmlのtableタグを使用して同様の表示(クリップはしない)を行っています。
参考リンク
- JComboBoxのItemを左右に配置
- こちらは
html
のtable
タグを使用して同様の表示(クリップはしない)を行っている
- こちらは
- JComboBoxのドロップダウンリストとしてJTableを使用する
- こちらは
JList
の代わりにJTable
を使用している
- こちらは
コメント
- ポップアップリストが更新されなくなって?、うまくクリップできなくなっていたのを修正。 -- aterai
コメント
- ポップアップリストが更新されなくなって?、うまくクリップできなくなっていたのを修正。 -- aterai
- 選択時の文字色を修正(
Windows 7
などへの対応)。 -- aterai