用GridLayout实现计算器的布局


MainActivity.java

package com.kale.gridlayout;

import android.app.Activity;
import android.os.Bundle;
import android.support.v7.widget.GridLayout;
import android.view.Gravity;
import android.widget.Button;

public class MainActivity extends Activity {
	String [] chars = new String[]{
		"7","8","9","÷",
		"4","5","6","x",
		"1","2","3","-",
		".","0","=","+"
	};
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		GridLayout gLayout = (GridLayout)findViewById(R.id.root_gridLayout_id);
		for (int i = 0; i < chars.length; i++) {
			Button bt = new Button(this);
			bt.setText(chars[i]);
			bt.setTextSize(40);
			
			//指定该组件所占的行
			GridLayout.Spec rowSpec = GridLayout.spec(i/4 + 2);
			//指定该组件所占的列
			GridLayout.Spec columnSpec = GridLayout.spec(i % 4); 
			//按照设置好的行和列来建立对象
			GridLayout.LayoutParams params = new GridLayout.LayoutParams(rowSpec,columnSpec);
			//指定该组件占满父控件
			params.setGravity(Gravity.FILL);
			gLayout.addView(bt,params);
		}
		
	}
}

xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="${relativePackage}.${activityClass}" 
     xmlns:app="http://schemas.android.com/apk/res/com.kale.gridlayout">

    <!-- 六行四列 -->
    <android.support.v7.widget.GridLayout
        android:id="@+id/root_gridLayout_id"
        android:layout_width="match_parent"
        android:layout_height="match_parent" 
        app:rowCount="6"
        app:columnCount="4">

        <TextView
            android:layout_width="match_parent"
            android:layout_height="100dp"
            app:layout_columnSpan="4"
            android:text="Large Text"
            android:textAppearance="?android:attr/textAppearanceLarge" />

        <Button
			android:layout_width="match_parent"
			android:layout_height="wrap_content"
            app:layout_gravity="center_horizontal|top"
            app:layout_columnSpan="4"
            android:text="Button" />
    </android.support.v7.widget.GridLayout>

</RelativeLayout>


posted @   developer_Kale  阅读(706)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
网站流量统计工具
点击右上角即可分享
微信分享提示