Swing-选项卡面板JTabbedPane-入门
注:非原创,内容源自《Swing 的选项卡面板》,笔者做了少量修改。
选项卡面板是一个很常用的Swing组件,在window下,右击我的电脑,查看属性,就是一个典型的选修卡面板。当然还有最经典的谷歌浏览器,也是选项卡的一个典型。Swing中的选项卡使用JTabbedPane类来实现,下面就来介绍JTabbedPane的使用:
1.构建一个JTabbedPane对象
JTabbedPane tab = new JTabbedPane();
2.向其中添加选项卡,一个选项卡就是一个Compnent组件,常用一个JPane面板把需要的组件组织起来, 其实Swing的思想也是这样的,他把组件分为两类一个是普通的组件一个是可以存放组件的组件被称为容器,最外面的frame通过布局方式把容器组织起来,各个容器又把自己的组件通过布局方式组织起来,所以Swing的使用只要把容器、组件、布局方式搞定就可以了,呵呵,这里扯多了,下面是添加的方法:
tab.addTab(String title,Component compnent);
tab.addTab(String title,Icon icon,Component compnent);
tab.addTab(String title,Icon icon,Component compnent,String tooltip);
title就是选项卡的标题,compnent当然就是选项卡的内容了,icon是图标tooltip是工具提示。addTab方法是按照顺序添加到选项卡集的最后,我们知道选项卡面板实际是一个选项卡的集合,每个选项卡从0开始计数,也就是说第一个选项卡的编号为0.于是我们可以把一个选项卡添加到选项卡集的任何一个位置上,
tab.addTab(String title,Icon icon,Component compnent,String tooltip,int index);
当然也可以根据编号删除一个选项卡,
tab.removeTabAt(int index);
那么这么多选项卡,一次只能显示一个,如何显示指定的选项卡呢?
tab.setSelectedIndex(int index);
如果选项卡太多,可以选择他们的显示方式,隐藏或者滚动
tab.setTabLayoutPolicy(JTabbedPane.WRAP_TAB_LAYOUT);
tab.setTabLayoutPolicy(JTabbedPane.SCROLL_TAB_LAYOUT);
当你选中一个选项卡时怎么相应事件更新界面呢?要给面板添加一个ChangeListener,它只有一个方法叫stateChanged。
下面是示例代码:
/*
* TabbedPaneTest.java
* @2015-06-02
*/
import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.ButtonGroup;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
import javax.swing.JTabbedPane;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
public class TabbedPaneTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
TabbedPaneFrame frame = new TabbedPaneFrame();
frame.setTitle("TabbedPaneFrame");
frame.setSize(400, 300);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setVisible(true);
}
}
class TabbedPaneFrame extends JFrame {
private JTabbedPane tabbedPane;
private int count = 0;
public TabbedPaneFrame() {
// 添加选项卡
tabbedPane = new JTabbedPane();
tabbedPane.addTab("Mercury", null);
tabbedPane.addTab("Venus", null);
tabbedPane.addTab("Earth", null);
tabbedPane.addTab("Mars", null);
tabbedPane.addTab("Jupiter", null);
tabbedPane.addTab("Saturn", null);
tabbedPane.addTab("Uranus", null);
tabbedPane.addTab("Neptune", null);
tabbedPane.addTab("Pluto", null);
// 添加选项卡面板
add(tabbedPane, "Center");
// 添加监听器
tabbedPane.addChangeListener(new ChangeListener() {
@Override
public void stateChanged(ChangeEvent e) {
// TODO Auto-generated method stub
int n = tabbedPane.getSelectedIndex();
loadTab(n);
}
});
loadTab(0);
//添加单选按钮,用于调节选项卡的布局方式
JPanel buttonPanel = new JPanel();
ButtonGroup buttonGroup = new ButtonGroup();
JRadioButton wrapButton = new JRadioButton("Wrap tabs");
wrapButton.setSelected(true);
wrapButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent arg0) {
// TODO Auto-generated method stub
tabbedPane.setTabLayoutPolicy(JTabbedPane.WRAP_TAB_LAYOUT);
}
});
buttonGroup.add(wrapButton);
buttonPanel.add(wrapButton);
JRadioButton scroButton = new JRadioButton("Scroll tabs");
scroButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent arg0) {
// TODO Auto-generated method stub
tabbedPane.setTabLayoutPolicy(JTabbedPane.SCROLL_TAB_LAYOUT);
}
});
buttonGroup.add(scroButton);
buttonPanel.add(scroButton);
add(buttonPanel, BorderLayout.SOUTH);
}
private void loadTab(int n) {
String title = tabbedPane.getTitleAt(n);
String countString = String.valueOf(count ++);
String msg = "this is " + title + ", load at " + countString + " times";
tabbedPane.setComponentAt(n, new JLabel(msg));
}
}
运行截图:

