最近一直在做软件,采用了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;
}
}
分享到:
相关推荐
强烈推荐漂亮的LOGO,让你的公司很容易感染每个客人。吐血推荐
dc machine control using fuzzy logoc
全国各大银行logo
android手机应用源码Imsdroid语音视频通话源码.rar
营销计划汇报PPT,市场品牌 推广渠道 产品 营销策略tbb.pptx
JavaScript
JavaScript
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表白html5爱心代码
520表白html5爱心代码 一个简单的HTML5和CSS代码示例,用于创建一个动态的爱心形状,并在网页上展示一个类似520表白的消息。这个示例使用了CSS的动画效果和HTML的结构。
智慧养老社区方案.pdf
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
codeviz 1.0.12
JavaScript
JavaScript
JavaScript
JavaScript
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