先看看Gridlayout的简单使用
<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:columnCount="4"
android:orientation="horizontal"
android:rowCount="5"
tools:context=".MainActivity">
<!-- 设定好column和row后,控件就会按照horizontal的方向逐次排练
,我们可以使用layout_rowSpan 和layout_columnSpan来确定占位-->
<Button android:text="1"></Button>
<Button android:text="2"></Button>
<Button android:text="3"></Button>
<Button android:text="/"
></Button>
<Button android:text="4"></Button>
<Button android:text="5"></Button>
<Button android:text="6"></Button>
<Button android:text="*"></Button>
<Button android:text="7"></Button>
<Button android:text="8"></Button>
<Button android:text="9"></Button>
<Button android:text="-"></Button>
<Button
android:layout_columnSpan="2"
android:layout_gravity="fill"
android:text="0"></Button>
<Button android:text="."></Button>
<Button
android:layout_rowSpan="2"
android:layout_gravity="fill"
android:text="+"></Button>
<Button
android:layout_columnSpan="3"
android:layout_gravity="fill"
android:text="="></Button>
</GridLayout>
效果如下
我们可以看到这样明显不太美观,那么我们如何填满整个屏幕呢
我们应该使用屏幕的长度/列数来填充。
看下面的代码
public class MainActivity extends AppCompatActivity {
private int column;
private int Screenwidth;
private GridLayout mygridlayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mygridlayout = (GridLayout) findViewById(R.id.gridlayout);
column = mygridlayout.getColumnCount();//获取列数
Screenwidth = this.getWindowManager().getDefaultDisplay().getWidth();
for (int i = 0; i < mygridlayout.getChildCount(); i++) {
Button button = (Button) mygridlayout.getChildAt(i);//返回你的按钮
button.setWidth(Screenwidth / column);//设置宽度
}
}
}
效果如下
这样就更加美观了。