`

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

    android手机应用源码Imsdroid语音视频通话源码.rar

    android手机应用源码Imsdroid语音视频通话源码.rar

    营销计划汇报PPT,市场品牌 推广渠道 产品 营销策略tbb.pptx

    营销计划汇报PPT,市场品牌 推广渠道 产品 营销策略tbb.pptx

    JavaScript_超过100种语言的纯Javascript OCR.zip

    JavaScript

    JavaScript_跨平台React UI包.zip

    JavaScript

    node-v16.17.0-headers.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提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    520表白代码.rar

    520表白html5爱心代码

    一个简单的HTML5和CSS代码示例,用于创建一个动态的爱心形状,并在网页上展示一个类似520表白的消息 这个示例使用了CSS的

    520表白html5爱心代码 一个简单的HTML5和CSS代码示例,用于创建一个动态的爱心形状,并在网页上展示一个类似520表白的消息。这个示例使用了CSS的动画效果和HTML的结构。

    智慧养老社区方案.pdf

    智慧养老社区方案.pdf

    node-v14.11.0-headers.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提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    JavaScript_美观和可访问的拖放列表与React.zip

    JavaScript

    codeviz 1.0.12

    codeviz 1.0.12

    JavaScript_高级用户LLM前端.zip

    JavaScript

    javascript koans是一个交互式学习环境,它使用失败测试按逻辑顺序向学生介绍javascript的各个方面.zip

    JavaScript

    JavaScript_巴勒斯坦和巴以冲突资源的策划列表.zip

    JavaScript

    JavaScript_手工制作的弗里达例子.zip

    JavaScript

    node-v17.4.0-headers.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提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    移动应用Android 实现QQ好友列表源码.rar

    移动应用Android 实现QQ好友列表源码.rar

Global site tag (gtag.js) - Google Analytics