创建按钮或按钮组很容易,
Root root = iface.createRoot(AxisLayout.vertical(), ROOT, modeLayer).
setStyles(make(VALIGN.top, HALIGN.right)).
setBounds(0, 0, width, height).
add(backButton);
然而,我无法弄清楚如何在不同的组中创建两个按钮, 即TOP-LEFT上的一个按钮和TOP-RIGHT上的按钮......
我尝试创建了两个root,一个按钮将被禁用/不可点击。 如果我创建一个根,它们将组合在一起:(
============ 感谢samskivert的详细解答,但我无法产生正确的结果。 对于'原始'答案中的第一个建议,完整代码如下:
Font SMALL = PlayN.graphics().createFont("Helvetica", Font.Style.PLAIN, 24);
final Stylesheet ROOT = SimpleStyles.newSheetBuilder().
add(Element.class, make(FONT.is(SMALL))).
add(Button.class, make(BACKGROUND.is(Background.solid(100)))).create();
Group group = new Group(AxisLayout.vertical()).add(
new Group(AxisLayout.horizontal(), Style.HALIGN.left).add(
new Button("Upper left")),
AxisLayout.stretch(new Shim(1, 1)),
new Group(AxisLayout.horizontal(), Style.HALIGN.right).add(
new Button("Lower right")));
iface.createRoot(AxisLayout.vertical(), ROOT, modeLayer)
.setBounds(0, 0, 960, 640)
.add(group);
它产生这个屏幕(即,它全部居中,而不是左上/下 - ......)
对于第二个,完整代码如下: Font SMALL = PlayN.graphics()。createFont(“Helvetica”,Font.Style.PLAIN,24);
final Stylesheet ROOT = SimpleStyles.newSheetBuilder().
add(Element.class, make(FONT.is(SMALL))).
add(Button.class, make(BACKGROUND.is(Background.solid(100)))).create();
Group group = new Group(new BorderLayout()).add(
new Group(AxisLayout.horizontal(), Style.HALIGN.left).
setConstraint(BorderLayout.NORTH).add(
new Button("Upper left")),
new Group(AxisLayout.vertical(), Style.HALIGN.right).
setConstraint(BorderLayout.SOUTH).add(
new Button("Lower right")));
iface.createRoot(AxisLayout.vertical(), ROOT, modeLayer)
.setBounds(0, 0, 960, 640)
.add(group);
它产生这个截图(即,它集中在和重叠......)
再次感谢。
答案 0 :(得分:1)
编辑:哎呀,现在我看到你想要左上角和右上角,而不是左上角和右下角。您想要的配置更简单。只需在按钮之间粘贴一个拉伸的垫片:
iface.createRoot(AxisLayout.vertical().offStretch(), ROOT, modeLayer).
setBounds(0, 0, width, height).
add(new Group(AxisLayout.horizontal()).add(
new Button("Upper-left"),
AxisLayout.stretch(new Shim(1, 1)),
new Button("Upper-right")));
原始回答:
AxisLayout在(水平或垂直)线中布置其所有元素。它们都必须彼此相邻,两者之间存在可配置的差距。如果要使用AxisLayout完成所需的布局,则需要使用嵌套组,如下所示:
+---------------------------------------+
|+-------------------------------------+|
|| [Button] left-aligned AxisLayout ||
|+-------------------------------------+|
| |
| [stretched shim widget] | <-- vertical AxisLayout
| |
|+-------------------------------------+|
|| right-aligned AxisLayout [Button] ||
|+-------------------------------------+|
+---------------------------------------+
在代码中,它看起来像:
Group group = new Group(AxisLayout.vertical()).add(
new Group(AxisLayout.horizontal(), Style.HALIGN.left).add(
new Button("Upper left")),
AxisLayout.stretch(new Shim(1, 1)),
new Group(AxisLayout.horizontal(), Style.HALIGN.right).add(
new Button("Lower right")));
你也可以使用BorderLayout来避免中间的垫片:
Group group = new Group(new BorderLayout()).add(
new Group(AxisLayout().horizontal(), Style.HALIGN.left).
setConstraint(BorderLayout.NORTH).add(
new Button("Upper left")),
new Group(AxisLayout.vertical(), Style.HALIGN.right).
setConstraint(BorderLayout.SOUTH).add(
new Button("Lower right")));