Swing/OverlayLayout のバックアップソース(No.11)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- バックアップ を表示
- Swing/OverlayLayout へ行く。
- 1 (2008-01-17 (木) 20:39:30)
- 2 (2008-10-29 (水) 18:45:42)
- 3 (2009-08-20 (木) 16:38:06)
- 4 (2011-03-20 (日) 16:55:33)
- 5 (2011-05-31 (火) 03:18:55)
- 6 (2013-06-12 (水) 15:37:05)
- 7 (2014-10-24 (金) 16:28:49)
- 8 (2015-03-12 (木) 15:07:29)
- 9 (2016-12-24 (土) 20:35:55)
- 10 (2017-04-04 (火) 14:17:08)
- 11 (2017-12-08 (金) 16:16:09)
- 12 (2019-08-15 (木) 14:37:53)
- 13 (2021-04-08 (木) 13:27:25)
--- category: swing folder: OverlayLayout title: OverlayLayoutの使用 tags: [OverlayLayout, LayoutManager, JButton] author: aterai pubdate: 2008-01-14T17:09:44+09:00 description: OverlayLayoutを使用し、JButtonを重ねて配置します。 image: https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTQqzbG85I/AAAAAAAAAf8/GAYWzSVrHvg/s800/OverlayLayout.png --- * 概要 [#summary] `OverlayLayout`を使用し、`JButton`を重ねて配置します。 #download(https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTQqzbG85I/AAAAAAAAAf8/GAYWzSVrHvg/s800/OverlayLayout.png) * サンプルコード [#sourcecode] #code(link){{ JButton b1 = new JButton(); JButton b2 = new JButton(); b1.setLayout(new OverlayLayout(b1)); Insets i = b1.getBorder().getBorderInsets(b1); b1.setBorder(BorderFactory.createEmptyBorder(i.top, i.left, i.bottom, 4)); b1.setAction(new AbstractAction("OverlayLayoutButton") { @Override public void actionPerformed(ActionEvent e) { Toolkit.getDefaultToolkit().beep(); } }); JButton b2 = new JButton() { private final Dimension dim = new Dimension(120, 24); @Override public Dimension getPreferredSize() { return dim; } @Override public Dimension getMaximumSize() { return getPreferredSize(); } @Override public Dimension getMinimumSize() { return getPreferredSize(); } }; b2.setAction(new AbstractAction("▼") { @Override public void actionPerformed(ActionEvent e) { System.out.println("sub"); } }); b2.setAlignmentX(Component.RIGHT_ALIGNMENT); b2.setAlignmentY(Component.BOTTOM_ALIGNMENT); b1.add(b2); }} * 解説 [#explanation] 上記のサンプルでは、`JButton`に`OverlayLayout`を使って、別の`JButton`を右下に重ねて配置しています。 * 参考リンク [#reference] - [https://docs.oracle.com/javase/tutorial/uiswing/layout/box.html#features Box Layout Features] - [[JTextAreaをキャプションとして画像上にスライドイン>Swing/EaseInOut]] * コメント [#comment] #comment - ボタンサイズの指定方法を変更しました。 -- &user(aterai); &new{2008-01-17 (木) 20:39:53}; - スクリーンショットなどを更新。 -- &user(aterai); &new{2008-10-29 (水) 18:51:52}; #comment