一、简介


GridLayout是Android4.0引入的网格布局,使用它可以减少布局嵌套。也算是常用,但一直没仔细看过,今天研究一下

二、常用属性介绍


GridLayout 使用属性

属性作用
android:columnCount最大列数
android:rowCount最大行数
android:orientationGridLayout中子元素的布局方向
android:alignmentModealignBounds:对齐子视图边界 alignMargins :对齐子视距内容,默认值
android:columnOrderPreserved使列边界显示的顺序和列索引的顺序相同,默认是true
android:rowOrderPreserved使行边界显示的顺序和行索引的顺序相同,默认是true
android:useDefaultMargins没有指定视图的布局参数时使用默认的边距,默认值是false

item属性

属性作用
android:layout_column指定该单元格在第几列显示
android:layout_row指定该单元格在第几行显示
android:layout_columnSpan指定该单元格占据的列数
android:layout_rowSpan指定该单元格占据的行数
android:layout_gravity指定该单元格在容器中的位置
android:layout_columnWeight(API21加入)列权重
android:layout_rowWeight(API21加入) 行权重
android:layout_gravity作用
center不改变元素的大小,仅居中
center_horizontal不改变大小,水平居中
center_vertical不改变大小,垂直居中
top不改变大小,置于顶部
left不改变大小,置于左边
bottom不改变大小,置于底部
right不改变大小,置于右边
start不改变大小,根据系统语言,置于开始位置
end不改变大小,置于结尾
fill拉伸元素控件,填满其应该所占的格子
fill_vertical仅垂直方向上拉伸填充
fill_horizontal仅水平方向上拉伸填充
clip_vertical垂直方向上裁剪元素,仅当元素大小超过格子的空间时
clip_horizontal水平方向上裁剪元素,仅当元素大小超过格子的空间时

注意

使用layout_columnSpanlayout_rowSpan时要加上layout_gravity属性,否则没有效果;另外item在边缘时宽高计算会出现错误,需要我们手动设置宽高,否则达不到想要的效果

三、平分问题


GridLayout在API21时引入了android:layout_columnWeightandroid:layout_rowWeight来解决平分问题

那么在API21以前的,想要平分的话:引用兼容包

compile 'com.android.support:gridlayout-v7:25.+'

注意:

  1. 使用该控件,命名空间使用app
  2. 单独设置app:layout_columnWeight时,这一列的所有item都设置为这个属性,才能达到预期效果,否则这一列中设置了该属性的item,都会被隐藏,显示不出来
  3. 单独设置app:layout_rowWeight时,没有问题

四、小米计算器效果


<?xml version="1.0" encoding="utf-8"?>                                                                                    

效果: 4.4.4模拟器


GridLayout 使用总结_第1张图片image

五、动态加载


1.xml引用GridLayout

<?xml version="1.0" encoding="utf-8"?>

2.动态添加

package com.strivestay.gridlayoutdemo;import android.graphics.Color;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.support.v7.widget.GridLayout;import android.view.Gravity;import android.widget.TextView;/** * GridLayout示例 * @author StriveStay * @date 2018/3/27 */public class MainActivity extends AppCompatActivity {    private String[] mStrings = {"0","AC","退格","/","*","7","8","9","—","4","5","6","+","1","2","3","=","%","0","."};    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        // xml布局//        setContentView(R.layout.activity_main);        // 动态添加        setContentView(R.layout.activity_main2);        GridLayout gridLayout = (GridLayout) findViewById(R.id.grid_layout);        // 6行   4列        gridLayout.setColumnCount(4);        gridLayout.setRowCount(6);        for (int i = 0; i < mStrings.length; i++) {            TextView textView = new TextView(this);            GridLayout.LayoutParams params = new GridLayout.LayoutParams();            params.width =0;            params.height =0;            if(i == 0){                // 设置行列下标, 所占行列  ,比重                // 对应: layout_row  , layout_rowSpan , layout_rowWeight                // 如下代表: item坐标(0,0), 占 1 行,比重为 3 ; 占 4 列,比重为 1                params.rowSpec = GridLayout.spec(0,1,3f);                params.columnSpec = GridLayout.spec(0,4,1f);                textView.setGravity(Gravity.BOTTOM|Gravity.RIGHT);            }else{                // 设置行列下标,和比重                params.rowSpec = GridLayout.spec((i+3)/4,1f);                params.columnSpec = GridLayout.spec((i+3)%4,1f);                // 背景                textView.setBackgroundColor(Color.WHITE);                // 字体颜色                if("AC".equals(mStrings[i])){                    textView.setTextColor(Color.parseColor("#f68904"));                }                if("=".equals(mStrings[i])){                    textView.setBackgroundColor(Color.parseColor("#f68904"));                    textView.setTextColor(Color.WHITE);                    params.rowSpec = GridLayout.spec((i+3)/4,2,1f);                }                                // 居中显示                textView.setGravity(Gravity.CENTER);                // 设置边距                params.setMargins(2,2,2,2);            }            // 设置文字            textView.setText(mStrings[i]);            // 添加item            gridLayout.addView(textView,params);        }    }}

效果和用xml中直接布局一样:

GridLayout 使用总结_第2张图片image

注意:
GridLayout.spec(); 这个方法是一个重点,需要好好看一下,而且由于它有几个重载方法,使用时也要注意。比如说下面两个方法:

 public static Spec spec(int start, int size) public static Spec spec(int start, float weight)

我刚开始就忽略了这点,本想用的是第二个带有weight的方法,但是传入参数时,没有加上f,就调用了第一个方法,搞了半天才发现

所以,如果调用的是第二个方法,一定要注意float参数的表示方法,加个f,如:GridLayout.spec(0,1f);

Github示例:GridLayoutDemo


个人总结,水平有限,如果有错误,希望大家能给留言指正!如果对您有所帮助,可以帮忙点个赞!如果转载,希望可以留言告知并在显著位置保留草帽团长的署名和标明文章出处!最后,非常感谢您的阅读!

更多相关文章

  1. android中实现指针滑动的动态效果
  2. android layout属性 .
  3. CardView 设置水波纹效果
  4. Android 命名空间和自定义属性
  5. android 神奇的android:clipChildren属性

随机推荐

  1. Android(安卓)拍照并对照片进行裁剪和压
  2. Android集成支付宝移动支付功能
  3. 简单的android ios抓包技巧
  4. PreferenceActivity用法简介
  5. Android(安卓)ListView下拉/上拉刷新:设计
  6. Android必知必会-自定义Scrollbar样式
  7. Android学习【0】安装android studio报错
  8. android耗时任务_IntentService
  9. android 与服务器用 http Post方法通迅
  10. Android中的Bundle的具体使用