GridLayout获取适合区域的按钮

时间:2016-01-19 18:57:31

标签: android android-gridlayout

我正在为Android设计游戏。代码已经有效,但我在UI方面遇到了一些问题。所有布局类型都令人困惑,似乎从来没有有助于定义它们的属性。基本上,我希望使我的按钮以编程方式添加,完全填满屏幕底部的整个空间。可能有2到6个按钮,具体取决于玩家选择的难度设置。但最终,我甚至会满足于在这里均匀适合所有6个按钮的布局。我不确定为什么这不会填写.xml设计器指示的整个区域。我试图在下面提供相关部分,但很高兴根据要求添加其他详细信息。

Game Image

这是网格布局的初始XML

  <GridLayout
        android:layout_width="match_parent"
        android:layout_height="182dp"
        android:rowCount="2"
        android:columnCount="3"
        android:id="@+id/buttonsLayout"
        android:layout_gravity="center"></GridLayout>

GridLayout

在此处设置按钮:

private static void setButtons() {
    for (int i = 0; i < GlobalValues.numberOfColors; i++) {
        Button b = new Button(mainActivity);
        ImageView IV = new ImageView(mainActivity);
        switch (i) {
            case 0:
                IV.setImageResource(R.drawable.red);
                b.setId(i);
                break;
            case 1:
                IV.setImageResource(R.drawable.green);
                b.setId(i);
                break;
            case 2:
                IV.setImageResource(R.drawable.blue);
                b.setId(i);
                break;
            case 3:
                IV.setImageResource(R.drawable.yellow);
                b.setId(i);
                break;
            case 4:
                IV.setImageResource(R.drawable.purple);
                b.setId(i);
                break;
            case 5:
                IV.setImageResource(R.drawable.cyan);
                b.setId(i);
                break;
            default:
                break;
        }
        b.setBackgroundDrawable(IV.getDrawable());
        b.setOnClickListener(new Button.OnClickListener() {
            public void onClick(View view) {
                UI.UpdateColor(view);
            }
        });

        buttonsLayout.addView(b);
    }
}

最后,这是目前的样子。显然没有很好地利用整个区域,我不知道为什么。

1 个答案:

答案 0 :(得分:1)

Align Buttons in GridLayout可能会对您有所帮助。我知道这不完全是你的情况,但你说现在它足以解决它的6个按钮,所以这可能有效。顺便说一句,如果我是你,我会有不同的布局,取决于按钮的数量,使它们很好。但从6开始就是这样。