android:RecyclerView交互动画(上下拖动,左右滑动删除)

这篇具有很好参考价值的文章主要介绍了android:RecyclerView交互动画(上下拖动,左右滑动删除)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

@Override

public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {

//监听侧滑;1.删除数据,2.调用adapter.notifyItemRemoved(position)

mMoveCallback.onItemRemove(viewHolder.getAdapterPosition());

}

//改变选中的Item

@Override

public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) {

//判断状态

if (actionState != ItemTouchHelper.ACTION_STATE_IDLE) {

viewHolder.itemView.findViewById(R.id.textview).setBackgroundColor(viewHolder.itemView.getContext().getResources().getColor(R.color.black));

}

super.onSelectedChanged(viewHolder, actionState);

}

//恢复改变选中的Item

@Override

public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {

//恢复

viewHolder.itemView.findViewById(R.id.textview).setBackgroundColor(viewHolder.itemView.getContext().getResources().getColor(R.color.colorPrimary));

//透明度动画

viewHolder.itemView.setAlpha(1);//1~0

//缩放动画

viewHolder.itemView.setScaleX(1);//1~0

viewHolder.itemView.setScaleY(1);//1~0

super.clearView(recyclerView, viewHolder);

}

//在拖拽的时候做效果

@Override

public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {

//dx 水平方向移动的增量(负:向左;正:向右)范围:0~View.getWidth

float alpha=1 - Math.abs(dX) / viewHolder.itemView.getWidth();

if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE) {

//透明度动画

viewHolder.itemView.setAlpha(alpha);//1~0

//缩放动画

viewHolder.itemView.setScaleX(alpha);//1~0

viewHolder.itemView.setScaleY(alpha);//1~0

}

// if (alpha==0){

// //透明度动画

// viewHolder.itemView.setAlpha(1);//1~0

// //缩放动画

// viewHolder.itemView.setScaleX(1);//1~0

// viewHolder.itemView.setScaleY(1);//1~0

// }

super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);

}

}

  • MainAdapter

import android.content.Context;

import android.support.v7.widget.RecyclerView;

import android.view.LayoutInflater;

import android.view.MotionEvent;

import android.view.View;

import android.view.ViewGroup;

import android.widget.ImageView;

import android.widget.TextView;

import java.util.Collections;

import java.util.List;

import tsou.cn.studyrecycler.R;

import tsou.cn.studyrecycler.callback.ItemTouchMoveCallback;

import tsou.cn.studyrecycler.callback.StartDragCallback;

/**

  • Created by Administrator on 2017/7/11 0011.

*/

public class MainAdapter extends RecyclerView.Adapter<MainAdapter.ViewHolder> implements ItemTouchMoveCallback {

private Context mContext;

private List mLists;

private StartDragCallback mCallback;

public MainAdapter(Context context, List lists, StartDragCallback callback) {

this.mContext = context;

this.mLists = lists;

this.mCallback = callback;

}

@Override

public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

View view = LayoutInflater.from(mContext).inflate(R.layout.item_main, parent, false);

return new ViewHolder(view);

}

@Override

public void onBindViewHolder(final ViewHolder holder, int position) {

holder.mTextview.setText(mLists.get(position));

//解决触摸移动

holder.mImageview.setOnTouchListener(new View.OnTouchListener() {

@Override

public boolean onTouch(View v, MotionEvent event) {

if (event.getAction() == MotionEvent.ACTION_DOWN) {

//传递触摸情况(触摸移动)

mCallback.onStartDrag(holder);

}

return false;

}

});

}

@Override

public boolean onItemMove(int fromPosition, int toPosition) {

//1.数据交换;2.刷新

Collections.swap(mLists, fromPosition, toPosition);

notifyItemMoved(fromPosition, toPosition);

return true;

}

@Override

public boolean onItemRemove(int position) {

//1.删除数据,2.刷新

mLists.remove(position);

notifyItemRemoved(position);

return true;

}

@Override

public int getItemCount() {

return mLists.size();

}

class ViewHolder extends RecyclerView.ViewHolder {

TextView mTextview;

ImageView mImageview;

ViewHolder(View view) {

super(view);

this.mTextview = (TextView) view.findViewById(R.id.textview);

this.mImageview = (ImageView) view.findViewById(R.id.imageview);

}

}

}

  • MainActivity

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.support.v7.widget.LinearLayoutManager;

