Java SWT:具有ScrolledComposite的嵌套布局超出可用空间
我想使用SWT为我的一个应用程序构建一个主细节布局 容器、内容、侧栏和Part1是复合实例。 Scrolled是一个ScrolledComposite 所需的布局类似于:Java SWT:具有ScrolledComposite的嵌套布局超出可用空间,java,layout,swt,grid-layout,scrolledcomposite,Java,Layout,Swt,Grid Layout,Scrolledcomposite,我想使用SWT为我的一个应用程序构建一个主细节布局 容器、内容、侧栏和Part1是复合实例。 Scrolled是一个ScrolledComposite 所需的布局类似于: +--Container-------------------------------------+ |+--Content----------------------++--Sidebar----+| || ||+--Part1----+|| ||
+--Container-------------------------------------+
|+--Content----------------------++--Sidebar----+|
|| ||+--Part1----+||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||+-----------+||
|| ||+--Scrolled-+||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||| |||
|| ||+-----------+||
|+-------------------------------++-------------+|
+------------------------------------------------+
内容应该在水平和垂直方向上抓住所有可用的空间
侧边栏基本上是Part1的容器,滚动条的高度应该相等
Scrolled是组合的容器,包含动态数量的子项,这些子项排列在内容组合中。因为子项的数量可能会有很大的变化,所以这个组合应该是可滚动的
我现在以以下方式实施了这一点:
- 容器的网格布局为2列
- 其中,内容既有填充行为,也有抓取所有水平/垂直空间
- 侧边栏有一个FillLayout(SWT.VERTICAL)并包含Part1和滚动的child
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();
}
}
public类已滚动{
公共静态void main(字符串[]args){
显示=新显示();
外壳=新外壳(显示);
shell.setLayout(新的GridLayout(2,false));
//shell.setLayout(新填充布局(SWT.HORIZONTAL));
复合材料含量=新复合材料(外壳、SWT.边框);
setLayoutData(新的GridData(SWT.LEFT,SWT.CENTER,false,false));
复合材料侧栏=新复合材料(壳体、SWT.边框);
侧栏设置布局(新的填充布局(SWT.垂直));
setLayoutData(新的GridData(SWT.LEFT,SWT.CENTER,false,false));
复合材料cc=新复合材料(侧栏,SWT.边框);
ScrolledComposite sc=新的ScrolledComposite(侧栏,SWT.BORDER
|SWT.V|U卷轴(SWT.H|U卷轴);
sc.setLayout(新网格布局(1,真));
复合材料c=新复合材料(sc,SWT.无);
c、 设置大小(400400);
c、 setLayout(新的GridLayout(1,true));
对于(int i=0;i<1000;i++){
新按钮(c,SWT.PUSH).SETEXT(“文本”);
}
sc.setMinSize(c.computeSize(SWT.DEFAULT,SWT.DEFAULT));
sc.setContent(c);
sc.setExpandHorizontal(真);
sc.setExpandVertical(真);
sc.setAlwaysShowScrollBars(真);
shell.open();
而(!shell.isDisposed()){
如果(!display.readAndDispatch())
display.sleep();
}
display.dispose();
}
}
看来我找到了解决方案
似乎复合材料必须采取GRAB\u overse\u VERTICAL
的方式,以限制可用宽度。否则,将为零部件指定首选高度,即一次显示所有零部件的最大高度
以下代码更改实现了这一目的:
content.setLayoutData(new GridData(SWT.FILL,SWT.FILL,true,true));
sidebar.setLayoutData(new GridData(SWT.FILL,SWT.FILL,false,true));