1

JFrameエレガントでより高度なレイアウトを行う方法を学ぼうとしています。かなり簡単だと思ったものを作ろうとしていますが、少し苦労しています。レイアウトを機能させるために何時間もいじくりまわすのとは対照的に (私は既に持っていますが)、私が説明しようとしているレイアウトの最良の規則は何かを尋ねようと思いました。

レイアウト
基本的には 2 列が必要ですが、最初の列は 2 番目の列よりも幅が広くなります。最初の列にはセルが 1 つだけあり、そのセルにはJLabelアイコンが付いた がセルの中央に配置されます。2 番目の列には 4 つの行があり、それぞれに がJComponent含まれます (内容は関係ありません)。もう 1 つの重要な点は、 内のすべてのコンポーネントがJFrame適切なサイズを保持し、そのセルや必要なものに合わせて伸縮しないことです。

希望するレイアウトの写真は次のとおりです。

ご希望のレイアウトイメージ

これまでのところ、これをいくつかの異なる方法で行うことを考えてきました。

  1. BorderLayout中央にJLabel- アイコンがあり、残りはGridLayout/で制御されます。GridBagLayout
  2. アイコンが 3x4 の領域を占有するGridBagLayout4x4 で、理論的にはスペースの 75% を占めます。JLabel

私が探している結果も得られません。考え/提案? すべてのヘルプと提案は大歓迎です。

4

2 に答える 2

2

あなたの最初の提案は合理的です。

ラベルは、垂直方向と水平方向の両方で中央揃えにすることができます。

GridLayout の場合、トリックは、デフォルトの gridbag 制約を持つ GridBagLayout を使用する JPanel に各コンポーネントを追加することです。次に、パネルを GridLayout に追加します。これで、フレームのサイズが変更された場合、パネルは拡大しますが、パネル上のコンポーネントは拡大せず、コンポーネントはパネルの中央に配置されます。

他のサブパネルで GridLayout を使用する代わりに、垂直の BoxLayout を使用して、すべてのコンポーネントの前後に「接着剤」を追加することもできます。このアプローチでは、すべてのコンポーネントが中央揃えの配置を使用していることを確認する必要があるわけではありません。また、一部のコンポーネントの最大サイズをコンポーネントの推奨サイズに等しく設定する必要がある場合もあります。これにより、スペースが使用可能になったときにコンポーネントが大きくならないようにすることができます。

于 2013-05-07T04:34:02.720 に答える
2

私自身の正気を保つために、通常はレイアウトの個々の要素を分離します。これにより、(各セクションにとって)重要なレイアウトの領域にのみ焦点を当てる必要があるため、プロセスが簡素化される場合があります。

次の例では、単一のレイアウトを使用して、GridBagLayout

ここに画像の説明を入力

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.io.File;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.imageio.ImageIO;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;

public class AdvancedLayout {

    public static void main(String[] args) {
        new AdvancedLayout();
    }

    public AdvancedLayout() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.setLayout(new BorderLayout());
                frame.add(new TestPane());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TestPane extends JPanel {

        private JLabel image;
        private JButton button;
        private JLabel label;
        private JComboBox comboBox;
        private JButton otherButton;

        public TestPane() {
            setLayout(new GridBagLayout());
            image = new JLabel();
            button = new JButton("A button");
            label = new JLabel("A label");
            comboBox = new JComboBox();
            otherButton = new JButton("Other");
            try {
                image.setIcon(new ImageIcon(ImageIO.read(new File("/path/to/a/image"))));
            } catch (IOException ex) {
                ex.printStackTrace();
            }
            GridBagConstraints gbc = new GridBagConstraints();
            gbc.gridx = 0;
            gbc.gridy = 0;
            gbc.weightx = 0.6666666666666667;
            gbc.weighty = 1f;
            gbc.gridheight = GridBagConstraints.REMAINDER;
            add(image, gbc);

            gbc.gridheight = 1;
            gbc.gridx++;
            gbc.weightx = 0.3333333333333333f;
            gbc.weighty = 0.25f;
            add(button, gbc);
            gbc.gridy++;
            add(label, gbc);
            gbc.gridy++;
            add(comboBox, gbc);
            gbc.gridy++;
            add(otherButton, gbc);

        }

    }

}

JPanelsこれは、画像用とオプション用の2 つの で簡単に使用できます。これにより、使用する必要がなくなりますgridheight...

于 2013-05-07T04:43:17.433 に答える