转:http://blog.csdn.net/liujun13579/article/details/7773945

卡片布局能够让多个组件共享同一个显示空间,共享空间的组件之间的关系就像一叠牌,组件叠在一起,初始时显示该空间中第一个添加的组件,通过CardLayout类提供的方法可以切换该空间中显示的组件。

1、  CardLayout类的常用构造函数及方法

2、  使用CardLayout类提供的方法可以切换显示该空间中的组件

方法一步骤:

(1)      定义使用卡片布局的容器

例如:Panel cardPanel=new Panel();

(2)      定义卡片对象:CardLayout 布局对象名称=new CardLayout();

例如:CardLayout card=new CardLayout();

(3)      设置使用卡片布局的容器为卡片布局:

格式:容器名称.setLayout(布局对象名称);

例如:cardPanel.setLayout(card);

(4)      设置容器中显示的组件

例如:for (int i = 0; i < 5; i++) {

cardPanel.add(newJButton("按钮"+i));

}

(5)      定义响应事件代码,让容器显示相应的组件

格式:

n  布局对象名称.next(容器名称)   显示容器中当前组件之后的一个组件,若当前组件为最后添加的组件,则显示第一个组件,即卡片组件显示是循环的。

n  布局对象名称.first(容器名称)   显示容器中第一个组件

n  布局对象名称.last(容器名称)   显示容器中最后一个组件

n  布局对象名称.previous(容器名称)   显示容器中当前组件之前的一个组件,若当前组件为第一个添加的组件,则显示最后一个组件,即卡片组件显示是循环的。

例如:

card.next(cardPanel);

card.previous(cardPanel);

card.first(cardPanel);

card.last(cardPanel);

实例一:卡片的切换

窗体默认边界布局,一个面板以卡片布局,面板上添加五个按钮,该面板添加到CENTER位置,另一个面板添加两个按钮,两个按钮添加事件来切换显示CENTER位置中的面板的组件

// cardlayout.java

import java.awt.*;

import javax.swing.*;

import java.awt.event.*;//引入事件包

//定义类时实现监听接口

public class cardlayout extendsJFrame implements ActionListener{

JButton nextbutton;

JButton preButton;

Panel cardPanel=new Panel();

Panel controlpaPanel=new Panel();

//定义卡片布局对象

CardLayout card=new CardLayout();

//定义构造函数

public cardlayout() {

super("卡片布局管理器");

setSize(300, 200);

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

setLocationRelativeTo(null);

setVisible(true);

//设置cardPanel面板对象为卡片布局

cardPanel.setLayout(card);

//循环,在cardPanel面板对象中添加五个按钮

//因为cardPanel面板对象为卡片布局,因此只显示最先添加的组件

for (int i = 0; i < 5; i++) {

cardPanel.add(new JButton("按钮"+i));

}

//实例化按钮对象

nextbutton=new JButton("下一张卡片");

preButton=new JButton("上一张卡片");

//为按钮对象注册监听器

nextbutton.addActionListener(this);

preButton.addActionListener(this);

controlpaPanel.add(preButton);

controlpaPanel.add(nextbutton);

//定义容器对象为当前窗体容器对象

Container container=getContentPane();

//将 cardPanel面板放置在窗口边界布局的中间,窗口默认为边界布局

container.add(cardPanel,BorderLayout.CENTER);

// 将controlpaPanel面板放置在窗口边界布局的南边,

container.add(controlpaPanel,BorderLayout.SOUTH);

}

//实现按钮的监听触发时的处理

public void actionPerformed(ActionEvent e){

//如果用户单击nextbutton,执行的语句

if (e.getSource()==nextbutton){

//切换cardPanel面板中当前组件之后的一个组件

//若当前组件为最后添加的组件,则显示第一个组件,即卡片组件显示是循环的。

card.next(cardPanel);

}

if (e.getSource()==preButton){

//切换cardPanel面板中当前组件之前的一个组件

//若当前组件为第一个添加的组件,则显示最后一个组件,即卡片组件显示是循环的。

card.previous(cardPanel);

}

}

public static void main(String[] args) {

cardlayout kapian=new cardlayout();

}

}

程序显示结果如下图所示,单击“上一张”、“下一张”等按钮可以上面的面板中显示不同的按钮来。

