当前位置: 首页 > news >正文

android动态添加列数,Android 具有动态跨度计数的GridLayoutManager

示例

使用gridlayout布局管理器创建recyclerview时,必须在构造函数中指定跨度计数。跨度计数是指列数。这相当笨拙,并且没有考虑更大的屏幕尺寸或屏幕方向。一种方法是为各种屏幕尺寸创建多个布局。下面可以看到另一种更动态的方法。

首先,我们创建一个自定义的RecyclerView类,如下所示:

public class AutofitRecyclerView extends RecyclerView {

private GridLayoutManager manager;

private int columnWidth = -1;

public AutofitRecyclerView(Context context) {

super(context);

init(context, null);

}

public AutofitRecyclerView(Context context, AttributeSet attrs) {

super(context, attrs);

init(context, attrs);

}

public AutofitRecyclerView(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

init(context, attrs);

}

private void init(Context context, AttributeSet attrs) {

if (attrs != null) {

int[] attrsArray = {

android.R.attr.columnWidth

};

TypedArray array = context.obtainStyledAttributes(attrs, attrsArray);

columnWidth = array.getDimensionPixelSize(0, -1);

array.recycle();

}

manager = new GridLayoutManager(getContext(), 1);

setLayoutManager(manager);

}

@Override

protected void onMeasure(int widthSpec, int heightSpec) {

super.onMeasure(widthSpec, heightSpec);

if (columnWidth > 0) {

int spanCount = Math.max(1, getMeasuredWidth() / columnWidth);

manager.setSpanCount(spanCount);

}

}

}

此类确定可以在recyclerview中容纳多少列。要使用它,您需要将其放入您的计算机中layout.xml,如下所示:

xmlns:android="http://schemas.android.com/apk/res/android"

android:id="@+id/auto_fit_recycler_view"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:columnWidth="200dp"

android:clipToPadding="false"

/>

注意,我们使用columnWidth属性。recyclerview将需要它来确定可容纳可用空间的列数。

在您的活动/片段中,您仅获得对recylerview的引用,并为其设置适配器(以及要添加的任何物品装饰或动画)。不要设置版面管理器

RecyclerView recyclerView = (RecyclerView) findViewById(R.id.auto_fit_recycler_view);

recyclerView.setAdapter(new MyAdapter());

(其中MyAdapter是您的适配器类)

现在,您将拥有一个recyclerview,该视图将调整跨度计数(即列)以适合屏幕尺寸。作为最后的补充,您可能想将列在recyclerview中居中(默认情况下,它们与layout_start对齐)。您可以通过稍微修改AutofitRecyclerView类来实现。首先在recyclerview中创建一个内部类。这是从GridLayoutManager扩展的类。它将在左侧和右侧添加足够的填充以使行居中:

public class AutofitRecyclerView extends RecyclerView {

// 等见上面

private class CenteredGridLayoutManager extends GridLayoutManager {

public CenteredGridLayoutManager(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {

super(context, attrs, defStyleAttr, defStyleRes);

}

public CenteredGridLayoutManager(Context context, int spanCount) {

super(context, spanCount);

}

public CenteredGridLayoutManager(Context context, int spanCount, int orientation, boolean reverseLayout) {

super(context, spanCount, orientation, reverseLayout);

}

@Override

public int getPaddingLeft() {

final int totalItemWidth = columnWidth * getSpanCount();

if (totalItemWidth >= AutofitRecyclerView.this.getMeasuredWidth()) {

return super.getPaddingLeft(); // 没做什么

} else {

return Math.round((AutofitRecyclerView.this.getMeasuredWidth() / (1f + getSpanCount())) - (totalItemWidth / (1f + getSpanCount())));

}

}

@Override

public int getPaddingRight() {

return getPaddingLeft();

}

}

}

然后,当您在AutofitRecyclerView中设置LayoutManager时,请使用CenteredGridLayoutManager,如下所示:

private void init(Context context, AttributeSet attrs) {

if (attrs != null) {

int[] attrsArray = {

android.R.attr.columnWidth

};

TypedArray array = context.obtainStyledAttributes(attrs, attrsArray);

columnWidth = array.getDimensionPixelSize(0, -1);

array.recycle();

}

manager = new CenteredGridLayoutManager(getContext(), 1);

setLayoutManager(manager);

}

就是这样!您有一个动态的跨度,基于中心的gridlayoutmanager基于recyclerview。

资料来源:陈秋琪的方岛博客

堆栈溢出

相关文章:

  • SDN第二次作业
  • android usb传输图片,关于Android接入USB外接摄像头以及控制拍照并保存图片
  • 如何将html文件放入Android,关于android:将HTML文件加载到WebView中
  • nginx3解析php
  • 荣耀8 android8.0 2018,荣耀这次很良心! 荣耀8全系可以升级安卓8.0
  • web测试方法
  • html5文字游戏制作工具,橙光文字游戏制作工具
  • MySQL timestampdiff 和 timestampadd 的用法
  • android 特殊机型问题,这四款机型十分特殊,购买需要谨慎!
  • Python可迭代对象中的添加和删除(add,append,pop,remove,insert)
  • android tabbar框架,Android 自定义tabbar 用viewPage实现
  • jdbc参数
  • Linux运维人员最常用150个命令汇总
  • html js文件调用函数,我怎么把js文件里的函数调用到html文件中,并使两个函数依次运行?...
  • [poj] 3422 Kaka's Matrix Travels || 最小费用最大流
  • [NodeJS] 关于Buffer
  • 【面试系列】之二:关于js原型
  • CSS相对定位
  • ES6 ...操作符
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • hadoop集群管理系统搭建规划说明
  • Java面向对象及其三大特征
  • js对象的深浅拷贝
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • TCP拥塞控制
  • vue-router的history模式发布配置
  • webpack项目中使用grunt监听文件变动自动打包编译
  • Zepto.js源码学习之二
  • 包装类对象
  • 从 Android Sample ApiDemos 中学习 android.animation API 的用法
  • 计算机常识 - 收藏集 - 掘金
  • 理清楚Vue的结构
  • 力扣(LeetCode)56
  • 十年未变!安全,谁之责?(下)
  • 时间复杂度与空间复杂度分析
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • (1)SpringCloud 整合Python
  • (a /b)*c的值
  • (第8天)保姆级 PL/SQL Developer 安装与配置
  • (二)pulsar安装在独立的docker中,python测试
  • (附源码)ssm教师工作量核算统计系统 毕业设计 162307
  • (四)Tiki-taka算法(TTA)求解无人机三维路径规划研究(MATLAB)
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (已解决)什么是vue导航守卫
  • (转)c++ std::pair 与 std::make
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • (轉貼) UML中文FAQ (OO) (UML)
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • **PHP二维数组遍历时同时赋值
  • .Net6使用WebSocket与前端进行通信
  • .NET牛人应该知道些什么(2):中级.NET开发人员
  • /bin/bash^M: bad interpreter: No such file or directory
  • @vue/cli 3.x+引入jQuery
  • @基于大模型的旅游路线推荐方案