Android StaggeredGridLayoutManager布局RecyclerView在滚动状态可见范围刷新数据
Android StaggeredGridLayoutManager布局RecyclerView在滚动状态可见范围刷新数据
之所以把StaggeredGridLayoutManager布局的RecyclerView单列出来处理滚动状态下可见(可视)范围内的数据更新问题,是因为在StaggeredGridLayoutManager布局下的RecyclerView,对于第一个可视item和最后一个可视item,即第一个可视item位置和最后一个可视item位置,不像在LinearLayoutManager布局下直接获取,需要进行一个简单计算。关键的计算过程我写在了getOutRange()方法内。
package zhangphil.recyclerview; import android.graphics.Color; import android.os.Bundle; import android.support.annotation.NonNull; import android.support.annotation.Nullable; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.RecyclerView; import android.support.v7.widget.StaggeredGridLayoutManager; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView; import java.util.ArrayList; import java.util.Arrays; public class RecyclerViewActivity extends AppCompatActivity { private RecyclerView mRecyclerView; private RecyclerViewAdapter mAdapter; private StaggeredGridLayoutManager layoutManager; private ArrayList<String> mItems; @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.recycler_view_activity); mItems = new ArrayList<>(); for (int i = 0; i < 110; i++) { mItems.add(i + ""); } initRecyclerView(); mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); if (recyclerView.getScrollState() == RecyclerView.SCROLL_STATE_IDLE) { int[] outRange = getOutRange(); int len = outRange[1] - outRange[0] + 1; int num = (int) (Math.random() * 10); for (int i = 0; i < len; i++) { mItems.set(outRange[0] + i, num + ""); } mAdapter.notifyDataSetChanged(); } } }); } private int[] getOutRange() { int[] range = new int[2]; int[] first = new int[layoutManager.getSpanCount()]; layoutManager.findFirstVisibleItemPositions(first); int[] last = new int[layoutManager.getSpanCount()]; layoutManager.findLastVisibleItemPositions(last); range[0] = first[0]; Arrays.sort(last); range[1] = last[last.length - 1]; return range; } private void initRecyclerView() { mRecyclerView = findViewById(R.id.recycler_view); layoutManager = new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL); mRecyclerView.setLayoutManager(layoutManager); mAdapter = new RecyclerViewAdapter(); mRecyclerView.setAdapter(mAdapter); } private class RecyclerViewAdapter extends RecyclerView.Adapter<MyVH> { @NonNull @Override public MyVH onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(getApplicationContext()).inflate(android.R.layout.simple_list_item_2, parent, false); return new MyVH(view); } @Override public void onBindViewHolder(@NonNull MyVH holder, int position) { holder.text1.setText("" + position); holder.text2.setText(mItems.get(position)); } @Override public int getItemCount() { return mItems.size(); } } private class MyVH extends RecyclerView.ViewHolder { public TextView text1; public TextView text2; public MyVH(View itemView) { super(itemView); text1 = itemView.findViewById(android.R.id.text1); text1.setTextColor(Color.WHITE); text1.setBackgroundColor(Color.RED); text2 = itemView.findViewById(android.R.id.text2); text2.setTextColor(Color.DKGRAY); } } }
代码实现一个简单意图,用StaggeredGridLayoutManager控制RecyclerView,当RecyclerView滚动停止后,更新可可范围内的数据到最新。
如图:
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android Studio3.0新的依赖指令
前言 Android studio 版本更新至3.0,同时也出现了两个新的依赖指令:implement 和api。 在com.android.tools.build:gradle 3.0 以下版本依赖在gradle 中的声明写法: compile fileTree(dir: 'libs', include: ['*.jar']) 3.0后的写法为 implementation fileTree(dir: 'libs', include: ['*.jar']) 或 api fileTree(dir: 'libs', include: ['*.jar']) 新增两个指令的区别 api 指令完全等同于compile指令,没区别 implement指令的特点是,对于使用了该命令编译的依赖,对该项目有依赖的项目将无法访问到使用该命令编译的依赖中的任何程序,也就是将该依赖隐藏在内部,而不对外部公开。 图片解释 用api指令编译,Glide依赖对app Module 是可见的 image 用implement指令编译依赖对app Module 是不可见的 image 建议 在Google IO 相关...
- 下一篇
javah生成头文件
编写native方法,如: package com.example.renzhenming.appmarket.ui.selectimage; import android.graphics.Bitmap; public class ImageUtil { static { System.loadLibrary("jpeg"); System.loadLibrary("compressimg"); } /** * 图片压缩 * @param quality 压缩的质量 * @param fileName 压缩后的路径 */ public static void compressImage(Bitmap bitmap,int quality, String fileName){ compressBitmap(bitmap,quality,fileName); } /** * NDK方法加载图片 * @param quality 压缩的质量 * @param fileName 压缩后的路径 * @return */ public native static int compressBitm...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2全家桶,快速入门学习开发网站教程
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- MySQL8.0.19开启GTID主从同步CentOS8