先看看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);//設置寬度
}
}
}
效果如下
這樣就更加美觀了。