Android实现计算器布局(四种布局方式)之GridLayout网格布局

网格布局:GridLayout

其他三种布局:

RelativeLayout相对布局实现计算器界面布局

LinearLayout线性布局实现计算器界面布局

TableLayout表格布局实现计算器界面布局

网格布局实现计算器界面布局非常简单,实现跨行跨列功能主要用到:
layout_columnSpan属性和layout_rowSpan

如:
android:layout_columnSpan=”3”
android:layout_gravity=”fill”

设置为fill能让控件占满所跨的行或列

界面效果:

计算器布局-网格布局

outline视图

计算器布局-网格布局

布局源码:

<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:columnCount="6"
    android:orientation="vertical"
    android:rowCount="9" >

    <!-- n行n列 -->

    <Button
        android:id="@+id/button1"
        android:layout_column="0"
        android:layout_gravity="left"
        android:layout_row="0"
        android:text="1" />

    <Button
        android:id="@+id/button4"
        android:layout_column="0"
        android:layout_gravity="right|bottom"
        android:layout_row="1"
        android:text="4" />

    <Button
        android:id="@+id/button7"
        android:layout_column="0"
        android:layout_gravity="left|bottom"
        android:layout_row="2"
        android:text="7" />

    <Button
        android:id="@+id/button13"
        android:layout_column="0"
        android:layout_columnSpan="2"
        android:layout_gravity="fill"
        android:layout_row="3"
        android:text="0" />

    <Button
        android:id="@+id/button14"
        android:layout_column="0"
        android:layout_columnSpan="3"
        android:layout_gravity="fill"
        android:layout_row="4"
        android:text="+" />

    <Button
        android:id="@+id/button2"
        android:layout_column="1"
        android:layout_gravity="left|bottom"
        android:layout_row="0"
        android:text="2" />

    <Button
        android:id="@+id/button5"
        android:layout_column="1"
        android:layout_gravity="left|bottom"
        android:layout_row="1"
        android:text="5" />

    <Button
        android:id="@+id/button8"
        android:layout_column="1"
        android:layout_gravity="right"
        android:layout_row="2"
        android:text="8" />

    <Button
        android:id="@+id/button3"
        android:layout_column="2"
        android:layout_gravity="left|bottom"
        android:layout_row="0"
        android:text="3" />

    <Button
        android:id="@+id/button6"
        android:layout_column="2"
        android:layout_gravity="left"
        android:layout_row="1"
        android:text="6" />

    <Button
        android:id="@+id/button9"
        android:layout_column="2"
        android:layout_gravity="left"
        android:layout_row="2"
        android:text="9" />

    <Button
        android:id="@+id/button17"
        android:layout_column="2"
        android:layout_gravity="left"
        android:layout_row="3"
        android:text="." />

    <Button
        android:id="@+id/button16"
        android:layout_column="3"
        android:layout_columnSpan="2"
        android:layout_gravity="left"
        android:layout_row="0"
        android:text="/" />

    <Button
        android:id="@+id/button10"
        android:layout_column="3"
        android:layout_columnSpan="2"
        android:layout_gravity="left"
        android:layout_row="1"
        android:text="*" />

    <Button
        android:id="@+id/button11"
        android:layout_column="4"
        android:layout_gravity="left|bottom"
        android:layout_row="2"
        android:text="-" />

    <Button
        android:id="@+id/button12"
        android:layout_column="4"
        android:layout_gravity="fill"
        android:layout_row="3"
        android:layout_rowSpan="2"
        android:text="=" />

    <Space
        android:layout_width="1dp"
        android:layout_height="32dp"
        android:layout_column="0"
        android:layout_row="2" />

    <Space
        android:layout_width="63dp"
        android:layout_height="15dp"
        android:layout_column="5"
        android:layout_row="2" />

    <Space
        android:layout_width="100dp"
        android:layout_height="220dp"
        android:layout_row="7" />

    <TextView
        android:id="@+id/textView1"
        android:layout_column="0"
        android:layout_columnSpan="5"
        android:layout_gravity="fill"
        android:layout_row="6"
        android:text="0"
        android:textAppearance="?android:attr/textAppearanceLarge" />

</GridLayout>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值