歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

Java布局管理器之CardLayout(卡片布局管理器)

對於選項卡這個概念大家可能不會陌生,就是在一個窗口中可以切換顯示多頁不同的內容,但同一時間只能是其中的某一頁可見的,這樣的一個個的頁面就是選項卡。

CardLayout就是類似的這樣一個布局管理器,它能夠讓多個組件共享同一個顯示空間,共享空間的組件之間的關系就像重疊在一起的一幅撲克牌,組件重疊在一起,初始時顯示該空間中第一個組件,通過CardLayout類提供的方法可以切換該空間中顯示的組件。

下面我們來看一個例子,實現CardLayout布局管理器的使用。

創建一個使用CardLayout布局的面板:
// 卡片布局管理器
private CardLayout cardLayout;
// 使用卡片布局管理器的面板
private JPanel cardPnl;

cardLayout = new CardLayout();
cardPnl = new JPanel(cardLayout);


向面板中添加幾張圖片,因為面板使用卡片布局,所以所添加的圖片是重疊在一起的:
/* 向面板中添加幾張圖片 */
for (int i = 0; i < 8; i++) {
    final int j = i + 1;
    // 將圖片繪制到面板中
    JPanel img = new JPanel() {
        private static final long serialVersionUID = 1L;
        @Override
        protected void paintComponent(Graphics g) {
            g.drawImage(
                    Toolkit.getDefaultToolkit().getImage(
                            "images/Freedom" + j + ".gif"), 0, 0, null);
        }
    };
    // 將圖片面板添加到使用了CardLayout的容器面板中
    cardPnl.add("Freedom" + j, img);
}


添加兩個按鈕,用於顯示上一張圖片與下一張圖片,並為按鈕注冊事件監聽器,處理事件的方法:
/**
 * 處理按鈕點擊事件
 */
@Override
public void actionPerformed(ActionEvent e) {
    String cmd = e.getActionCommand(); // 獲取是何種操作
    if ("next".equals(cmd)) // 顯示下一張圖片
        cardLayout.next(cardPnl); // 切換下一個選項卡
    else if ("previous".equals(cmd)) // 顯示上一張圖片
        cardLayout.previous(cardPnl); // 切換上一個選項卡
}


我們可以通過調用CardLayout的next()方法翻轉到指定容器的下一張卡片,如果當前的可見卡片是最後一個,則翻轉到布局的第一張卡片。同樣,也可以使用previout()方法翻轉到指定容器的前一張卡片。除了這兩個方法外,還有last()、first()方法可以翻轉到最後一張、第一張卡片,我們也可以直接使用show()方法翻轉到指定名稱的卡片。

完整示例代碼:

package cardLayout;

import java.awt.BorderLayout;
import java.awt.CardLayout;
import java.awt.Graphics;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JTextField;

/**
 * 測試卡片布局管理器 如果插入圖片的名字不相同的話,就要用多個面板去繪制,因為一個面板只裝一張圖。名字相同就可以用循環。
 *
 * @author hellokitty燕
 *
 */
public class CardLayoutDemo2 extends JFrame implements ActionListener {

    private static final long serialVersionUID = 1L;

    private CardLayout cardLayout;// 卡片布局管理器
    private JPanel jPanel;// 使用卡片布局管理器的面板
    private JTextField jTextField;// 用於你輸入的跳轉頁面

    public CardLayoutDemo2() {

        setTitle("布局管理器之CardLayout");
        setSize(600, 600);
        setDefaultCloseOperation(EXIT_ON_CLOSE);
        setLocationRelativeTo(null);

        /* 創建兩個按鈕,添加到窗體底部,默認窗體布局采用BorderLayout */
        JPanel jp = new JPanel();// 面板默認布局使用FlowLayout

        JButton up = new JButton("上一張");
        JButton next = new JButton("下一張");
        jTextField = new JTextField("2");
        JButton go = new JButton("go");

        jp.add(up);
        jp.add(next);
        jp.add(jTextField);
        jp.add(go);
        // 注冊按鈕監聽事件

        up.addActionListener(this);
        next.addActionListener(this);
        go.addActionListener(this);
        this.add(jp, BorderLayout.SOUTH);

        /* 創建使用CardLayout布局管理器的容器 */
        cardLayout = new CardLayout();
        jPanel = new JPanel(cardLayout);

        /* 向面板中添加幾張圖片 */

        // 將圖片繪制到面板中 /
        JPanel images = new JPanel() {
            private static final long serialVersionUID = 1L;

            @Override
            protected void paintComponent(Graphics g) {
                super.paintComponent(g);
                g.drawImage(
                        Toolkit.getDefaultToolkit().getImage(
                                "src/images/sprite.png"), 200, 100, this);

            }

        };
        // 將圖片面板添加到使用了cardLayout容器面板中

        jPanel.add("sprite", images);

        JPanel img = new JPanel() {

            private static final long serialVersionUID = 1L;

            @Override
            protected void paintComponent(Graphics g) {
                super.paintComponent(g);
                g.drawImage(
                        Toolkit.getDefaultToolkit().getImage(
                                "src/images/Freedom1.gif"), 200, 100, this);
            }

        };

        jPanel.add("Freedom1", img);

        JPanel im = new JPanel() {

            private static final long serialVersionUID = 1L;

            @Override
            protected void paintComponent(Graphics g) {
                super.paintComponent(g);
                g.drawImage(
                        Toolkit.getDefaultToolkit().getImage(
                                "src/images/sprite1.png"), 200, 100, this);
            }

        };
        jPanel.add("sprite1", im);

        // 將使用了CardLayout的面板添加到窗體中顯示
        this.add(jPanel, BorderLayout.CENTER);

        setVisible(true);

    }

    @Override
    public void actionPerformed(ActionEvent e) {
        String cmd = e.getActionCommand();
        if ("下一張".equals(cmd)) {
            cardLayout.next(jPanel); // 切換下一個選項卡
        } else if ("上一張".equals(cmd)) {
            cardLayout.previous(jPanel);// 切換上一個選項卡
        } else if ("go".equals(cmd)) {
            cardLayout.show(jPanel, "Freedom" + jTextField.getText());//這個主要是用於名字相似的圖片,如果你想跳轉的圖片名字不一樣的話,你就可以去把圖片的名字改成相似的。
        }

    }

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

運行效果:

Copyright © Linux教程網 All Rights Reserved