libGDX:创建一个toolBar

时间:2015-09-02 22:06:59

标签: java libgdx scene2d

我想创建一个工具栏。如果我单击一个图标,列表应该打开。我使用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;
}

1 个答案:

答案 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 ,您无法使用多个舞台。你可以在这里阅读更多内容:

https://github.com/libgdx/libgdx/wiki/Event-handling