`

SWT如何实现面板内容切换,解决方案(原创-logoc)

阅读更多

       最近一直在做软件,采用了SWT插件,经过近1个多月的使用,对SWT有了初步的认识,今日刚刚解决SWT面板如实现内容切换,而非窗口切换做一些分享,希望对各位有所帮助!

       建议入门同学读一下<理解SWT布局>这篇文章,多读几次也无妨。这是我的感受。

       现在切入正题,如何解决面板内容切换问题!

       在CSDN、百度、google我查了相关的资料,相关资料很少,不知道是我搜索关键字有问题还是其他原因。这个问题困扰我很久,网上提供的使用CTabItem的较多,但这是我想要的效果。我要的效果,是通过按钮实现内容切换而且,实现不同面板在不同的类中进行设计。经过反复调试测验,发现当我现在一个composite面板,调用setVisible(true/false)方法来实现面板的转换,但是发现不行,布局有问题,最后发现使用StackLayout()叠加布局类来实现。所有的面板都叠放在一起,通过按钮将需要的面板置顶即可。总体思路就是这样。如有描述错误,贻笑大方还请各位指点。

实现代码:可独立运行

 

package com.hbaas.main;

import org.eclipse.swt.SWT;
import org.eclipse.swt.custom.SashForm;
import org.eclipse.swt.custom.StackLayout;
import org.eclipse.swt.graphics.Image;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Event;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Listener;
import org.eclipse.swt.widgets.Shell;

import com.hbaas.composite.SystemSetComposite;

public class SystemFrame {

 protected Shell shell;
 protected Button systemBt ;
 protected Button nhinfoBt ;
 protected Composite systemComp;
 protected Composite nhinfoComp;
 protected StackLayout stackLayout = new StackLayout();
 protected Composite displayComp;
 /**
  * Launch the application.
  * @author 李亮

  * @param Composite
  */
 public static void main(String[] args) {
  try {
   SystemFrame window = new SystemFrame();
   window.open();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 /**
  * Open the window.
  */
 public void open() {
  Display display = Display.getDefault();
  createContents();
  shell.open();
  shell.layout();
  while (!shell.isDisposed()) {
   if (!display.readAndDispatch()) {
    display.sleep();
   }
  }
 }

 /**
  * Create contents of the window.
  */
 protected void createContents() {
  shell = new Shell(SWT.MIN | SWT.CLOSE);
  shell.setSize(1200, 800);
  shell.setLocation(Display.getCurrent().getClientArea().width/2 - shell.getShell().getSize().x/2, Display.getCurrent().getClientArea().height/2 - shell.getSize().y/2);
  
  shell.setText("湖北省xxxx系统");
  shell.setImage(new Image(null,"./icons/log.ico")); 
  shell.setLayout(new GridLayout());
  SashForm sashForm = new SashForm(shell, SWT.NONE);
 
  sashForm.setOrientation(SWT.VERTICAL);
  {
   GridData gridData = new GridData(SWT.LEFT, SWT.CENTER, false, false, 1, 1);
   gridData.widthHint = 1185;
   gridData.heightHint = 755;
   sashForm.setLayoutData(gridData);
  }
  
  final Composite controlComp = new Composite(sashForm,SWT.NONE);
  controlComp.setBackgroundImage(new Image(shell.getDisplay(),"./icons/top.gif"));
  final GridData controlGridata = new GridData(SWT.FILL,SWT.CENTER);  
  {
   systemBt = new Button(controlComp, SWT.NONE);
   systemBt.setBounds(579, 24, 100, 60);
   systemBt.setText("系统设置");

   nhinfoBt = new Button(controlComp, SWT.NONE);
   nhinfoBt.setBounds(739, 24, 100, 60);
   nhinfoBt.setText("农户信息");

   Button dataBt = new Button(controlComp, SWT.NONE);
   dataBt.setBounds(889, 24, 100, 60);
   dataBt.setText("数据交换");
   Button aboutBt = new Button(controlComp, SWT.NONE);
   aboutBt.setBounds(1040, 24, 100, 60);
   aboutBt.setText("关于");
  }
  controlComp.setLayoutData(controlGridata);

//  systemBt.addSelectionListener(new CompSelectionListener());
//  nhinfoBt.addSelectionListener(new CompSelectionListener());
  
  displayComp = new Composite(sashForm,SWT.NONE);
  displayComp.setLayout(stackLayout);
  
//  systemComp = createSystemComp(displayComp);
  systemComp = new SystemSetComposite().createFrame(displayComp);
  nhinfoComp = createNhInfoComp(displayComp);  
  stackLayout.topControl = systemComp;
 
  
  Listener listener = new Listener(){
   public void handleEvent(Event event) {
    if (event.widget == systemBt){
     stackLayout.topControl = systemComp;
//     System.out.println(systemBt.getText());
    }else if(event.widget == nhinfoBt){
     stackLayout.topControl = nhinfoComp;
//     System.out.println(nhinfoBt.getText());
    } 
    displayComp.layout();
   }   
  };
  systemBt.addListener(SWT.Selection , listener);
  nhinfoBt.addListener(SWT.Selection, listener); 
  sashForm.setWeights(new int[] {118, 681});
 }
 private Composite createSystemComp(Composite displayComp) {
  Composite comp = new Composite(displayComp, SWT.NONE);
  comp.setLayout(new GridLayout());
  new Label(comp, SWT.NONE).setText("系统面板");
  return comp; 
 } 
 private Composite createNhInfoComp(Composite displayComp) {
  Composite comp = new Composite(displayComp, SWT.NONE);
  comp.setLayout(new GridLayout());
  new Label(comp, SWT.NONE).setText("农户信息面板");
  return comp;  
 }
}

分享到:
评论
2 楼 logoc 2012-06-27  
dotjar 写道
SystemSetComposite在哪里?

这个是一个新的面板,你可以自己定义的。
1 楼 dotjar 2012-06-08  
SystemSetComposite在哪里?

相关推荐

    公司漂亮的标识LOGO

    强烈推荐漂亮的LOGO,让你的公司很容易感染每个客人。吐血推荐

    CH02- CMD Machine CC.rar_adaptive control_dc fuzzy_dc machine

    dc machine control using fuzzy logoc

    银行logo.rar(117个)

    全国各大银行logo

    基于matlab实现的空间调制通信过程,包含信号调制、天线选择等发送过程,以及采用最大似然估计的检测过程 .rar

    基于matlab实现的空间调制通信过程,包含信号调制、天线选择等发送过程,以及采用最大似然估计的检测过程。.rar

    基于matlab的关于生猪养殖场经营管理的研究.docx

    本文档是课题研究的研究报告内含调研以及源码设计以及结果分析

    网络作为特征提取器-python源码.zip

    网络作为特征提取器-python源码.zip

    JavaScript-javaweb项目

    JavaScript-javaweb项目

    node-v12.11.0-linux-arm64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    仿Slideby触屏版html5响应式手机wap网站模板下载.zip

    触屏版自适应手机wap软件网站模板 触屏版自适应手机wap软件网站模板

    node-v10.18.1-linux-arm64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    IEC 60695-11-3:2012.pdf

    IEC 60695-11-3:2012.pdf

    2021-2010上市公司和讯网社会责任评级CSR-股东员工客户消费者环境社会责任分项评级

    上市公司和讯网社会责任评级CSR-股东责任员工责任客户消费者环境社会责任分项评级 得分(2010-2021年) "中国上市公司-和讯网社会责任数据"是 一份来自和讯网的数据集,它同步并收集了中国上市公司关于社会责任的相关信息。包括了 公司在股东责任、员工责任、供应商客户消费者权益责任、环境责任、社会责任中的表现和 成绩,以反映公司承担社会责任的程度。可以帮助大家了解公司在承担社会责任方面的具体 表现。这对于研究公司社会责任与公司业绩、公司声誉、公司风险等方面的关系具有参考意 义。 一、数据介绍 数据名称:上市公司和讯网社会责任评级CSR-股东责任员工责任 客户消费者环境社会责任分项评级得分 数据年份:2010-2021年 样本数量:每 年含2300-4600左右上市公司数据,总数据量40058条(注:因披露口径原因 ,2021年仅有430+上市公司数据) 数据格式:Excel面板数据 二、指标说 明 共计11个指标:股票名称、股票代码、年份、总得分、等级、股东责任、员工责任、 供应商客户和消费者权益责任、环境责任、社会责任、统计日期 三、部分excel数据 展示

    使用opencv进行人脸识别和对比-python源码.zip

    使用opencv进行人脸识别和对比-python源码.zip

    EmotionVGGnet情绪识别-python源码.zip

    EmotionVGGnet情绪识别-python源码.zip

    node-v12.1.0-linux-arm64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    MediaPipe人体姿势估计-python源码.zip

    MediaPipe人体姿势估计-python源码.zip

    构造并使用决策树进行分类-python源码.zip

    构造并使用决策树进行分类-python源码.zip

    <2024年5月软考高项极限冲刺>《1 考试简介》

    <2024年5月软考高项极限冲刺>《1 考试简介》

    【特效超多】仿德国开元旅游触屏版html5手机wap旅游网站模板下载.zip

    【特效超多】仿德国开元旅游触屏版html5手机wap旅游网站模板下载.zip

    JSP基于WEB网上论坛设计与实现(源代码+论文+开题报告+答辩PPT+外文翻译).zip

    JSP基于WEB网上论坛设计与实现(源代码+论文+开题报告+答辩PPT+外文翻译)

Global site tag (gtag.js) - Google Analytics