Java分割面板和选项卡面板的应用
1、分割面板
| JSplitPane类的常用构造方法 | |
|---|---|
| 构造方法 | 说明 |
| JSplitPane() | 创建一个默认的分割面板。默认情况下为在水平方向上分割,重绘方式为只在调整分隔条位置完成时重绘 |
| JSplitPane(int neworientation) | 创建一个按照指定方向分割的分割面板。入口参数newOrientation的可选静态JSplitPane(int newOrientation)常量有HORIZONTAL_SPLIT和VERTICAL_SPLIT |
| JSplitPane(int neworientation,boolean newContinuousLayout) | 创建一个按照指定方向分割,并且按照指定方式重绘的分割面板。如果将入口参数 newContinuousLayout设为true,表示在调整分隔条位置的过程中连续重绘,设为false则表示只在调整分隔条位置完成时重绘 |
重绘:重新绘制组件的布局方式。如果把 newContinuousLayout设为true,拖动分隔条的时候组件也会跟着动,如果是false,拖动的仅仅是分隔条(组件不会跟着动),待分隔条定下来时,组件才跟着定下来。如果既需要水平分割又要在垂直分割,可以在其中一个分割面板的两个方向上再添加分割面板。小例子:
// 创建一个水平方向的分割面板
JSplitPane hSplitPane = new JSplitPane();
// 分隔条左侧的宽度为40像素
hSplitPane.setDividerLocation(40);
// 添加到指定区域
getContentPane().add(hSplitPane, BorderLayout.CENTER);
// 在水平面板左侧添加一个标签组件
hSplitPane.setLeftComponent(new JLabel("左面板"));
// 创建一个垂直方向的分割面板
JSplitPane vSplitPane = new JSplitPane(JSplitPane.VERTICAL_SPLIT);
// 分隔条上方的高度为30像素
vSplitPane.setDividerLocation(30);
vSplitPane.setDividerSize(8);// 分隔条的宽度为8像素
vSplitPane.setOneTouchExpandable(true);// 提供UI小部件
// 在调整分隔条位置时面板的重绘方式为连续绘制
vSplitPane.setContinuousLayout(true);
hSplitPane.setRightComponent(vSplitPane);// 添加到水平面板的右侧
// 在垂直面板上方添加一个标签组件
vSplitPane.setLeftComponent(new JLabel("上"));
// 在垂直面板下方添加一个标签组件
vSplitPane.setRightComponent(new JLabel("下"));

2、选项卡面板
| 表23.3JTabbedPane类的所有构造方法 | |
|---|---|
| 构造方法 | 说明 |
| JTabbedPane() | 创建一个默认的选项卡面板。默认情况下标签位于选项卡的上方,布局方式为限制布局 |
| JTabbedPane(int tabPlacement) | 创建一个指定标签显示位置的选项卡面板。入口参数tabPlacement的可选静态常量可以TOP、BOTTOM、LEFT 和RIGHT |
| JTabbedPane(int tabPlacement,int tabLayoutPolicy) | 创建一个既指定标签显示位置又指定选项卡布局方式的选项卡面板。入口参数tabLayoutPolicy的可选静态常量可以是WRAP_TAB_LAYOUT(限制布局为默认值)和SCROLL_TAB_LAYOUT(滚动布局) |
两种布局方式是限制布局和滚动布局,限制布局中的选项卡面板可以随着窗体的拖动做出合适的调整,滚动布局是窗体变小的时候会出现一个滚动条,可以点击显示被遮挡的选项卡。addTab()方法可以把所有入口参数都设置为空,即:
tabbedPane.addTab(null,null);
| 方法 | 说明 |
|---|---|
| addTab(String title,Component component) | 添加一个标签为title |
| addTab(String title,Icon icon,Component component) | 添加一个标签为title、图标为icon |
| addTab(String title,Icon icon,Component component,String tip) | 添加一个标签为title、图标为icon、提示为tip的选项卡 |
| InsertTab(String title,Icon icon,Component component,String tip, int index) | 在索引位置index处插入一个标签为title、图标为icon、提示为tip的选项卡。索引值从0开始 |
| setTabPlacement(int tabPlacement) | 设置选项卡标签的显示位置 |
| setTabLayoutPolicy(int tabLayoutPolicy) | 设置选项卡标签的布局方式 |
| setSelectedIndex(int index) | 设置指定索引位置的选项卡被选中 |
| setEnabledAt(int index, boolean enabled) | 设置指定索引位置的选项卡是否可用。设为true表示可用,设为false则表示不可用 |
| setDisabledIconAt(int index,Icon disabledIcon) | 为指定索引位置的选项卡设置不可用时显示的图标 |
| getTabCount() | 获得该选项卡面板拥有选项卡的数量 |
| getSelectedIndex() | 获得被选中选项卡的索引值 |
| getTitleAt(int index) | 获得指定索引位置的选项卡标签 |
| addChangeListener(ChangeListener 1) | 为选项卡面板添加捕获被选中选项卡发生改变的事件 |
小例子:
final JTabbedPane tabbedPane = new JTabbedPane();
// 设置选项卡标签的布局方式
tabbedPane.setTabLayoutPolicy(JTabbedPane.SCROLL_TAB_LAYOUT);
tabbedPane.addChangeListener(new ChangeListener() {
public void stateChanged(ChangeEvent e) {
// 获得被选中选项卡的索引
int selectedIndex = tabbedPane.getSelectedIndex();
// 获得指定索引的选项卡标签
String title = tabbedPane.getTitleAt(selectedIndex);
System.out.println(title);
}
});
getContentPane().add(tabbedPane, BorderLayout.CENTER);
URL resource = ExampleFrame_02.class.getResource("/tab.JPG");
ImageIcon imageIcon = new ImageIcon(resource);
final JLabel tabLabelA = new JLabel();
tabbedPane.addTab("选项卡A", imageIcon, tabLabelA, "点击查看选项卡A");
final JLabel tabLabelB = new JLabel();
tabbedPane.addTab("选项卡B", imageIcon, tabLabelB, "点击查看选项卡B");
final JLabel tabLabelC = new JLabel();
tabbedPane.addTab("选项卡C", imageIcon, tabLabelC, "点击查看选项卡C");
tabbedPane.setSelectedIndex(2); // 设置索引为2的选项卡被选中
tabbedPane.setEnabledAt(0, false); // 设置索引为0的选项卡不可用