方法二步骤:

(1)      定义使用卡片布局的容器

例如:Panel cardPanel=new Panel();

(2)      定义卡片对象:CardLayout 布局对象名称=newCardLayout();

例如:CardLayout card=new CardLayout();

(3)      设置使用卡片布局的容器为卡片布局:

格式:容器名称.setLayout(卡片对象名称);

例如:cardPanel.setLayout(card);

(4)      设置容器中显示的组件,同时为组件命名对应的卡片名称

格式: 容器名称. Add(卡片名称,组件名称)

例如:for (int i = 0; i < 4; i++) {

cardPanel.add(“0”,newJButton("按钮"+i));

}

(5)      定义响应事件代码,让容器显示相应的组件

格式:卡片对象名称.show(容器名称,卡片名称)

例如:card.show(cardPanel,”0”);

实例二:使用CardLayout类的show方法显示组件。

窗体默认边界布局,一个面板以卡片布局,面板上添加4个按钮,该面板添加到CENTER位置,另一个面板添加4个按钮,这4个按钮添加事件来切换显示CENTER位置中的面板的组件按钮。

// cardlayout1.java

import java.awt.*;

import javax.swing.*;

import java.awt.event.*;//引入事件包

//定义类时 实现监听接口

public class cardlayout1extends JFrameimplements ActionListener{

JButton b0,b1,b2,b3;

Panel cardPanel=new Panel();

Panel controlpaPanel=newPanel();

//定义卡片布局对象

CardLayout card=newCardLayout();

//定义字符数组,为卡片命名

StringcardName[]={"0","1","2","3"};

//定义构造函数

public cardlayout1() {

super("卡片布局管理器");

setSize(400,200);

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

setLocationRelativeTo(null);

setVisible(true);

//设置cardPanel面板对象为卡片布局

cardPanel.setLayout(card);

//循环,在cardPanel面板对象中添加4个按钮

//因为cardPanel面板对象为卡片布局,因此初始时显示最先添加的组件

for (int i = 0; i< 4; i++) {

//面板中添加的每个按钮对应设置一个卡片名

cardPanel.add(cardName[i],newJButton("按钮"+i));

}

//实例化按钮对象

b0=newJButton("0");

b1=newJButton("1");

b2=newJButton("2");

b3=newJButton("3");

//为按钮对象注册监听器

b0.addActionListener(this);

b1.addActionListener(this);

b2.addActionListener(this);

b3.addActionListener(this);

controlpaPanel.add(b0);

controlpaPanel.add(b1);

controlpaPanel.add(b2);

controlpaPanel.add(b3);

//定义容器对象为当前窗体容器对象

Containercontainer=getContentPane();

//将 cardPanel面板放置在窗口边界布局的中间,窗口默认为边界布局

container.add(cardPanel,BorderLayout.CENTER);

// 将controlpaPanel面板放置在窗口边界布局的南边,

container.add(controlpaPanel,BorderLayout.SOUTH);

}

//实现按钮的监听触发时的处理

public voidactionPerformed(ActionEvent e){

//用户单击b0按钮时执行的语句

if(e.getSource()==b0){

//通过show()方法中的卡片名称,显示容器中的组件。

card.show(cardPanel,cardName[0]);

}

if(e.getSource()==b1){

card.show(cardPanel,cardName[1]);

}

if(e.getSource()==b2){

card.show(cardPanel,cardName[2]);

}

if(e.getSource()==b3){

card.show(cardPanel,cardName[3]);

}

}

public static voidmain(String[] args) {

cardlayout1kapian=new cardlayout1();

}

}

程序执行结果:

