当前位置:   article > 正文

Android布局之GridLayout的使用总结

gridlayout

文章目录

一、简介

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_columnSpan 、layout_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时,没有问题

四、小米计算器效果

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.v7.widget.GridLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. xmlns:app="http://schemas.android.com/apk/res-auto"
  5. xmlns:tools="http://schemas.android.com/tools"
  6. android:id="@+id/grid_layout"
  7. android:layout_width="match_parent"
  8. android:layout_height="match_parent"
  9. android:background="#ece7e7"
  10. app:alignmentMode="alignBounds"
  11. app:columnCount="4"
  12. app:orientation="horizontal"
  13. app:rowCount="5"
  14. app:useDefaultMargins="false"
  15. tools:context="com.strivestay.gridlayoutdemo.MainActivity">
  16. <!-- 如果不使用 app:layout_gravity="fill"
  17. 则实际下面这个textview的宽度只是wrap_content,
  18. 实现不了想要的right|bottom效果;
  19. 或者,
  20. 用app:layout_columnWeight="1"
  21. 效果等同,填充满
  22. -->
  23. <TextView
  24. android:gravity="right|bottom"
  25. android:text="0"
  26. app:layout_columnSpan="4"
  27. app:layout_rowWeight="3"
  28. app:layout_columnWeight="1"/>
  29. <TextView
  30. android:layout_margin="1dp"
  31. android:background="#ffffff"
  32. android:gravity="center"
  33. android:text="AC"
  34. android:textColor="#f68904"
  35. app:layout_columnWeight="1"
  36. app:layout_rowWeight="1"/>
  37. <TextView
  38. android:layout_margin="1dp"
  39. android:background="#ffffff"
  40. android:gravity="center"
  41. android:text="退格"
  42. app:layout_columnWeight="1"
  43. app:layout_rowWeight="1"/>
  44. <TextView
  45. android:layout_margin="1dp"
  46. android:background="#ffffff"
  47. android:gravity="center"
  48. android:text="/"
  49. app:layout_columnWeight="1"
  50. app:layout_rowWeight="1"/>
  51. <TextView
  52. android:layout_margin="1dp"
  53. android:background="#ffffff"
  54. android:gravity="center"
  55. android:text="*"
  56. app:layout_columnWeight="1"
  57. app:layout_rowWeight="1"/>
  58. <TextView
  59. android:layout_margin="1dp"
  60. android:background="#ffffff"
  61. android:gravity="center"
  62. android:text="7"
  63. app:layout_columnWeight="1"
  64. app:layout_rowWeight="1"/>
  65. <TextView
  66. android:layout_margin="1dp"
  67. android:background="#ffffff"
  68. android:gravity="center"
  69. android:text="8"
  70. app:layout_columnWeight="1"
  71. app:layout_rowWeight="1"/>
  72. <TextView
  73. android:layout_margin="1dp"
  74. android:background="#ffffff"
  75. android:gravity="center"
  76. android:text="9"
  77. app:layout_columnWeight="1"
  78. app:layout_rowWeight="1"/>
  79. <TextView
  80. android:layout_margin="1dp"
  81. android:background="#ffffff"
  82. android:gravity="center"
  83. android:text="—"
  84. app:layout_columnWeight="1"
  85. app:layout_rowWeight="1"/>
  86. <TextView
  87. android:layout_margin="1dp"
  88. android:background="#ffffff"
  89. android:gravity="center"
  90. android:text="4"
  91. app:layout_columnWeight="1"
  92. app:layout_rowWeight="1"/>
  93. <TextView
  94. android:layout_margin="1dp"
  95. android:background="#ffffff"
  96. android:gravity="center"
  97. android:text="5"
  98. app:layout_columnWeight="1"
  99. app:layout_rowWeight="1"/>
  100. <TextView
  101. android:layout_margin="1dp"
  102. android:background="#ffffff"
  103. android:gravity="center"
  104. android:text="6"
  105. app:layout_columnWeight="1"
  106. app:layout_rowWeight="1"/>
  107. <TextView
  108. android:layout_margin="1dp"
  109. android:background="#ffffff"
  110. android:gravity="center"
  111. android:text="+"
  112. app:layout_columnWeight="1"
  113. app:layout_rowWeight="1"/>
  114. <TextView
  115. android:layout_margin="1dp"
  116. android:background="#ffffff"
  117. android:gravity="center"
  118. android:text="1"
  119. app:layout_columnWeight="1"
  120. app:layout_rowWeight="1"/>
  121. <TextView
  122. android:layout_margin="1dp"
  123. android:background="#ffffff"
  124. android:gravity="center"
  125. android:text="2"
  126. app:layout_columnWeight="1"
  127. app:layout_rowWeight="1"/>
  128. <TextView
  129. android:layout_margin="1dp"
  130. android:background="#ffffff"
  131. android:gravity="center"
  132. android:text="3"
  133. app:layout_columnWeight="1"
  134. app:layout_rowWeight="1"/>
  135. <TextView
  136. android:layout_margin="1dp"
  137. android:background="#f68904"
  138. android:gravity="center"
  139. android:text="="
  140. android:textColor="#ffffff"
  141. app:layout_columnWeight="1"
  142. app:layout_rowSpan="2"
  143. app:layout_rowWeight="1"/>
  144. <TextView
  145. android:layout_margin="1dp"
  146. android:background="#ffffff"
  147. android:gravity="center"
  148. android:text="%"
  149. app:layout_columnWeight="1"
  150. app:layout_rowWeight="1"/>
  151. <TextView
  152. android:layout_margin="1dp"
  153. android:background="#ffffff"
  154. android:gravity="center"
  155. android:text="0"
  156. app:layout_columnWeight="1"
  157. app:layout_rowWeight="1"/>
  158. <TextView
  159. android:layout_margin="1dp"
  160. android:background="#ffffff"
  161. android:gravity="center"
  162. android:text="."
  163. app:layout_columnWeight="1"
  164. app:layout_rowWeight="1"/>
  165. </android.support.v7.widget.GridLayout>

