Swing/OneTouchButton のバックアップ(No.6)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/OneTouchButton へ行く。
- 1 (2014-10-19 (日) 19:02:41)
- 2 (2015-11-12 (木) 21:57:59)
- 3 (2016-05-17 (火) 01:52:12)
- 4 (2017-08-18 (金) 14:51:40)
- 5 (2018-05-31 (木) 14:40:30)
- 6 (2018-11-02 (金) 19:36:13)
- 7 (2020-11-04 (水) 16:06:49)
- 8 (2022-08-08 (月) 02:12:40)
- 9 (2025-01-03 (金) 08:57:02)
- 10 (2025-01-03 (金) 09:01:23)
- 11 (2025-01-03 (金) 09:02:38)
- 12 (2025-01-03 (金) 09:03:21)
- 13 (2025-01-03 (金) 09:04:02)
- category: swing
folder: OneTouchButton
title: JSplitPaneのDividerを展開収納するOneTouchButtonのサイズ、色などを変更
tags: [JSplitPane, SplitPaneDivider, JButton, LookAndFeel]
author: aterai
pubdate: 2014-09-08T00:05:45+09:00
description: JSplitPaneのDividerをワンクリックで展開・収納するためのOneTouchButtonのサイズ、オフセット、背景色などを変更します。
image:
概要
JSplitPane
のDivider
をワンクリックで展開・収納するためのOneTouchButton
のサイズ、オフセット、背景色などを変更します。
Screenshot

Advertisement
サンプルコード
UIManager.put("SplitPane.oneTouchButtonSize", 32);
UIManager.put("SplitPane.oneTouchButtonOffset", 50);
//UIManager.put("SplitPane.centerOneTouchButtons", true);
UIManager.put("SplitPaneDivider.border", BorderFactory.createLineBorder(Color.RED, 10));
UIManager.put("SplitPaneDivider.draggingColor", new Color(255, 100, 100, 100));
BasicSplitPaneDivider divider = ((BasicSplitPaneUI) splitPane.getUI()).getDivider();
divider.setBackground(Color.ORANGE);
for (Component c: divider.getComponents()) {
if (c instanceof JButton) {
JButton b = (JButton) c;
b.setBackground(Color.ORANGE);
}
}
View in GitHub: Java, Kotlin解説
上記のサンプルでは、OneTouchButton
(JSplitPane
のDivider
をワンクリックで展開・収納するためのJButton
)のサイズ、オフセット、背景色などを変更しています。
OneTouchButton
のサイズ指定UIManager.put("SplitPane.oneTouchButtonSize", 32);
MetalLookAndFeel
では無効NimbusLookAndFeel
では無効で、Divider
のサイズに依存?
OneTouchButton
のオフセット指定UIManager.put("oneTouchButtonOffset", 50);
JSplitPane.VERTICAL_SPLIT
の場合、Divider
の左端からLeftOneTouchButton
までの距離が設定可能NimbusLookAndFeel
のデフォルトは、30
になっているため、JSplitPane.HORIZONTAL_SPLIT
でDivider
の高さがそれ以下の場合は、OneTouchButton
が表示できない
OneTouchButton
の背景色JButton#paint(...)
がオーバーライドされて、oneTouchButton.getBackground()
の色で塗り潰されている(oneTouchButton.setOpaque(false)
で透明にしても無意味)ので、setBackground()
で、Divider
の背景色と同じ色を設定OneTouchButton
の図形の色と形も、JButton#paint(...)
の中で直接描画(Color.BLACK
固定)されているので、簡単に変更することが出来ない(BasicSplitPaneUI
やBasicSplitPaneDivider
をオーバーライドする必要がある)
MetalLookAndFeel
、NimbusLookAndFeel
では無効
OneTouchButton
の中央揃えUIManager.put("SplitPane.centerOneTouchButtons", true);
MetalLookAndFeel
、MotifLookAndFeel
、WindowsLookAndFeel
、NimbusLookAndFeel
などでは、効果が無い
Divider
のBorder
と、OneTouchButton
divider.setBorder(BorderFactory.createMatteBorder(20, 0, 5, 0, Color.RED));
などを設定すると、OneTouchButton
がBorder
にめり込んでしまう?