转:三十二、Java图形化界面设计——布局管理器之CardLayout(卡片布局)的更多相关文章

  1. 转:三十、Java图形化界面设计——布局管理器之BorderLayout(边界布局)

    http://blog.csdn.net/liujun13579/article/details/7772215 边界布局管理器把容器的的布局分为五个位置:CENTER.EAST.WEST.NORTH ...

  2. 三十、Java图形化界面设计——布局管理器之BorderLayout(边界布局)

    边界布局管理器把容器的的布局分为五个位置:CENTER.EAST.WEST.NORTH.SOUTH.依次相应为:上北(NORTH).下南(SOUTH).左西(WEST).右东(EAST),中(CENT ...

  3. 三十三、Java图形化界面设计——布局管理器之null布局(空布局)

    摘自http://blog.csdn.net/liujun13579/article/details/7774267 三十三.Java图形化界面设计--布局管理器之null布局(空布局) 一般容器都有 ...

  4. 三十一、Java图形化界面设计——布局管理器之GridLayout(网格布局)

    摘自http://blog.csdn.net/liujun13579/article/details/7772491 三十一.Java图形化界面设计--布局管理器之GridLayout(网格布局) 网 ...

  5. 转:三十三、Java图形化界面设计——布局管理器之null布局(空布局)——即SWT中的绝对布局

    http://blog.csdn.net/liujun13579/article/details/7774267    一般容器都有默认布局方式,但是有时候需要精确指定各个组建的大小和位置,就需要用到 ...

  6. 转:三十一、Java图形化界面设计——布局管理器之GridLayout(网格布局)

    http://blog.csdn.net/liujun13579/article/details/7772491 网格布局特点: l  使容器中的各组件呈M行×N列的网格状分布. l  网格每列宽度相 ...

  7. 三十二、Java图形化界面设计——布局管理器之CardLayout(卡片布局)

    摘自 http://blog.csdn.net/liujun13579/article/details/7773945 三十二.Java图形化界面设计--布局管理器之CardLayout(卡片布局) ...

  8. 转:二十七、Java图形化界面设计——容器(JFrame)

    转:http://blog.csdn.net/liujun13579/article/details/7756729 二十七.Java图形化界面设计——容器(JFrame) 程序是为了方便用户使用的, ...

  9. 二十七、Java图形化界面设计——容器(JFrame)

    摘自http://blog.csdn.net/liujun13579/article/details/7756729 二十七.Java图形化界面设计--容器(JFrame) 程序是为了方便用户使用的, ...

  10. Java图形化界面设计——容器(JFrame)

    Java图形化界面设计——容器(JFrame) 程序是为了方便用户使用的,因此实现图形化界面的程序编写是所有编程语言发展的必然趋势,在命令提示符下运行的程序可以让我们了解java程序的基本知识体系结构 ...

随机推荐

  1. T-SQL基础 (子查询,连接查询,交叉查询,事务|| 笔记0807)

    一: A.子查询: 1.select 字段名 from table where 字段名=(select 字段名 from table 条件)  //只能做1个匹配 2.select 字段名 from ...

  2. 开发一个完整的JavaScript组件

    作为一名开发者,大家应该都知道在浏览器中存在一些内置的控件:Alert,Confirm等,但是这些控件通常根据浏览器产商的不同而形态各异,视觉效果往往达不到UI设计师的要求.更重要的是,这类内置控件的 ...

  3. Objective-C description的用法

    description类似于.net/java ToString()方法的用途. 假设有一个CTPerson类, - (NSString *)description { return @"d ...

  4. iOS支付宝集成步骤;王刚韧的技术博客

  5. jQuery动态效果实例

    jQuery常见的动态效果: 隐藏/显示效果: 1.(1):隐藏,显示:通过 jQuery,使用 hide() 和 show() 方法可以用来隐藏和显示 HTML 元素. (2):隐藏/显示的速度: ...

  6. SSM配置

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  7. (转)Libevent(3)— 基础库

    转自:http://name5566.com/4202.html 参考文献列表:http://www.wangafu.net/~nickm/libevent-book/ 此文编写的时候,使用到的 Li ...

  8. Jquery 动态生成表单 并将表单数据 批量通过Ajax插入到数据库

    利用Jquery 动态生成 Table 表单 之后利用each 方法来遍历所有文本框获取文本的value值  并通过Ajax 将数据 提交到Web服务里把数据插入数据库 Html页面 <!DOC ...

  9. js函数与变量同名

    console.log(a); var a = 3; function a(){} 输出的结果是:[Function: a] 注意一下几点就能知道原因了! 1)函数声明会置顶2)变量声明也会置顶3)函 ...

  10. thinkphp给图片打水印不清晰

    项目中打印条形码的函数,从thinkphp自带的water函数修改而来的. 贴上代码: /** * water2 * 改写thinkphp的water函数更强健的函数,增加了写入位置参数 去掉了alp ...