图1 Wrap模式效果

图2 Scroll模式效果
Swing-选项卡面板JTabbedPane-入门的更多相关文章
- 高级组件——选项卡面板JTabbedPane
选项卡面板:JTabbedPane(标签位置,布局方式) 标签位置:JTabbedPane.TOP,JTabbedPane.BOTTOM,JTabbedPane.LEFT,JTabbedPane.RI ...
- Java分割面板和选项卡面板的应用
1.分割面板 JSplitPane类的常用构造方法 构造方法 说明 JSplitPane() 创建一个默认的分割面板.默认情况下为在水平方向上分割,重绘方式为只在调整分隔条位置完成时重绘 JSplit ...
- jQuery EasyUI 选项卡面板tabs使用实例精讲
1. 对选项卡面板区域 div 设置 class=”easyui-tabs” 2. 对选项卡面板区域添加多个 div,每个 div 就是一个选项卡(每个面板一定设置 title) 3. 设置面板 fi ...
- Ext 选项卡面板TabPanel
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- iframe和选项卡面板切换
<div class="col-sm-6"> <div class="tabs-container"> <ul class=&qu ...
- Java Swing实战(一)JFrame和JTabbedPane容器
概述: 项目是一个桌面程序,涉及标签和按钮组件.布局管理器组件.面板组件.列表框和下拉框组件等组件,以及Swing事件处理机制. 下面先从最基础的界面开始. /** * @author: lishua ...
- Java Swing实战(五)表格组件JTable(1)
dbPanel面板的配置告一段落. 接下来配置taskPanel 面板. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public clas ...
- Java Swing实战(三)文本组件JTextField和密码组件JPasswordField
接下来添加文本组件JTextField和密码组件JPasswordField. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public c ...
- Java Swing实战(二)下拉菜单组件JComboBox及其事件监听
接下来给"数据源配置"面板添加下拉框. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public class Weimi ...
- Java Swing实战(四)按钮组件JButton及其事件监听
接下来为面板添加保存按钮,并为按钮绑定事件监听. /** * @author: lishuai * @date: 2018/11/26 13:51 */ public class WeimingSyn ...
随机推荐
- salesforce 得到下拉列表控制依赖值的方法
salesforce中得到下拉列表的控制依赖值没有系统提供的方法.在网上找了一些,自己也编辑了一下. public static List<Integer> B64ToBytes (Str ...
- VS2013 C++代码运行问题
VS2013(工具集V120)下编译的C++代码,在win7运行错误,提示缺少msvcr230.dll,但是添加dll之后无效. 解决办法: 官方下载VS2013的C++运行库: vcredist_x ...
- Java入门——(3)面对对象(下)
关键词: 类的继承.final关键字.多态.接口.异常.包.访问控制 一.类的继承 1.类的继承是指在一个现有类的基础上去构建一个新的类,构建出来的新类被称作子类,现有类被称作父类,子类 ...
- Ubuntu 简单安装和配置 GitLab
使用的 Ubuntu Server 16.04 LTS 版本,服务器托管在 Azure 上,用的 1 元试用 1 个月服务器订阅(1500 元额度). 安装命令(推荐使用): curl -sS htt ...
- ESLint入门
ESLint是一个用于识别和报告ECMAScript/JavaScript中代码格式的工具,目的是使代码风格更加统一和避免错误. 1.安装和使用有两种方式去安装ESLint:全局和本地. 1.1本地安 ...
- Canvas 旋转风车绘制
写在前面: 亲爱的朋友们大家好,鄙人自学前端,第一次写博客,写的不好的地方,烦请同学们谅解,如果本文对你有一丁点帮助,还请劳驾您给我点个赞,您的认可将是我坚持下去的强大动力!谢谢! 在进行教学之前 ...
- IntelliJ IDEA Windows下Spark开发环境部署
0x01 环境说明 本地 OS: windows 10 jdk: jdk1.8.0_121 scala: scala-2.11.11 IDE: IntelliJ IDEA ULTIMATE 2017. ...
- windows域与工作组概念
局域网上的资源需要管理,“域”和“工作组”就是两种不同的网络资源管理模式.那么二者有何区别呢? 工作组 Work Group 在一个网络内,可能有成百上千台电脑,如果这些电脑不进行分组,都列在“网上邻 ...
- rtems在mini2440上的移植(ubuntu)
第一步 建立编译环境,rtems的编译环境需要使用newlib的库,所以ubuntu自带的gcc是不可以的,我是参照下面的博客才编译成功的,之前走了好多弯路. http://blog.sina.com ...
- Velocity.js的使用
前面的话 Velocity是一款优秀的JS动画库,完全可以作为jQuery的animate的替代品.需要动画功能时,使用Velocity是一个好选择.本文将详细介绍Velocity.js的使用 概述 ...