我想使用 SWT 为我的一个应用程序构建一个主从布局。
Container、Content、Sidebar 和 Part1 是 Composite 实例。Scrolled 是一个 ScrolledComposite
所需的布局类似于:
+--Container-------------------------------------+
|+--Content----------------------++--Sidebar----+|
|| ||+--Part1----+||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||+-----------+||
|| ||+--Scrolled-+||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||+-----------+||
|+-------------------------------++-------------+|
+------------------------------------------------+
内容应该在水平和垂直方向上占据所有可用的空间。
侧边栏基本上是 Part1 和 Scrolled 的容器,它们的高度应该相等。
Scrolled 是 Composite 的容器,其中包含动态数量的子项,这些子项排列在内容组合中。因为子项的数量可能会有很大的变化,所以这个 Composite 应该是可滚动的。
我现在已经通过以下方式实现了这一点:
Container 有一个 GridLayout 和 2 列。
其中内容具有 FILL_BOTH 行为并且还抓取所有水平/垂直空间。
侧边栏有一个 FillLayout(SWT.VERTICAL) 并包含 Part1 和 Scrolled Childs。
问题: 当将大量项目放入滚动组合中时,布局刚好溢出可用空间,并且在应有的位置没有可用的滚动。
当我对容器使用 FillLayout(SWT.HORIZONTAL) 时,行为是所希望的,因为存在滚动并且一切都在“范围内”。
有没有办法在使用 GridLayout 时也实现这种行为,因为我希望内容能够占据大部分空间。
附上当前的测试 SWT 片段:
public class Scrolled {
public static void main(String[] args) {
Display display = new Display();
Shell shell = new Shell(display);
shell.setLayout(new GridLayout(2,false));
//shell.setLayout(new FillLayout(SWT.HORIZONTAL));
Composite content = new Composite(shell, SWT.BORDER);
content.setLayoutData(new GridData(SWT.LEFT,SWT.CENTER,false,false));
Composite sidebar = new Composite(shell, SWT.BORDER);
sidebar.setLayout(new FillLayout(SWT.VERTICAL));
sidebar.setLayoutData(new GridData(SWT.LEFT,SWT.CENTER,false,false));
Composite cc = new Composite(sidebar, SWT.BORDER);
ScrolledComposite sc = new ScrolledComposite(sidebar, SWT.BORDER
| SWT.V_SCROLL | SWT.H_SCROLL);
sc.setLayout(new GridLayout(1,true));
Composite c = new Composite(sc, SWT.NONE);
c.setSize(400, 400);
c.setLayout(new GridLayout(1, true));
for(int i = 0; i < 1000; i++){
new Button(c, SWT.PUSH).setText("Text");
}
sc.setMinSize(c.computeSize(SWT.DEFAULT, SWT.DEFAULT));
sc.setContent(c);
sc.setExpandHorizontal(true);
sc.setExpandVertical(true);
sc.setAlwaysShowScrollBars(true);
shell.open();
while (!shell.isDisposed()) {
if (!display.readAndDispatch())
display.sleep();
}
display.dispose();
}
}