Swing/GridBagLayout のバックアップ(No.21)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/GridBagLayout へ行く。
- 1 (2004-06-02 (水) 09:56:26)
- 2 (2004-06-04 (金) 07:26:55)
- 3 (2004-07-23 (金) 03:02:12)
- 4 (2004-10-08 (金) 06:22:54)
- 5 (2004-11-04 (木) 10:08:17)
- 6 (2004-12-16 (木) 01:48:26)
- 7 (2005-04-28 (木) 04:32:53)
- 8 (2005-05-11 (水) 07:11:30)
- 9 (2005-06-27 (月) 06:44:30)
- 10 (2005-07-01 (金) 02:26:40)
- 11 (2005-10-13 (木) 15:58:48)
- 12 (2006-02-27 (月) 15:59:18)
- 13 (2006-06-13 (火) 12:41:02)
- 14 (2007-07-13 (金) 19:45:36)
- 15 (2007-07-25 (水) 12:38:17)
- 16 (2007-08-09 (木) 20:09:11)
- 17 (2008-10-28 (火) 15:04:42)
- 18 (2008-11-12 (水) 21:19:19)
- 19 (2013-02-26 (火) 14:55:09)
- 20 (2013-05-03 (金) 23:44:28)
- 21 (2015-10-13 (火) 20:11:08)
- 22 (2017-04-18 (火) 15:08:38)
- 23 (2018-04-10 (火) 17:06:36)
- 24 (2020-04-07 (火) 16:40:49)
- 25 (2021-10-12 (火) 10:34:36)
- title: GridBagLayoutの使用 tags: [GridBagLayout, LayoutManager] author: aterai pubdate: 2003-09-15 description: GridBagLayoutを使用して、左右の部品のサイズを固定、中央だけは水平方向に伸縮可になるよう配置します。
概要
GridBagLayout
を使用して、左右の部品のサイズを固定、中央だけは水平方向に伸縮可になるよう配置します。
Screenshot
Advertisement
サンプルコード
public JPanel createPanel(JComponent cmp, JButton btn, String str) {
GridBagConstraints c = new GridBagConstraints();
JPanel panel = new JPanel(new GridBagLayout());
c.gridheight = 1;
c.gridwidth = 1;
c.gridy = 0;
c.gridx = 0;
c.weightx = 0.0;
c.insets = new Insets(5, 5, 5, 0);
c.anchor = GridBagConstraints.WEST;
panel.add(new JLabel(str), c);
c.gridx = 1;
c.weightx = 1.0;
//c.insets = new Insets(5, 5, 5, 0);
c.fill = GridBagConstraints.HORIZONTAL;
panel.add(cmp, c);
c.gridx = 2;
c.weightx = 0.0;
c.insets = new Insets(5, 5, 5, 5);
c.anchor = GridBagConstraints.WEST;
panel.add(btn, c);
return panel;
}
View in GitHub: Java, Kotlin解説
上記のサンプルでは、GridBagLayout
でBorderLayout
のような配置を行っています。ただし、GridBagLayout
の場合は、各コンポーネントが推奨する高さが生かされるように設定しています。
BorderLayout
- それぞれデフォルトの高さが違うコンポーネントを、
BorderLayout
を使って、WEST
、CENTER
、EAST
に配置すると、一番高いコンポーネントに揃えられる。 CENTER
のJComboBox
が、EAST
のJButton
の高さになっている(スクリーンショット参照)。MotifLookAndFeel
の場合
- それぞれデフォルトの高さが違うコンポーネントを、
GridBagLayout
- 左右のコンポーネントのサイズは
BorderLayout
のように固定して、中央のコンポーネントだけを水平方向にのみ伸縮させる。 weightx
を指定することで、余分のスペースを各列のウェイトに比例して分配している。- ウェイトが
0
の場合、余分のスペースはその列に分配されない。 - 左右の列の
weightx
が0.0
なので、中央の列のweightx
は、0.001
でも100.0
でも水平方向の余分なスペースすべてが配分されている。 - 垂直方向のスペースは指定していないため、デフォルト値の
weighty=0.0
となり、フレームのサイズを変更しても、垂直方向に関しては常にコンポーネントの推奨サイズで固定される。
- 左右のコンポーネントのサイズは
IDE
などのサポート無しでは、すこし面倒なGridBagLayout
ですが、GridBagの使い方1の「紙などにマス目で下書きをしてから、コンポーネントのレイアウトを設計する」方法を使えば、凝ったレイアウトでも理解しやすく、すっきり設計できます。