Swing佈局管理器介紹

當選擇使用 JPanel 和頂層容器的 content pane 時,須要考慮佈局管理。 JPanel 缺省是初始化一個 FlowLayout ,而 content pane 缺省是初始化一個 BorderLayout
下面將分別介紹幾種最經常使用的佈局管理器: FlowLayout BorderLayout BoxLayout CardLayout GridLayout GridBagLayout
 
代碼演示
每個佈局管理器都會有一個代碼演示, xxxLayoutDemo.java (見附件)。這些文件主要有三個方法組成:
addComponentsToPane() 提供佈局邏輯(依據不一樣的佈局管理器和 UI 內容)。
public static void addComponentsToPane(Container pane) { 。。。 }
createAndShowGUI() 實例化一個 JFrame ,經過它的 ContentPane 加載佈局邏輯內容。
private static void createAndShowGUI() {
    // Create and set up the window.
    JFrame frame = new JFrame( "FlowLayoutDemo" );
    frame.setDefaultCloseOperation(JFrame. EXIT_ON_CLOSE );
    // Set up the content pane.
    addComponentsToPane(frame.getContentPane());
    // Display the window.
    frame.pack();
    frame.setVisible( true );
}
main() 程序入口,單獨起一個線程,實例化 UI
public static void main(String[] args) {
    javax.swing.SwingUtilities.invokeLater( new Runnable() {
       public void run() {
           createAndShowGUI();
       }
    });
}
 
FlowLayout
FlowLayout 類是最簡單的佈局管理器。它按照和頁面上排列單詞的相似方式來安排組件 ---- 從左到右,直至沒有多餘的空間,而後轉到下一行。
效果:
內容面板代碼:
public static void addComponentsToPane(Container pane) {
    pane.setLayout( new FlowLayout());
    pane.add( new JButton( "Button 1" ));
    pane.add( new JButton( "Button 2" ));
    pane.add( new JButton( "Button 3" ));
    pane.add( new JButton( "Long-Named Button 4" ));
    pane.add( new JButton( "5" ));
}
 
BorderLayout
一個 BorderLayout 對象將界面分紅五大區域,分別用 BorderLayout 類的靜態常量指定:
-PAGE_START
-PAGE_END
-LINE_START
-LINE_END
-CENTER
效果:
內容面板代碼:
public static void addComponentsToPane(Container pane) {      
    JButton button = new JButton( "Button 1 (PAGE_START)" );
    pane.add(button, BorderLayout. PAGE_START );     
    button = new JButton( "Button 2 (CENTER)" );
    button.setPreferredSize( new Dimension(200, 100));
    pane.add(button, BorderLayout. CENTER );   
    button = new JButton( "Button 3 (LINE_START)" );
    pane.add(button, BorderLayout. LINE_START );     
    button = new JButton( "Long-Named Button 4 (PAGE_END)" );
    pane.add(button, BorderLayout. PAGE_END );      
    button = new JButton( "5 (LINE_END)" );
    pane.add(button, BorderLayout. LINE_END );
}
 
BoxLayout
BoxLayout 能夠將組件由上至下或由左至右依次加入當前面板。
效果:
內容面板代碼:
public static void addComponentsToPane(Container pane) {
    JPanel xPanel = new JPanel();
    xPanel.setLayout( new BoxLayout(xPanel, BoxLayout. X_AXIS ));
    addButtons(xPanel);
    JPanel yPanel = new JPanel();
    yPanel.setLayout( new BoxLayout(yPanel, BoxLayout. Y_AXIS ));
    addButtons(yPanel);
   
    pane.add(yPanel, BorderLayout. PAGE_START );
    pane.add(xPanel, BorderLayout. PAGE_END );
}
 
private static void addAButton(String text, Container container) {
    JButton button = new JButton(text);
    button.setAlignmentX(Component. CENTER_ALIGNMENT );
    container.add(button);
}
 
private static void addButtons(Container container) {
    addAButton( "Button 1" , container);
    addAButton( "Button 2" , container);
    addAButton( "Button 3" , container);
    addAButton( "Long-Named Button 4" , container);
    addAButton( "5" , container);
}
 
CardLayout
卡片佈局和其餘佈局不一樣,由於它隱藏了一些組件。卡片佈局就是一組容器或者組件,它們一次僅僅顯是一個,組中的每一個容器稱爲卡片。
效果:
內容面板代碼:
public void addComponentToPane(Container pane) {
    final JPanel contentPanel = new JPanel();
    JPanel controlPanel = new JPanel();
    final CardLayout cardLayout= new CardLayout();;
    pane.setLayout( new BorderLayout());
    pane.add(contentPanel, BorderLayout. CENTER );
    pane.add(controlPanel, BorderLayout. PAGE_END );
    controlPanel.setLayout( new FlowLayout());
 
    JButton[] b = new JButton[10];
    for ( int i = 0; i < 10; i++) {
       b[i] = new JButton( "No." + i);
       contentPanel.add(b[i]);
    }
    contentPanel.setLayout(cardLayout);
    JButton nextButton = new JButton( "next" );
    nextButton.addActionListener( new ActionListener(){
       public void actionPerformed(ActionEvent e) {
           cardLayout.next(contentPanel);
       }});
    controlPanel.add(nextButton);
}
 
