grivate與layout_gravite的區別和GridLayout的簡單使用

先看看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);//設置寬度
        }

    }
}

效果如下

這樣就更加美觀了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章