欢迎关注我的公众号:物联网技术猿
我可以帮你免费下载csdn积分资料!!
Java分割面板和选项卡面板的应用的更多相关文章
- jQuery EasyUI 选项卡面板tabs使用实例精讲
1. 对选项卡面板区域 div 设置 class=”easyui-tabs” 2. 对选项卡面板区域添加多个 div,每个 div 就是一个选项卡(每个面板一定设置 title) 3. 设置面板 fi ...
- 高级组件——选项卡面板JTabbedPane
选项卡面板:JTabbedPane(标签位置,布局方式) 标签位置:JTabbedPane.TOP,JTabbedPane.BOTTOM,JTabbedPane.LEFT,JTabbedPane.RI ...
- Ext 选项卡面板TabPanel
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JAVA GUI学习 - JTabbedPane选项卡组件学习
public class JTabbedPaneKnow extends JFrame { JTabbedPane jTabbedPane; JPanel jPanelRed; JPanel jPan ...
- 出售Illustrator脚本插件面板(包含面板源码,以及面板上所有的功能源码)
出售Illustrator脚本插件面板(包含面板源码,以及面板上所有的功能源码) 购买后可提供相应的小修改,以及教你使用往这个多列面里再加上按钮功能! 这套源码可作为工作使用,也可用为新手学习AI脚面 ...
- 关于液晶显示器的6bit面板、8bit面板及E-IPS(转)
原文:http://bbs.3dmgame.com/thread-2232447-1-1.html 1.什么是6bit面板.8bit面板 众所周知,液晶显示器 ...
- iframe和选项卡面板切换
<div class="col-sm-6"> <div class="tabs-container"> <ul class=&qu ...
- (八)easyUI之Accordion折叠面板:动态面板
二.动态面板 数据库设计 函数设计:该函数用于获取某个节点的所有子节点 CREATE FUNCTION fn_getAddress_ChildList_test(rootId INT) RETURNS ...
- Axure教程:如何使用动态面板?动态面板功能详解
写了几个Axure教程之后发现,可能教程的起点有些高了,过分的去讲效果的实现,而忽略了axure功能以及基础元件的使用,那么从这个教程开始,把这些逐渐的展开讲解. 关于Axure动态面板 动态面板是a ...
随机推荐
- Zookeeper作为配置中心使用说明
为了保证数据高可用,那么我们采用Zookeeper作为配置中心来保存数据.SpringCloud对Zookeeper的集成官方也有说明:spring_cloud_zookeeper 这里通过实践的方式 ...
- 关于一个 websocket 多节点分布式问题的头条面试题
原文链接,欢迎讨论: [Q023]websocket 服务多节点部署时会有什么问题,怎么解决 你来说说 websocket 有什么用 双向通信,服务器端可以主动 push,给客户端发送通知 那webs ...
- python 爬取猫眼电影top100数据
最近有爬虫相关的需求,所以上B站找了个视频(链接在文末)看了一下,做了一个小程序出来,大体上没有修改,只是在最后的存储上,由txt换成了excel. 简要需求:爬虫爬取 猫眼电影TOP100榜单 数据 ...
- 易初大数据 2019年11月2日 计算机英语 wangqingchao
一.Match the explantions in Column B with words and expressions in Column A.(搭配每组中同意以的词或短语) 1.交换机(pos ...
- vmware centos共享文件夹
vmware centos共享文件夹 查看VMware Tools 是否安装成功 <pre>vmware-hgfsclient</pre> 出现共享文件夹<pre> ...
- starUML 3.0.2文件 百度云
文件百度云---链接:https://pan.baidu.com/s/1BVX9Ze40bkgd3k_4WFb99A 提取码:t7kj 使用方法:将starUML安装目录(一般为 C:\Program ...
- Vue的指令以及组件化开发
一. 自定义指令 如何: 1. 创建指令 Vue.directive("指令名",{ inserted(elem){//指令所在的元素被加载到DOM树上后自动执行指令 //elem ...
- Flink入门(一)——Apache Flink介绍
Apache Flink是什么? 在当代数据量激增的时代,各种业务场景都有大量的业务数据产生,对于这些不断产生的数据应该如何进行有效的处理,成为当下大多数公司所面临的问题.随着雅虎对hadoop的 ...
- 深入理解计算机系统 第三章 程序的机器级表示 part2
这周由于时间和精力有限,只读一小节:3.4.4 压入和弹出栈数据 栈是一种特殊的数据结构,遵循“后进先出”的原则,可以用数组实现,总是从数组的一端插入和删除元素,这一端被称为栈顶. 栈有两个常用指令 ...
- element 动态合并表格
前言 element 官方的例子太简单了,不满足实际的需求 数据肯定是动态的,合并的行数,列数都是动态的,该如何知道每一行的合并数呢 需求 动态合并表格,数据来源于数据库 正文 一开始,我的数据源是单 ...