效果: 4.4.4模拟器

五、动态加载

1.xml引用GridLayout

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.v7.widget.GridLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. xmlns:app="http://schemas.android.com/apk/res-auto"
  5. xmlns:tools="http://schemas.android.com/tools"
  6. android:id="@+id/grid_layout"
  7. android:layout_width="match_parent"
  8. android:layout_height="match_parent"
  9. android:background="#ece7e7"
  10. app:orientation="horizontal"
  11. app:useDefaultMargins="false"
  12. app:alignmentMode="alignBounds"
  13. tools:context="com.strivestay.gridlayoutdemo.MainActivity">
  14. </android.support.v7.widget.GridLayout>

2.动态添加

  1. import android.graphics.Color;
  2. import android.os.Bundle;
  3. import android.support.v7.app.AppCompatActivity;
  4. import android.support.v7.widget.GridLayout;
  5. import android.view.Gravity;
  6. import android.widget.TextView;
  7. /**
  8. * GridLayout示例
  9. * @author StriveStay
  10. * @date 2018/3/27
  11. */
  12. public class MainActivity extends AppCompatActivity {
  13. private String[] mStrings = {"0","AC","退格","/","*","7","8","9","—","4","5","6","+","1","2","3","=","%","0","."};
  14. @Override
  15. protected void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. // xml布局
  18. // setContentView(R.layout.activity_main);
  19. // 动态添加
  20. setContentView(R.layout.activity_main2);
  21. GridLayout gridLayout = (GridLayout) findViewById(R.id.grid_layout);
  22. // 64
  23. gridLayout.setColumnCount(4);
  24. gridLayout.setRowCount(6);
  25. for (int i = 0; i < mStrings.length; i++) {
  26. TextView textView = new TextView(this);
  27. GridLayout.LayoutParams params = new GridLayout.LayoutParams();
  28. params.width =0;
  29. params.height =0;
  30. if(i == 0){
  31. // 设置行列下标, 所占行列 ,比重
  32. // 对应: layout_row , layout_rowSpan , layout_rowWeight
  33. // 如下代表: item坐标(0,0), 占 1 行,比重为 3 ; 占 4 列,比重为 1
  34. params.rowSpec = GridLayout.spec(0,1,3f);
  35. params.columnSpec = GridLayout.spec(0,4,1f);
  36. textView.setGravity(Gravity.BOTTOM|Gravity.RIGHT);
  37. }else{
  38. // 设置行列下标,和比重
  39. params.rowSpec = GridLayout.spec((i+3)/4,1f);
  40. params.columnSpec = GridLayout.spec((i+3)%4,1f);
  41. // 背景
  42. textView.setBackgroundColor(Color.WHITE);
  43. // 字体颜色
  44. if("AC".equals(mStrings[i])){
  45. textView.setTextColor(Color.parseColor("#f68904"));
  46. }
  47. if("=".equals(mStrings[i])){
  48. textView.setBackgroundColor(Color.parseColor("#f68904"));
  49. textView.setTextColor(Color.WHITE);
  50. params.rowSpec = GridLayout.spec((i+3)/4,2,1f);
  51. }
  52. // 居中显示
  53. textView.setGravity(Gravity.CENTER);
  54. // 设置边距
  55. params.setMargins(2,2,2,2);
  56. }
  57. // 设置文字
  58. textView.setText(mStrings[i]);
  59. // 添加item
  60. gridLayout.addView(textView,params);
  61. }
  62. }
  63. }

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

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

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

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/614233
推荐阅读
相关标签
  

闽ICP备14008679号