import android.support.v7.widget.RecyclerView;

import android.support.v7.widget.helper.ItemTouchHelper;

import java.util.ArrayList;

import tsou.cn.lib_hxgioc.HxgBind;

import tsou.cn.lib_hxgioc.HxgContentView;

import tsou.cn.lib_hxgioc.HxgViewUtils;

import tsou.cn.studyrecycler.adatper.MainAdapter;

import tsou.cn.studyrecycler.callback.MyItemTouchHelperCallback;

import tsou.cn.studyrecycler.callback.StartDragCallback;

@HxgContentView(R.layout.activity_main)

public class MainActivity extends AppCompatActivity implements StartDragCallback {

@HxgBind(R.id.recyclerView)

private RecyclerView mRecyclerView;

private ArrayList list = new ArrayList<>();

private ItemTouchHelper itemTouchHelper;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

HxgViewUtils.getView().inject(this);

for (int i = 0; i < 100; i++) {

list.add(“huangxiaoguo” + i);

}

mRecyclerView.setLayoutManager(new LinearLayoutManager(this));

MainAdapter adapter = new MainAdapter(this, list, this);

mRecyclerView.setAdapter(adapter);

//条目触摸帮助类

ItemTouchHelper.Callback callback = new MyItemTouchHelperCallback(adapter);

itemTouchHelper = new ItemTouchHelper(callback);

itemTouchHelper.attachToRecyclerView(mRecyclerView);

}

/**

  • 解决触摸移动

  • @param viewHolder

*/

@Override

public void onStartDrag(RecyclerView.ViewHolder viewHolder) {

itemTouchHelper.startDrag(viewHolder);

}

}

-手指触摸上下滑动监听StartDragCallback

public interface StartDragCallback {

public void onStartDrag(RecyclerView.ViewHolder viewHolder);

}

  • 拖拽和侧滑回调 ItemTouchMoveCallback

import android.graphics.Canvas;

import android.support.v7.widget.RecyclerView;

import android.support.v7.widget.helper.ItemTouchHelper;

import tsou.cn.studyrecycler.R;

/**

  • Created by Administrator on 2018/10/11 0011.

*/

public class MyItemTouchHelperCallback extends ItemTouchHelper.Callback {

private ItemTouchMoveCallback mMoveCallback;

public MyItemTouchHelperCallback(ItemTouchMoveCallback callback) {

this.mMoveCallback = callback;

}

//Callback回调监听时先调用的,用来判断当前是什么动作,比如判断方向(监听哪个方向的拖动)

@Override

public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {

//放向:up、down、left、right

//常量:

// int up = ItemTouchHelper.UP;//1 0x0001

// int down = ItemTouchHelper.DOWN;//2 0x0010

// int left = ItemTouchHelper.LEFT;

// int right = ItemTouchHelper.RIGHT;

//要监听的拖拽方向,不监听为0

int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;

//要监听的侧滑方向,不监听为0

// int swipeFlags = 0;

int swipeFlags = ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;

int flags = makeMovementFlags(dragFlags, swipeFlags);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

android:RecyclerView交互动画(上下拖动,左右滑动删除),程序员,android,交互

【Android高级架构视频学习资源】

**Android部分精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!文章来源地址https://www.toymoban.com/news/detail-848921.html

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

频面试题**,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

[外链图片转存中…(img-xVA2aEz9-1712249208536)]

【Android高级架构视频学习资源】

**Android部分精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

到了这里,关于android:RecyclerView交互动画(上下拖动,左右滑动删除)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 解决微信小程序在IOS端会上下左右滑动的问题

    在开发微信小程序的时候发现在IOS端会出现上下左右都能滑动的情况,但是安卓端就不会出现这种情况,百度了一下好像IOS就是默认可以滑动,安卓默认不允许,本篇就这个问题解决一下,毕竟可以随意滑动视觉上不太美观 在外层的view设置overflow隐藏就好了,重新编译测试就

    2024年02月12日
    浏览(165)
  • 微信小程序、uniapp使用touchstart和touchmove左右滑动删除。以及解决上下抖动问题。

    展示效果图直接上代码 如果要修改里面内容直接从content这个类修改就行。 直接复制粘贴就行。拿上直接用。 如果遇到滑动会导致上下抖动用这个解决。给最外层得一个view标签加一个样式。 这样的话滑动会有阴影,但不会抖动,可以尝试一下看看,如果哪位能人能解决,就

    2024年02月11日
    浏览(135)
  • 微信小程序在ios端上下左右滑动以及底部滚动条的解决方案

    最近在写小程序,碰到一个非常棘手的问题,就是安卓没事,苹果手机上的页面能上下左右的滑动,不美观这里我理解为不兼容,本着有问题就去解决,苹果默认应该是滑动的,下面是解决方法 底部滚动条解决

    2024年02月04日
    浏览(136)
  • Android的RecyclerView实现列表拖动(移动顺序)交换数据位置

    1.先看效果图 这是拖动前的图片 这是拖动列表改变位置后的图片 这里放上视频演示 RecyclerView实现列表拖动交换数据位置 2.主活动MainActivity2类代码如下

    2024年02月12日
    浏览(49)
  • Android之RecyclerView仿ViewPage滑动

    我们都知道ViewPage+Fragment滑动,但是的需求里面已经有了这玩意,但是在Fragment中还要有类似功能,这时我相信很多人就苦恼了,没事,这张来解决,用RecyclerView去实现即可,而且还带指示器。 这里我没有弄GIF,反正效果和ViewPage+Fragment是一样的。 代码如下(示例): 一个是

    2024年02月09日
    浏览(43)
  • 【Element】实现基于 Element UI el-tabs 的左右滑动动画

    在构建现代 web 应用时,为用户提供平滑的动画效果是提升用户体验的关键。本篇博客将详细介绍如何在使用 Vue 以及 Element UI 时,实现一个具有左右滑动效果的 tab 切换动画。 首先,我们需要创建一个基础的 el-tabs 组件,用于展示不同的内容区域。 我们希望了解用户是向左

    2024年03月14日
    浏览(48)
  • 前端vue可以左右滚动的切换的tabs tabs选项卡 滑动动画效果 自动宽度

    前端vue可以左右滚动的切换的tabs tabs选项卡 滑动动画效果 自动宽度, 阅读全文下载完整代码请关注微信公众号: 前端组件开发 效果图如下:           #### 使用方法 ```使用方法 swiperTabList: [\\\"2023-06-10\\\",\\\"2023-06-11\\\",\\\"2023-06-12\\\",\\\"2023-06-13\\\",\\\"2023-06-14\\\",\\\"2023-06-15\\\"], //导航列表 swiperTabIdx:

    2024年02月08日
    浏览(44)
  • Android 自动滚动的RecyclerView,手动滑动和自动滑动无缝衔接,手动滑动时数据不重复

    概要 做一个自动滑动的列表,用于展示聊天记录或者通知栏信息等,还是使用主流的RecyclerView来做。网上有很多案例,但当手动滑动时会一直无限循环,数据重复的出现,如果想要自动滑动时能无限循环,手动滑动时又能滑到底呢?本案例就解决这种手动滑动和自动滑动无缝

    2024年01月23日
    浏览(48)
  • Android之解决RecyclerView与NestedScrollView的滑动冲突方法

    问题一:当我们滑动RecyclerView组件时,上方的轮播图并没有进行滑动(NestedScrollView没有滑动,即滑动事件被RecyclerView消费了), 当RecyclerView滑到底时,轮播图部分才进行滑动 。 如下图,RecyclerView已经进行了滑动,但轮播图部分没有。 整体布局 这并不符合我们的设计要求,

    2024年02月16日
    浏览(50)
  • [Android]自定义RecyclerView中View的动画

    官方有一个默认Item动画类DafaultItemAnimator,其中 DefaultItemAnimator 继承了SimpleItemAnimator 继承了 RecyclerView.ItemAnimator SimpleItemAnimator 它是一个包装类,用来判断当前的ViewHolder到底是执行移动、移除、添加或者改变等行为。 DefaultItemAnimator 是执行具体动画类,它负责将viewHolder初始化

    2024年02月11日
    浏览(64)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包