Swing/ClippedCellTooltips のバックアップの現在との差分(No.2)
- バックアップ一覧
- 差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- バックアップ を表示
- Swing/ClippedCellTooltips へ行く。
- 1 (2009-10-12 (月) 17:37:22)
- 2 (2009-10-13 (火) 16:39:07)
- 3 (2011-03-13 (日) 21:44:49)
- 4 (2013-01-05 (土) 19:53:38)
- 5 (2013-10-17 (木) 14:57:55)
- 6 (2015-02-06 (金) 19:36:07)
- 7 (2015-03-12 (木) 15:08:59)
- 8 (2016-12-22 (木) 11:54:42)
- 9 (2016-12-22 (木) 19:16:41)
- 10 (2017-12-09 (土) 02:03:40)
- 11 (2019-08-07 (水) 20:21:19)
- 12 (2021-04-07 (水) 11:07:53)
- 13 (2023-03-23 (木) 21:44:23)
- 追加された行はこの色です。
- 削除された行はこの色です。
TITLE:JTableのセルがクリップされている場合のみJToolTipを表示 #navi(../) RIGHT:Posted by [[terai]] at 2009-10-12 *JTableのセルがクリップされている場合のみJToolTipを表示 [#kb1661a0] JTableのセルがクリップされている場合のみJToolTipを表示します。 --- category: swing folder: ClippedCellTooltips title: JTableのセルがクリップされている場合のみJToolTipを表示 tags: [JTable, JTableHeader, TableCellRenderer, JToolTip] author: aterai pubdate: 2009-10-12T17:37:22+09:00 description: JTableのセルがクリップされている場合のみJToolTipを表示します。 image: https://lh4.googleusercontent.com/_9Z4BYR88imo/TQTJNQAyg-I/AAAAAAAAAUA/F6oQbiUShl4/s800/ClippedCellTooltips.png --- * 概要 [#summary] `JTable`のセルがクリップされている場合のみ`JToolTip`を表示します。 -&jnlp; -&jar; -&zip; #download(https://lh4.googleusercontent.com/_9Z4BYR88imo/TQTJNQAyg-I/AAAAAAAAAUA/F6oQbiUShl4/s800/ClippedCellTooltips.png) #screenshot **サンプルコード [#a310ddc6] #code{{ * サンプルコード [#sourcecode] #code(link){{ class ToolTipHeaderRenderer implements TableCellRenderer { private final TableCellRenderer renderer; private final Icon icon = UIManager.getIcon("Table.ascendingSortIcon"); public ToolTipHeaderRenderer(TableCellRenderer renderer) { this.renderer = renderer; } public Component getTableCellRendererComponent(JTable table,Object value, boolean isSelected, boolean hasFocus, int row, int column) { JLabel l = (JLabel)renderer.getTableCellRendererComponent( table, value, isSelected, hasFocus, row, column); Insets i = l.getInsets(); Rectangle rect = table.getCellRect(row, column, false); rect.width -= i.left + i.right; RowSorter<? extends TableModel> sorter = table.getRowSorter(); if(sorter!=null && !sorter.getSortKeys().isEmpty() && sorter.getSortKeys().get(0).getColumn()==column) { rect.width -= icon.getIconWidth() + 2; //XXX // private final Icon icon = UIManager.getIcon("Table.ascendingSortIcon"); @Override public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) { JTableHeader header = table.getTableHeader(); TableCellRenderer r = header.getDefaultRenderer(); Component c = r.getTableCellRendererComponent( table, value, isSelected, hasFocus, row, column); if (c instanceof JLabel) { JLabel l = (JLabel) c; Insets i = l.getInsets(); Rectangle rect = header.getHeaderRect(column); rect.width -= i.left + i.right; boolean isClipped = isClipped(l, rect); // isClipped = fontMetrics.stringWidth(l.getText()) > rect.width; l.setToolTipText(isClipped ? l.getText() : header.getToolTipText()); } FontMetrics fm = l.getFontMetrics(l.getFont()); String str = value.toString(); int cellTextWidth = fm.stringWidth(str); l.setToolTipText(cellTextWidth>rect.width?str:null); return l; return c; } private static boolean isClipped(JLabel label, Rectangle viewR) { Rectangle iconR = new Rectangle(); Rectangle textR = new Rectangle(); String str = SwingUtilities.layoutCompoundLabel( label, label.getFontMetrics(label.getFont()), label.getText(), label.getIcon(), label.getVerticalAlignment(), label.getHorizontalAlignment(), label.getVerticalTextPosition(), label.getHorizontalTextPosition(), viewR, iconR, textR, label.getIconTextGap()); return !Objects.equals(label.getText(), str); } } }} **解説 [#rb49016f] -ヘッダセル --TableCellRendererで、セルの幅と文字列の長さを比較して、ToolTipを設定 --ソートアイコンと文字列の間のgapが不明? * 解説 [#explanation] - ヘッダセル -- `TableCellRenderer`内でセルの幅と文字列の長さを比較し`ToolTip`を設定 -- ソートアイコンなどが存在する場合を考慮して`SwingUtilities.layoutCompoundLabel(...)`メソッドを使用して`JLabel`内の文字列が省略されているかどうかを判断する -- %%ソートアイコンと文字列の間隔は`JLabel#getIconTextGap()`で取得してセル幅から除外する%% --- %%`Windows 10`で使用される`WindowsLookAndFeel`のように文字列の上にソートアイコンが表示される場合(`TableCellRenderer#getIcon()`が`null`)はこのアイコンの幅を無視する%% - セル -- `JTable#prepareRenderer`メソッドをオーバーライドし、セルの幅と文字列の長さを比較して`ToolTip`を設定 -セル --JTable#prepareRendererメソッドをオーバーライドし、セルの幅と文字列の長さを比較して、ToolTipを設定 #code{{ JTable table = new JTable(model) { public Component prepareRenderer(TableCellRenderer tcr, int row, int column) { @Override public Component prepareRenderer( TableCellRenderer tcr, int row, int column) { Component c = super.prepareRenderer(tcr, row, column); if(c instanceof JComponent) { JComponent l = (JComponent)c; Object o = getValueAt(row, column); Insets i = l.getInsets(); Rectangle rect = getCellRect(row, column, false); rect.width -= i.left + i.right; FontMetrics fm = l.getFontMetrics(l.getFont()); String str = o.toString(); int cellTextWidth = fm.stringWidth(str); l.setToolTipText(cellTextWidth>rect.width?str:null); if (c instanceof JComponent) { JComponent l = (JComponent) c; Insets i = l.getInsets(); Rectangle rect = getCellRect(row, column, false); rect.width -= i.left + i.right; FontMetrics fm = l.getFontMetrics(l.getFont()); String str = Objects.toString(getValueAt(row, column), ""); int cellTextWidth = fm.stringWidth(str); l.setToolTipText(cellTextWidth > rect.width ? str : getToolTipText()); } return c; } }; }} **参考リンク [#l13d8dfe] -[[JTableHeaderのTooltipsを列ごとに変更>Swing/HeaderTooltips]] -[[JTableのTooltipsを行ごとに変更>Swing/RowTooltips]] * 参考リンク [#reference] - [[JTableHeaderのTooltipsを列ごとに変更>Swing/HeaderTooltips]] - [[JTableのTooltipsを行ごとに変更>Swing/RowTooltips]] - [[Fontから文字列の境界を取得する>Swing/StringBounds]] **コメント [#kb103118] * コメント [#comment] #comment #comment