我想创建一个工具栏。如果我单击一个图标,列表应该打开。我使用Stack add容器(图标列表)并向其添加一个Table。 (因此所有人都需要在重新调整时进行调整,并且不需要在那里完成工作)
但是我无法通过container.setX(float)设置X轴。但是列表必须在点击的图标下打开。
有没有更好的方法或方法来设置X而不需要alingment?
private void rebuildStage() {
VerticalGroup toolBar = buildToolBar();
VerticalGroup vGroup = new VerticalGroup();
vGroup.fill().setFillParent(true);
vGroup.addActor(toolBar);
clear();
addActor(vGroup);
}
private VerticalGroup buildToolBar() {
ImageButton btnFile = new ImageButton(Assets.instance.btn_skin, "file");
ImageButton btnArrangement = new ImageButton(Assets.instance.btn_skin, "arrangement");
ImageButton btnCollision = new ImageButton(Assets.instance.btn_skin, "collision");
ButtonGroup<ImageButton> buttonGroup = new ButtonGroup<ImageButton>(btnFile, btnArrangement, btnCollision);
buttonGroup.setMinCheckCount(0);
Container<Table> tableFile = new Container<Table>(buildTableFile());
tableFile.top().left();
Container<Table> tableArrangement = new Container<Table>(buildTableArrangement());
tableArrangement.top();
Container<Table> tableCollision = new Container<Table>(buildTableCollision());
tableArrangement.top();
Stack stack = new Stack();
stack.add(tableFile);
stack.add(tableArrangement);
stack.add(tableCollision);
Table layer = new Table(Assets.instance.bg_skin);
layer.setBackground("bg_table");
layer.left();
layer.add(btnFile).padLeft(10);
layer.add(btnArrangement).padLeft(10);
layer.add(btnCollision).padLeft(10);
VerticalGroup vGroup = new VerticalGroup();
vGroup.fill();
vGroup.addActor(layer);
vGroup.addActor(stack);
return vGroup;
}
private Table buildTableFile() {
ImageButton button1 = new ImageButton(Assets.instance.btn_skin, "load");
ImageButton button2 = new ImageButton(Assets.instance.btn_skin, "save");
ImageButton button3 = new ImageButton(Assets.instance.btn_skin, "new");
Table layer = new Table(Assets.instance.bg_skin);
layer.setBackground("bg_table");
layer.add(button1).pad(10, 10, 0, 10).row();
layer.add(button2).pad(10, 10, 0, 10).row();
layer.add(button3).pad(10, 10, 10, 10).row();
return layer;
}
答案 0 :(得分:1)
您可以为工具栏在上创建一个新舞台。
您需要做的就是将 ClickListener 附加到 toolbarStage ,它将检查点击的位置,并在 toolbarStage上呈现工具栏 - 当然你可以在旧的iconsStage上设置另一个 ClickListener ,它将为工具栏设置变量集(我假设它的工作与你点击的图标相关联)。
Stage iconsStage;
Viewport iconsStageViewport;
Stage toolbarStage;
Viewport toolbarStageViewport;
public void prepareStages()
{
... //here you are creating iconsStage, filling it with actors etc...
toolbarStage = new Stage();
toolbarStageViewport = ... //create any viewport you need
toolbarStage.setViewport(toolbarStageViewport );
... //now add to toolbarStage a proper listener and listeners to icons etc...
}
...
public void render()
{
Gdx.gl.glClearColor(0, 0, 0, 1);
Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
iconsStageViewport.update(this.screenWidth, this.screenHeight);
iconsStage.act();
iconsStage.draw();
toolbarStageViewport.update(this.screenWidth, this.screenHeight);
toolbarStage.act();
toolbarStage.draw();
}
请记住如果不使用InputMultiplexer ,您无法使用多个舞台。你可以在这里阅读更多内容: