在我们很多项目中,一般列表页面的展示都用到了ListView或者是RecyclerView(其实一般现在的APP主页都是用RecyclerView了,它能完美的实现多布局),那么有时候会有滑到指定位置的需求,最常见的需求就是回到顶部操作。今天就给大家简单的介绍一下,如何用recyclerview实现这种操作,有的人就会提出,recyclerview自己就提供了方法能为我们实现,recycle.smoothScrollToPosition(position)这个方法就能实现,其实不然,这里边有个不大不小的坑,且听我为大家慢慢道来。
recycle.smoothScrollToPosition(position)这个方法是能自动滑动到指定位置(即position),因为它是平滑的滑动过去的,不会给用户一种突兀的感觉,所以大家都爱用。
在我们使用过程中,只要传入想要滑动到的位置就可以了。但是在实际中,如果我们传入的position是大于屏幕中第一个可见的itemView位置时,也就是从上往下滑动的时候,我们发现他只能将我们想要的View展示在屏幕最底部,但是我们想要的效果往往是将其滑动到顶部。所以我们需要进行判断,当想滑动到位置position(下文position都代表想要滑到的位置)小于当前第一个可见itemView时候,我们直接调用recycle.smoothScrollToPosition(position)方法,这是没有问题的,但是当其大于的时候,我们就需要对其进行处理。我们先调用recycle.smoothScrollToPosition(position)方法,现将想要滑动到的位置给显示出来,然后再计算它离顶部还有多少距离,然后调用recycle.smoothScrollBy(0,top)这个方法使其滑动到想要的位置,那么到底是如何操作的呢?直接上代码:
int firstItem=grid.findFirstVisibleItemPosition();
if(50<firstItem){
recycle.smoothScrollToPosition(50);//直接调用没有任何问题
}else{
recycle.smoothScrollToPosition(50);
readyMove=true;//是否准备好二次滑动
moving=true;//是否处于滑动状态
}
,上面的代码中我们进行了判断,但是我们能够看到在大于的时候,我们也是直接调用了该方法,并且将两个标识符都设置成了true,接下还有处理,还是直接上代码:
recycle.addOnScrollListener(newRecyclerView.OnScrollListener() {
@Override
public voidonScrollStateChanged(RecyclerView recyclerView, intnewState) {
super.onScrollStateChanged(recyclerView,newState);
if(newState==RecyclerView.SCROLL_STATE_IDLE){
moving=false;
}
if(moving==false&&readyMove==true){
int firstItem=grid.findFirstVisibleItemPosition();
int top =recycle.getChildAt(50- firstItem).getTop();
recycle.smoothScrollBy(0,top);
moving=true;
readyMove=false;
}
}
@Override
public voidonScrolled(RecyclerView recyclerView, intdx, intdy) {
super.onScrolled(recyclerView,dx,dy);
}
});
上边我们可以看到,在recyclerview的滑动监听中,我们也进行了处理,只有在第一次滑动完了并且好准备好第二次滑动后,我们才开始进行第二次滑动,首先先计算离顶部的高度,
int firstItem=grid.findFirstVisibleItemPosition();
int top =recycle.getChildAt(50- firstItem).getTop();
其实recycle.getChildAt(position)这个方法也有坑的,当传入position大于屏幕显示itemView的最大数量的时候这个方法会报空指针异常,所以我们在使用的时候需要将position减去firstItem,这样才能避免爆出空指针错误。
这样我们就实现recyclerview滑到指定位置的功能啦~
第一次自己写文章,文中有不对的地方欢迎大家指正,有更好的解决办法也欢迎讨论,希望大家能共同进步!