GridLayout
GridLayout 讓你創建一個組件表格,而且當組件加入時,會依序又左至右,由上至下填充到每一個格子,它不能由你指定想放那個格子就放那個格子
效果:
內容面板代碼:
public static void addComponentsToPane(Container pane) {
    JButton[] buttons = new JButton[9];
    pane.setLayout( new GridLayout(3, 3));
    for ( int i = 0; i < buttons. length ; i++) {
       buttons[i] = new JButton(i + "" );
       pane.add(buttons[i]);
    }
}
 
GridBagLayout
GridBagLayout 是全部AWT 佈局管理器當中最複雜的,同時他的功能也是最強大的。GridBagLayout GridLayout 同樣,在容器中以網格形式來管理組件。但GridBagLayout 功能要來得強大得多。
1 GridBagLayout 管理的全部行和列均可以是大小不一樣的;
2 GridLayout 把每一個組件限制到一個單元格,而GridBagLayout 並不這樣:組件在容器中能夠佔據任意大小的矩形區域。
GridBagLayout 一般由一個專用類來對他佈局行爲進行約束,該類叫GridBagConstraints 。其中有11 個公有成員變量, GridBagConstraints 能夠從這 11 個方面來進行控制和操縱。這些內容是:
1 gridx— 組件的橫向座標;
2 girdy— 組件的縱向座標;
3 gridwidth— 組件的橫向寬度,也就是指組件佔用的列數;
4 gridheight— 組件的縱向長度,也就是指組件佔用的行數;
5 weightx— 指行的權重,告訴佈局管理器如何分配額外的水平空間;
6 weighty— 指列的權重,告訴佈局管理器如何分配額外的垂直空間;
7 anchor— 當組件小於其顯示區域時使用此字段;
8 fill— 若是顯示區域比組件的區域大的時候,能夠用來控制組件的行爲。控制組件是垂直填充,仍是水平填充,或者兩個方向一塊兒填充;
9 insets— 指組件與表格空間四周邊緣的空白區域的大小;
10 ipadx—  組件間的橫向間距,組件的寬度就是這個組件的最小寬度加上 ipadx 值;
11 ipady—  組件間的縱向間距,組件的高度就是這個組件的最小高度加上 ipady 值。
說明:
1 gridx gridy :其實就是組件行列的設置,注意都是從 0 開始的,好比 gridx=0 gridy=1 時放在 0 1 列;
2 gridwidth gridheight :默認值爲 1 GridBagConstraints.REMAINDER 常量,表明此組件爲此行或此列的最後一個組件,會佔據全部剩餘的空間;
3 weightx weighty :當窗口變大時,設置各組件跟着變大的比例。好比組件 A weightx=0.5 ,組件 B weightx=1 ,那麼窗口 X 軸變大時剩餘的空間就會以 1 2 的比例分配給組件 A B
4 anchor :當組件空間大於組件自己時,要將組件置於何處。 CENTER (默認值)、 NORTH NORTHEAST EAST SOUTHEAST WEST NORTHWEST 選擇。
5 insets :設置組件之間彼此的間距。它有四個參數,分別是上,左,下,右,默認爲( 0 0 0 0 )。
效果:
內容面板代碼:
public static void addComponentsToPane(Container pane) {
    JButton button;
    pane.setLayout( new GridBagLayout());
    GridBagConstraints c = new GridBagConstraints();
 
    button = new JButton( "Button 1" );
    c. fill = GridBagConstraints. HORIZONTAL ;
    c. gridx = 0;
    c. gridy = 0;
    pane.add(button, c);
 
    button = new JButton( "Button 2" );
    c. fill = GridBagConstraints. HORIZONTAL ;
    c. weightx = 0.5;
    c. gridx = 1;
    c. gridy = 0;
    pane.add(button, c);
 
    button = new JButton( "Button 3" );
    c. fill = GridBagConstraints. HORIZONTAL ;
    c. weightx = 0.5;
    c. gridx = 2;
    c. gridy = 0;
    pane.add(button, c);
 
    button = new JButton( "Long-Named Button 4" );
    c. fill = GridBagConstraints. HORIZONTAL ;
    c. ipady = 40; // make this component tall
    c. weightx = 0.0;
    c. gridwidth = 3;
    c. gridx = 0;
    c. gridy = 1;
    pane.add(button, c);
 
    button = new JButton( "5" );
    c. fill = GridBagConstraints. HORIZONTAL ;
    c. ipady = 0; // reset to default
    c. weighty = 1.0; // request any extra vertical space
    c. anchor = GridBagConstraints. PAGE_END ; // bottom of space
    c. insets = new Insets(10, 0, 0, 0); // top padding
    c. gridx = 1; // aligned with button 2
    c. gridwidth = 2; // 2 columns wide
    c. gridy = 2; // third row
    pane.add(button, c);
    }
 
一個 GardBagLayout 佈局的左右選擇框,代碼 GridBagLayoutFrame.java 見附件,效果:
相關文章
相關標籤/搜索