当前位置: 首页 > article >正文

JavaGUI之SWT框架 【SashForm CBanner】

文章目录

  • SashForm 分割窗
    • 样式
    • 设置窗口显示比例
    • 多层划分窗口
  • CBanner

SashForm 分割窗

SashForm分割窗,能够将容器面板进行切割,分为两块。SashForm分割的方向有两种,一种是水平分割,另一种是垂直分割。

SashForm的创建方式如下

// 创建分割窗口
SashForm sashForm = new SashForm(shell, SWT.HORIZONTAL);

// 创建窗口1
Composite c1 = new Composite(sashForm, SWT.BORDER);
c1.setLayout(new FillLayout());
new Text(c1, SWT.NONE).setText("窗口1");
// 创建窗口2
Composite c2 = new Composite(sashForm, SWT.BORDER);
c2.setLayout(new FillLayout());
new Text(c2, SWT.NONE).setText("窗口2");

// 设定每个窗口weight的比例值
sashForm.setWeights(new int[]{20, 40});

效果
在这里插入图片描述

样式

SWT.HORIZONTAL
请注意,在SashForm中,HORIZONTAL表示的是垂直划分
在这里插入图片描述


SWT.VERTICAL
请注意,在SashForm中,VERTICAL表示的是水平划分
在这里插入图片描述


SWT.BORDER
加粗边框
在这里插入图片描述


SWT.SMOOTH
平滑边框
在这里插入图片描述

设置窗口显示比例

sashForm.setWeights(new int[]{25, 50, 25}); 其中int[]数组的元素个数等于绑定sashForm面板的元素的个数。int[]数组中的数值表示每个组件的宽度比例

在这里插入图片描述

多层划分窗口

如果想要在已经分割的窗口上继续分割,可以在窗口上继续绑定SashForm

public static void main(String[] args) {
    Display display = new Display();
    Shell shell = new Shell(display);
    shell.setLayout(new FillLayout());
    shell.setSize(500, 400);

    // 创建两列的sashForm
    SashForm sashForm = new SashForm(shell, SWT.HORIZONTAL);
    sashForm.setLayout(new GridLayout(1, true));

    // 划分左侧区间, 创建两行的leftSashForm
    SashForm leftSashForm = new SashForm(sashForm, SWT.VERTICAL);
    leftSashForm.setLayout(new GridLayout(1, true));

    Composite leftUp = new Composite(leftSashForm, SWT.BORDER);
    leftUp.setLayout(new FillLayout());
    new Text(leftUp, SWT.NONE).setText("左上");

    Composite leftDown = new Composite(leftSashForm, SWT.BORDER);
    leftDown.setLayout(new FillLayout());
    new Text(leftDown, SWT.NONE).setText("左下");

    Composite right = new Composite(sashForm, SWT.BORDER);
    right.setLayout(new FillLayout());
    new Text(right, SWT.NONE).setText("右");

    shell.open();
    while (!shell.isDisposed()) {
        while (!display.readAndDispatch()) {
            display.sleep();
        }
    }
    shell.dispose();
}

在这里插入图片描述

CBanner

CBanner将容器划分为三个部分,左侧,右侧,底栏
CBanner的创建方式如下

CBanner cBanner = new CBanner(shell, SWT.BORDER);
cBanner.setLayout(new FillLayout());

// 创建3个面板
Composite c1 = new Composite(cBanner, SWT.NONE);
c1.setLayout(new FillLayout());
new Label(c1, SWT.NONE).setText("面板1");

Composite c2 = new Composite(cBanner, SWT.NONE);
c2.setLayout(new FillLayout());
new Label(c2, SWT.NONE).setText("面板2");

Composite c3 = new Composite(cBanner, SWT.NONE);
c3.setLayout(new FillLayout());
new Label(c3, SWT.NONE).setText("面板3");

// 设置控件
cBanner.setLeft(c1);
cBanner.setRight(c2);
cBanner.setBottom(c3);

效果
在这里插入图片描述

CBanner需要额外手动设置绑定位置。绑定为api为setLeft(Composite composite), setRight(Composite composite), setBottom(Composite composite)


http://www.kler.cn/a/226957.html

相关文章:

  • 学习Spring的第十三天
  • 二维图像生成 3D 场景:nerfstudio 帮你简化流程 | 开源日报 No.164
  • Leaf——美团点评分布式ID生成系统
  • [Python] scikit-learn中数据集模块介绍和使用案例
  • 计算机服务器中了DevicData勒索病毒如何解密,DevicData勒索病毒解密流程
  • Atlassian Intelligence功能简介,AI驱动生成、概括、优化内容,助力工作效率加倍
  • Open3D 深度图像转点云
  • Ps:旋转视图工具
  • 《计算机网络简易速速上手小册》第10章:未来网络技术趋势(2024 最新版)
  • 06:原生云K8S解密|K8S集群安装部署|K8S网络插件
  • 【NodeJS】fs 模块 (2)
  • 探索前端开发框架:React、Angular 和 Vue 的对决(二)
  • 非精线搜索步长规则Armijo规则Goldstein规则Wolfe规则
  • XUbuntu22.04之两款实用画笔工具(二百一十)
  • 32GPIO输入LED闪烁蜂鸣器
  • Kotlin 协程:深入理解 ‘lifecycleScope‘
  • Guava cache中 LoadingCache和Cache的区别
  • 图论练习2
  • 【Python基础】数字基础
  • unittest、nosetest、pytest