[Android]笔记8-GridLayout布局
2017-05-23 16:33
197 查看
GridLayout
概述
GridLayout即网格布局,它是Android4.0新增的布局管理器,因此需要在Android4.0之后的版本中才能使用该布局。
GridLayout的作用类似于HTML中的table标签,它把整个容器划分成rowsxcolumns个网格,每个网格可以放置一个组件。
初次之外,也可以设置一个组件横跨多少列、一个组件纵跨多少行。
GridLayout提供了setRowCount(int)和setColumnCount(int)方法来控制该网格的行数量和列数量
为了控制GridLayout布局容器中各子组件的布局分布,GridLayout提供了一个内部类:
GridLayout.layoutParams
XML属性及方法
XML属性 相关方法 说明
android:alignmentMode setAlignmentMode(int) 设置该布局管理器采用的对齐模式
android:columnCount setColumnCount(int) 设置该网格的列数量
android:columnOrderPreserved setColumnOrderPreserved(boolean) 设置该网格容器是否保留列序号
android:rowCount setRowCount(int) 设置该网格的行数量
android:rowOrderPreserved setRowOrderPreserved(boolean) 设置该网格容器是否保留行序号
android:useDefaultMargins setUseDefaultMargins(boolean) 设置该布局管理器是否使用默认的页边距
设计计算器界面:
概述
GridLayout即网格布局,它是Android4.0新增的布局管理器,因此需要在Android4.0之后的版本中才能使用该布局。
GridLayout的作用类似于HTML中的table标签,它把整个容器划分成rowsxcolumns个网格,每个网格可以放置一个组件。
初次之外,也可以设置一个组件横跨多少列、一个组件纵跨多少行。
GridLayout提供了setRowCount(int)和setColumnCount(int)方法来控制该网格的行数量和列数量
为了控制GridLayout布局容器中各子组件的布局分布,GridLayout提供了一个内部类:
GridLayout.layoutParams
XML属性及方法
XML属性 相关方法 说明
android:alignmentMode setAlignmentMode(int) 设置该布局管理器采用的对齐模式
android:columnCount setColumnCount(int) 设置该网格的列数量
android:columnOrderPreserved setColumnOrderPreserved(boolean) 设置该网格容器是否保留列序号
android:rowCount setRowCount(int) 设置该网格的行数量
android:rowOrderPreserved setRowOrderPreserved(boolean) 设置该网格容器是否保留行序号
android:useDefaultMargins setUseDefaultMargins(boolean) 设置该布局管理器是否使用默认的页边距
设计计算器界面:
<?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="match_parent" android:layout_height="match_parent" android:rowCount="6" android:columnCount="4" android:id="@+id/root" tools:context="com.dezai.gridlayouttest.MainActivity"> <!--定义一个横跨4列的文本框, 并设置该文本框的前景色、背景色等属性--> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_columnSpan="4" android:textSize="50sp" android:layout_marginLeft="2pt" android:layout_marginRight="2pt" android:padding="3pt" android:layout_gravity="right" android:background="#eee" android:textColor="#000" android:text="0" /> <!--定义一个横跨4列的按钮--> <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_columnSpan="4" android:layout_gravity="fill" android:text="清除" /> </GridLayout>
package com.dezai.gridlayouttest; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.Gravity; import android.widget.Button; import android.widget.GridLayout; public class MainActivity extends AppCompatActivity { GridLayout gridLayout; //定义16个按钮的文本 String[] chars=new String[]{ "7","8","9","÷", "4","5","6","×", "1","2","3","-", ".","0","=","+", }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); gridLayout =(GridLayout) findViewById(R.id.root); for(int i=0;i<chars.length;i++) { Button bn=new Button(this); bn.setText(chars[i]); //设置按钮的字体大小 bn.setTextSize(40); //设置按钮四周的空白区域 bn.setPadding(5,35,5,35); //指定该组件所在的行 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); gridLayout.addView(bn,params); } } }
相关文章推荐
- ANDROID笔记:基于GridLayout布局的简易计算器
- Android笔记——GridLayout布局
- Android用户界面设计——关于布局的学习笔记
- Android布局文件属性笔记
- android笔记二(水平布局与垂直布局)
- 第16章、布局Layouts之GridLayout网格布局(从零开始学Android)
- Android的布局和Intent笔记和常用实例
- Android(OPhone) 学习笔记 - 布局
- Android开发入门之学习笔记(四):程序窗口的布局(二)
- swing 学习笔记十二(网格布局GridLayout)
- Android 布局笔记
- android界面开发小结——android笔记---控件和布局
- Android的布局和Intent笔记和常用实例
- Android布局文件属性笔记
- Android开发笔记3-- 动态布局
- swing 学习笔记十二(网格布局GridLayout)
- Android的布局和Intent笔记和常用实例
- Android的布局和Intent笔记和常用实例
- Android 面试题笔记-------android五种布局及其作用
- 【转】Android 面试题笔记-------android五种布局及其作用