`
stonefox
  • 浏览: 30976 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Shell Layout

阅读更多

在SWT中提供了5种布局:FillLayout, RowLayout, GridLayout, FormLayout, and StackLayout。下面我将详细讨论这5种布局的使用。
  FillLayout
  FillLayout是最简单的布局。它可以将控件横向或纵向进行排列,并且其中每个控件都有同样的宽度或高度。使用FillLayout一般分为2步。
  1. 建立一个FillLayout对象。
  2. 使用setLayout方法设置Shell对象的布局。
  下面代码使用FillLayout在Shell上放了3个按钮,代码如下:
package layout;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.*;
import org.eclipse.swt.layout.*;
public class TestFillLayout
{
 public static void main(String[] args)
 {
  Display display = new Display();
  Shell shell = new Shell(display, SWT.DIALOG_TRIM);
  shell.setText("FillLayout演示");
  shell.setSize(400, 300);
  // 设置shell的布局
  FillLayout layout = new FillLayout();
  shell.setLayout(layout);
  // 向shell添加控件
  Button button1 = new Button(shell, SWT.PUSH);
  button1.setText("按钮1");
  Button button2 = new Button(shell, SWT.PUSH);
  button2.setText("按钮2");
  Button button3 = new Button(shell, SWT.PUSH);
  button3.setText("按钮3");
  shell.open();
  while (!shell.isDisposed())
  {
   if (!display.readAndDispatch())
   {
    display.sleep();
   }
  }
  display.dispose();
 }
}
  界面如图1所示。

图 1 使用横向FillLayout的Shell界面
  如果想要Shell上的控件纵向排列,可以在建立布局时将type属性设置成SWT.VERTICAL。代码如下:
FillLayout layout = new FillLayout();
layout.type = SWT.VERTICAL;
shell.setLayout(layout);
  图2是控件纵向排列的效果图

图 2 使用纵向FillLayout的Shell界面
  FillLayout的构造函数重载了2次。其中一个构造函数有一个参数,这个参数就是type。因此,我们也可以通过FillLayout的构造函数对type赋值。
shell.setLayout(new FillLayout(SWT.VERTICAL));
RowLayout
  RowLayout的功能和FillLayout差不多。只是它和FillLayout的最大区别是每个控件并不一定是一样大小。而且RowLayout是按行排列,这一点和FillLayout是不同的。在一行排满后,就从下一行开始排列。和RowLayout配合使用的还有一个RowData类。这个类可以设置每一个控件的大小。下面代码是一个使用RowLayout的小例子。
package layout;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.*;
import org.eclipse.swt.layout.*;
public class TestRowLayout
{
 public static void main(String[] args)
 {
  Display display = new Display();
  Shell shell = new Shell(display, SWT.DIALOG_TRIM);
  shell.setText("RowLayout演示");
  shell.setSize(220, 200);
  // 将Shell的布局设置成RowLayout
  RowLayout layout = new RowLayout(SWT.HORIZONTAL);
  layout.spacing = 30;
  layout.marginLeft = 30;
  layout.marginTop = 30;
  shell.setLayout(layout);
  RowData rowData = new RowData();
  rowData.height = 50;
  rowData.width = 100;
  // 向shell添加控件
  Button button1 = new Button(shell, SWT.PUSH);
  button1.setText("按钮1");
  button1.setLayoutData(rowData);
  Button button2 = new Button(shell, SWT.PUSH);
  button2.setText("按钮2");
  Button button3 = new Button(shell, SWT.PUSH);
  button3.setText("按钮3");
  shell.open();
  while (!shell.isDisposed())
  {
   if (!display.readAndDispatch())
   {
    display.sleep();
   }
  }
  display.dispose();
 }
}
  图3是使用RowLayout的效果图

图3 RowLayout效果图
  可以在两个地方设置和RowLayout相关的数据,一个是RowData,它可以设置控件的大小。另外一个就是RowLayout本身,它可以设置控件开始排列的起点坐标(marginLeft和marginTop)、以及控件之间的间距等信息(spacing)。在RowLayout中有个很重要的属性justify。这个属性默认是false。当它为true时,将自动调整行或整列的控件,使其尽量占满一行或一列。
GridLayout

  GridLayout是SWT中最重要的布局。这个布局十分强大,它可以满足大多数的需要。而且它的网络可以通过Composite对象进行嵌套。GridLayout有两个构造函数。一个是默认的构造函数public GridLayout()。另外一个需要两个函数public GridLayout(int numColumns, boolean makeColumnsEqualWidth)。其中numColumns是这个网格的列数,而另外一个参数将使每一列等宽。下面的代码是一个完整的关于GridLayout的例子。

package layout;

import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.*;
import org.eclipse.swt.layout.*;

public class TestGridLayout
{
 public static void main(String[] args)
 {
  Display display = new Display();
  Shell shell = new Shell(display);
  shell.setText("GridLayout演示");
  GridLayout layout = new GridLayout();
  layout.numColumns = 3;
  layout.makeColumnsEqualWidth = true;
  shell.setLayout(layout);

  // 建立左上角的按钮
  GridData data = new GridData(GridData.FILL_BOTH);
  data.widthHint = 200; //按钮的初始宽度为200
  Button one = new Button(shell, SWT.PUSH);

  one.setText("按钮1");
  one.setLayoutData(data);

  // 建立一个Composite对象,并在上面放三个按钮
  Composite composite = new Composite(shell, SWT.NONE);
  data = new GridData(GridData.FILL_BOTH);
  data.horizontalSpan = 2; // Composite的占两个Cell

  composite.setLayoutData(data);
  layout = new GridLayout();
  layout.numColumns = 1;
  layout.marginHeight = 15;
  layout.marginRight = 150;
  composite.setLayout(layout);
 
  // 建立第二个按钮
  data = new GridData(GridData.FILL_BOTH);
  Button two = new Button(composite, SWT.PUSH);
  two.setText("按钮2");
  two.setLayoutData(data);

  // 建立第三个按钮
  data = new GridData(GridData.HORIZONTAL_ALIGN_END);
  Button three = new Button(composite, SWT.PUSH);
  three.setText("按钮3");
  three.setLayoutData(data);

  // 建立第四个按钮
  data = new GridData(GridData.HORIZONTAL_ALIGN_BEGINNING);
  Button four = new Button(composite, SWT.PUSH);
  four.setText("按钮4");
  four.setLayoutData(data);

  // 建立下面的一个长按钮
  data = new GridData();
  data.horizontalAlignment = GridData.FILL;
  data.grabExcessHorizontalSpace = true;
  data.horizontalSpan = 3;
  data.verticalSpan = 2;
  data.heightHint = 150;
  Button five = new Button(shell, SWT.PUSH);
  five.setText("按钮5");
  five.setLayoutData(data);
  
  shell.pack();
  shell.open();
  while (!shell.isDisposed())
  {
   if (!display.readAndDispatch())
   {
    display.sleep();
   }
  }
  display.dispose();
 }
}

  上面的例子将网格设成3列,在第一行的第一列放置了第一个按钮。然后将一个Composite对象放到第一行第二、三列(data.horizontalSpan = 2),在这个对象上放到个按钮。最后在下面建立了第5个按钮。

  FormLayout

  FormLayout是SWT中最复杂的布局。在这一部分我将详细讨论FormLayout。这个布局虽然复杂,但它确可以对控件进行更多的控制。

  FormLayout和其它的布局类似,也有一个FormData类用于设置布局信息。但我其它的布局不同的是FormLayout使用另外一个类来控制控件的大小和位置,这个类是FormAttachment。控件的上、下、左、右分别要4个FormAttachment对象来控制。通过这些FormAttachment对象可以控制当前控件如何在它的父窗口中显示,以及和其它控件的相对位置。

  在FormLayout中,描述位置的4个属性(left、top、right、bottom)都是一个FormAttachment对象。而并不是一个简单的值。在FormAttachment中比较常用的属性是numerator,这个属性描述控件的4个边距Shell的边缘的距离。
按百分比放置控件

  可以通过FormAttachment的numerator属性设置百分比。下面的代码将一个按钮在它的父窗口的宽度的40%处放置按钮。当Shell的尽寸改变后,按钮的位置也随之变化,但按钮的大小并不改变。

Button button = new Button(shell, SWT.PUSH);
button.setText("按钮");
FormData data = new FormData();
data.left = new FormAttachment(40);
button.setLayoutData(data);

  但如果同时设置data的left和right属性又如何呢?如果是这样的话,那么这个按钮的尺寸就会改变。下面的例子将一个按钮放到水平方向中心的位置。我们可以将left的比例设计为40%,而right的比例设置60%。如果这样设置,无论窗体如何变化,这个按钮始终在水平方向的中心。这是一个简单的数学计算。如果一个按钮的左边在40%的位置,而右边在60%的位置,也就是说,按钮的右边距窗体的右边也是40%。这样可以算出,按钮的宽度占窗体的20%(哈哈,要想使用FormLayout,可要有一定的数学基础啊!)。

Button button = new Button(shell, SWT.PUSH);
button.setText("按钮");
FormData data = new FormData();
data.left = new FormAttachment(40);
data.right = new FormAttachment(60);
button.setLayoutData(data);

  不过在使用FormAttachment同时给left和right或top和bottom赋值时,不能将这两个比例设成一样的,要不就将按钮压扁了(按钮看不到了,宽或高为0)。如果想要按钮在中心位置,这两个比例的和必须是100。而且left(top)的比例要小于right(bottom)的比例。

  设置控件的偏移量

  SWT之所以提供了布局,目的就是让你尽量少使用绝对坐标来设置控件。但在有时,我们又必须使用绝对坐标。如果是这样的话,你可以使用控件的setLocation来设置,也可以使用FormAttachment提供的偏移量去达到同样的效果。

FormData data = new FormData();
data.left = new FormAttachment(0, 20);
data.top = new FormAttachment(0, 40);
button.setLayoutData(data);

  上面的代码相当于setLocation(20, 40),即将按钮设置的位置设置成(20, 40)。

  根据其它控件的调整位置

  一般在窗体上都有不只一个控件,这些控件之间都是有一定关系的,它们的位置也是相对的。因此,FormLayout为我们提供了根据其它控件设置当控件位置的方法。如根据另外一个控件设置当前控件左边或右边的位置。

  下面的例子将根据一个按钮的位置设置另外一个按钮的位置。有两个按钮,第二个按钮根据第一个按钮的底边设置自己的位置。

Button button1 = new Button(shell, SWT.PUSH);
button1.setText("按钮1");
FormData data1 = new FormData();
data1.top = new FormAttachment(20);
data1.left = new FormAttachment(40);
data1.right = new FormAttachment(50);
button1.setLayoutData(data1);
// 第二个按钮
Button button2 = new Button(shell, SWT.PUSH);
button2.setText("按钮2");
FormData data2 = new FormData();
data2.left = new FormAttachment(button1, 0, SWT.CENTER);
data2.top = new FormAttachment(button1);
button2.setLayoutData(data2);

  上面的"按钮2"将根据"按钮1"将自己水平方向的位置设置成"按钮1"的中心位置。
StackLayout

  我们在最后一部分来讨论StackLayout,并不是因为StackLayout在这5种布局中最复杂,而是这个布局并不在org.eclipse.swt.layout中,而在org.eclipse.swt.custom中。从这个布局的名子可看出,它是将许多SWT控件放到一个集合中,这些控件有同样的尺寸和位置。但只有在最上面的控件才能被显示。

  StackLayout只有一个空的构造函数,它只有一个属性topControl,这个属必确定了哪一个控件可以被显示。这个属性默认值是null,也就是说,如果不设置它,那将没有控件被显示在窗体上。但要注意的是,设置topControl并不会将StackLayout中控件删除。

package layout;

import org.eclipse.swt.events.*;
import org.eclipse.swt.widgets.*;
import org.eclipse.swt.custom.StackLayout;
import org.eclipse.swt.SWT;

public class TestStackLayout
{
 public static void main(String[] args)
 {
  Display display = new Display();
  Shell shell = new Shell(display);
  StackLayout layout = new StackLayout();
  shell.setLayout(layout);
  StackLayoutSelectionAdapter adapter = new StackLayoutSelectionAdapter(shell, layout);
  Button one = new Button(shell, SWT.PUSH);
  one.setText("按钮1");
  one.addSelectionListener(adapter);
  Button two = new Button(shell, SWT.PUSH);
  two.setText("按钮2");
  two.addSelectionListener(adapter);
  Button three = new Button(shell, SWT.PUSH);
  three.setText("按钮3");
  three.addSelectionListener(adapter);
  layout.topControl = one;
  shell.open();
  while (!shell.isDisposed())
  {
   if (!display.readAndDispatch())
   {
    display.sleep();
   }
  }
  display.dispose();
 }
}

class StackLayoutSelectionAdapter extends SelectionAdapter
{
 Shell shell;
 StackLayout layout;

 public StackLayoutSelectionAdapter(Shell shell, StackLayout layout)
 {
  this.shell = shell;
  this.layout = layout;
 }

 public void widgetSelected(SelectionEvent event)
 {
  Control control = layout.topControl;
  Control[] children = shell.getChildren();
  int i = 0;
  for (int n = children.length; i < n; i++)
  {
   Control child = children[i];
   if (child == control)
   {
    break;
   }
  }
  ++i;
  if (i >= children.length)
   i = 0;
  layout.topControl = children[i];
  shell.layout();
 }
}

  上面这个例子在Shell上有三个按钮,通过按最上面显示的按钮,这三个按钮循环交替显示。

分享到:
评论

相关推荐

    networkx 画图布局.zip

    首先,`networkx`库提供了多种布局算法,如`spring_layout`、`fruchterman_reingold_layout`、`kamada_kawai_layout`和`shell_layout`等,这些布局算法旨在根据图形的结构特征将节点分布在二维平面上,以便于观察和...

    xpe模板 XPE系统定制组件.zip

    这两个文件都是SLD(Shell Layout Description)文件,用于定义XPE系统的界面布局和组件选择。 首先,我们来看“Full XP Pro 2007.sld”。这个文件很可能代表了一种完整版的Windows XP Professional 2007的组件集,...

    capital_shell_ios 2021-07-27 19-44-42.zip

    5. **自动布局和响应式设计**:为了适应不同尺寸和方向的屏幕,iOS开发者需要熟练掌握Auto Layout和Size Classes,确保UI在各种设备上都能良好展示。 6. **多线程与异步处理**:iOS应用通常使用Grand Central ...

    swt layout

    3. 对子组件设置布局数据,这可能涉及到`LayoutData`对象的使用,以便于布局管理器正确地定位和调整子组件的大小。 通过以上布局管理器,开发者可以创建出各种符合需求的用户界面。在实际编程中,选择合适的布局...

    Android 如何执行shell脚本.doc

    setContentView(R.layout.main); tv = (TextView)findViewById(R.id.tv01); try { execCommand("./data/kenshin/x.sh"); } catch (IOException e) { e.printStackTrace(); } } public void execCommand...

    清楚android项目工程drawable/mipmap/layout/menu路径下无用的资源文件

    shell脚本编写的功能,在Linux和mac终端上运行;主要用于Android studio下的Android项目,自动清除项目drawable、mimap、layout和menu下无用的资源文件

    bsp-layout:管理bspwm中的布局(高和宽)

    由于`bsp-layout`是基于Bash Shell的,你可以结合其他Bash工具和命令行工具,如`xprop`和`xdotool`,来实现更复杂的窗口操作。例如,使用`xprop`获取窗口属性,`xdotool`控制鼠标和键盘事件,可以实现自动化操作,如...

    SSH Secure Shell.rar 连接器

    2. `layout.bin`:这通常是安装程序的布局信息文件,用于指导安装过程中的界面布局和元素位置。 3. `setup.bmp`:这可能是一个设置或安装过程的背景图像文件,提升用户体验。 4. `data2.cab` 和 `data1.cab`:这些...

    i3-keyboard-layout:通过按键更改键盘布局,并在状态栏中显示它

    安装下载i3-keyboard-layout ,确保它是可执行文件( chmod + x &lt;file&gt; ),并将其存储在主目录中(如果需要,也可以存储在$PATH )用法在配置中分配一个按键,以切换到不同的布局: # ~/.config/i3/configbindsym $...

    sass-director:一个可生成Shell脚本以基于您的Sass清单文件构建目录结构的应用程序

    萨斯导演一个可生成Shell脚本以基于您的Sass清单文件构建目录结构的应用程序。使用输入: @import " utils/variables " ;@import " utils/functions " ;@import " utils/mixins " ;@import " utils/placeholders " ;...

    网易云课程“Linux 入门基础”课程学习笔记

    **Create Custom Layout** → **Standard Partition** → 创建swap分区 → 创建根分区。 3. **Format**确认 → **Write changes to disk** → 选择引导方式 → **Desktop**环境选择 → 安装所需软件包 → 完成安装...

    eclipse开发SWT应用

    shell.setLayout(layout); Button button = new Button(shell, SWT.PUSH); button.setText("Click me!"); shell.pack(); shell.open(); while (!shell.isDisposed()) { if (!display.readAndDispatch()) {...

    java swt table

    Shell shell = new Shell(display); shell.setSize(800, 600); // 使用GridLayout布局Shell GridLayout gridLayout = new GridLayout(2, false); shell.setLayout(gridLayout); // 创建Tree控件 Tree tree...

    LatinAmerican.keylayout:OS X的拉丁美洲布局

    "LatinAmerican.keylayout"就是其中一种,专为OS X设计的拉丁美洲键盘布局。这个布局考虑了拉丁字母语言的特殊字符,包括西班牙语、葡萄牙语和其他使用拉丁字母的美洲国家的语言。 首先,我们需要理解什么是键盘...

    MacOSKeyLayouts:PC ISO瑞士德语的Mac OS .keylayout文件

    MacOSKeyLayouts PC ISO瑞士德语的Mac OS .keylayout文件 取自并改编自: : 如何在系统范围内安装 sudo ./install.sh 然后,键盘布局应出现在系统偏好设置-&gt;键盘-&gt;输入源-&gt; +-&gt;其他(在最底部)下。

    Widgets-Layout

    在Shell中添加临时环境变量 在.env添加开发环境变量 我可以使用装饰器吗? 使用AJAX请求获取数据 与API后端集成 节点 Ruby on Rails 在开发中代理API请求 配置代理后出现“无效的主机头”错误 手动配置代理 配置...

    java内嵌浏览器源码.doc

    shell.setLayout(layout); ``` 并将浏览器组件添加到布局中。 5. **监听事件**: 可以注册监听器来处理浏览器的各种事件,如页面加载完成、地址更改、窗口关闭等。例如,可以添加`LocationListener`来监听URL的...

    使用java SWT编写界面的例子,多代码

    shell.setLayout(layout); // 创建两个按钮,它们将按列排列 Button button1 = new Button(shell, SWT.PUSH); button1.setText("Button 1"); Button button2 = new Button(shell, SWT.PUSH); button2.setText(...

    使用 SWT 写图形化界面的例子(eclipse)

    shell.setLayout(layout); ``` 在`swt_test`这个压缩包中,你可能会找到一个完整的SWT示例项目,包括源代码和运行结果。通过研究这个例子,你可以看到SWT是如何与Eclipse集成,以及如何构建复杂的用户界面的。 总...

    Standard Widget Toolkit(Java swt)类库以及安装文档

    shell.setLayout(layout); Label label = new Label(shell, SWT.NONE); label.setText("Hello, SWT!"); Button button = new Button(shell, SWT.PUSH); button.setText("Click me"); button.addListener...

Global site tag (gtag.js) - Google Analytics