android多个图片滑动切换效果,Android中实现类似探探中图片左右滑动切换效果

本文介绍了如何在Android中实现类似探探应用的图片左右滑动切换效果,主要利用RecyclerView和自定义LayoutManager。通过创建CardLayoutManager并实现关键方法,设置触摸监听器,以及使用ItemTouchHelper处理滑动事件,从而达到卡片式图片滑动的效果。
摘要由CSDN通过智能技术生成

原标题:Android中实现类似探探中图片左右滑动切换效果

偶然之间发现探探的左右滑动的图片挺好玩,试着去做了下,再到后来,看到许多大神也推出了同样仿探探效果的博客,从头到尾阅读下来,写得通俗易懂,基本上没什么问题。于是,实现仿探探效果的想法再次出现在脑海中。那么,还犹豫什么,趁热来一发吧!就这么愉快地决定了。

RecyclerView 是最佳选择!

RecyclerView 是最佳选择!

RecyclerView 是最佳选择!

重要的话讲三遍!!!

究其原因,第一,RecyclerView 是自带 Item View 回收和重用功能的,就不需要我们考虑这个问题了;第二,RecyclerView 的布局方式是通过设置 LayoutManager 来实现的,这样就充分地把布局和 RecyclerView “解耦”开来了。而 LayoutManager 是可以通过自定义的方式来实现的。这恰恰是我们想要的!!!再说一点,这也正是不选用 ListView 的原因之一。

5b5689ff5e20502c3216527b7fcfb764.gif

下面,我们就开始动手了。带你见证奇迹的时刻。

1.创建 CardLayoutManager 并继承自 RecyclerView.LayoutManager 。需要我们自己实现 generateDefaultLayoutParams() 方法:

@OverridepublicRecyclerView. LayoutParams generateDefaultLayoutParams(){

returnnewRecyclerView.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT);}

2.一般情况下,像上面这样写即可。

下面这个方法就是我们的重点了。 onLayoutChildren(final RecyclerView.Recycler recycler, RecyclerView.State state) 方法就是用来实现 Item View 布局的:

@OverridepublicvoidonLayoutChildren(RecyclerView.Recycler recycler, RecyclerView.State state){

super.onLayoutChildren(recycler, state); removeAllViews(); detachAndScrapAttachedViews(recycler);

intitemCount = getItemCount();

if(itemCount>CardConfig.DEFAULT_SHOW_ITEM){

for( intposition = CardConfig.DEFAULT_SHOW_ITEM;position>= 0;position--){

finalView view = recycler.getViewForPosition(position); addView(view); measureChildWithMargins(view, 0, 0);

intwidthSpace = getWidth() -getDecoratedMeasuredWidth(view);

intheightSpace = getHeight() - getBottomDecorationHeight(view); layoutDecoratedWithMargins(view,widthSpace/ 2,heightSpace/ 2,widthSpace/ 2+getDecoratedMeasuredWidth(view),heightSpace/ 2+getBottomDecorationHeight(view));

if(position == CardConfig.DEFAULT_SHOW_ITEM){ view.setScaleX( 1-(position- 1)*CardConfig.DEFAULT_SCALE); view.setScaleY( 1-(position- 1)*CardConfig.DEFAULT_SCALE); view.setTranslationY((position- 1)*view.getMeasuredHeight()/CardConfig.DEFAULT_TRANSLATE_Y); } elseif(position>0){ view.setScaleX( 1- position * CardConfig.DEFAULT_SCALE); view.setScaleY( 1- position * CardConfig.DEFAULT_SCALE); view.setTranslationY(position * view.getMeasuredHeight() / CardConfig.DEFAULT_TRANSLATE_Y); } else{ view.setOnTouchListener(mOnTouchListener); } } } else{

// 当数据源个数小于或等于最大显示数时for( intposition = itemCount - 1; position >= 0; position--) {

finalView view = recycler.getViewForPosition(position); addView(view); measureChildWithMargins(view, 0, 0);

intwidthSpace = getWidth() - getDecoratedMeasuredWidth(view);

intheightSpace = getHeight() - getDecoratedMeasuredHeight(view);

// recyclerview 布局layoutDecoratedWithMargins(view, widthSpace / 2, heightSpace / 2, widthSpace / 2+ getDecoratedMeasuredWidth(view), heightSpace / 2+ getDecoratedMeasuredHeight(view));

if(position > 0) { view.setScaleX( 1- position * CardConfig.DEFAULT_SCALE); view.setScaleY( 1- position * CardConfig.DEFAULT_SCALE); view.setTranslationY(position * view.getMeasuredHeight() / CardConfig.DEFAULT_TRANSLATE_Y); } else{ view.setOnTouchListener(mOnTouchListener); } } }}

3.创建onTouchListener

privateView.OnTouchListener mOnTouchListener = newView.OnTouchListener() {

@OverridepublicbooleanonTouch(View v, MotionEvent event){ RecyclerView.ViewHolder childViewHolder = mRecyclerView.getChildViewHolder(v);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值