RecyclerView实现Item滑动加载进入动画效果
来源:互联网 发布:软件授权方法 编辑:程序博客网 时间:2024/05/21 01:42
如果是使用ListView的话我们知道,可以很简单的实现加载的动画,但是使用android.support.v7.widget.RecyclerView 的话,暂时还不是很多,所以自己就实现了一个效果,先看图吧(第一次上传动态图片,不喜勿喷哦)
图片有点模糊,但是能看到效果,那就是下面进入会有一个延迟的效果,下面看看代码吧;
这是一个自定义的,能够上拉加载更多的RecyclerView
package com.socks.jiandan.view;import android.content.Context;import android.support.v7.widget.LinearLayoutManager;import android.support.v7.widget.RecyclerView;import android.util.AttributeSet;import com.meyhuan.mytest.LoadFinishCallBack;import com.nostra13.universalimageloader.core.ImageLoader;/** * Created by meyhuan 15/4/9. */public class AutoLoadRecyclerView extends RecyclerView implements LoadFinishCallBack {private onLoadMoreListener loadMoreListener;private boolean isLoadingMore;public AutoLoadRecyclerView(Context context) {this(context, null);}public AutoLoadRecyclerView(Context context, AttributeSet attrs) {this(context, attrs, 0);}public AutoLoadRecyclerView(Context context, AttributeSet attrs, int defStyle) {super(context, attrs, defStyle);isLoadingMore = false;setOnScrollListener(new AutoLoadScrollListener(null, true, true));}/** * 如果需要显示图片,需要设置这几个参数,快速滑动时,暂停图片加载 * * @param imageLoader * @param pauseOnScroll * @param pauseOnFling */public void setOnPauseListenerParams(ImageLoader imageLoader, boolean pauseOnScroll, boolean pauseOnFling) {setOnScrollListener(new AutoLoadScrollListener(imageLoader, pauseOnScroll, pauseOnFling));}public void setLoadMoreListener(onLoadMoreListener loadMoreListener) {this.loadMoreListener = loadMoreListener;}@Overridepublic void loadFinish(Object obj) {isLoadingMore = false;}public interface onLoadMoreListener {void loadMore();}/** * 滑动自动加载监听器 */private class AutoLoadScrollListener extends OnScrollListener {private ImageLoader imageLoader;private final boolean pauseOnScroll;private final boolean pauseOnFling;public AutoLoadScrollListener(ImageLoader imageLoader, boolean pauseOnScroll, boolean pauseOnFling) {super();this.pauseOnScroll = pauseOnScroll;this.pauseOnFling = pauseOnFling;this.imageLoader = imageLoader;}@Overridepublic void onScrolled(RecyclerView recyclerView, int dx, int dy) {super.onScrolled(recyclerView, dx, dy);//由于GridLayoutManager是LinearLayoutManager子类,所以也适用if (getLayoutManager() instanceof LinearLayoutManager) {int lastVisibleItem = ((LinearLayoutManager) getLayoutManager()).findLastVisibleItemPosition();int totalItemCount = AutoLoadRecyclerView.this.getAdapter().getItemCount();//有回调接口,并且不是加载状态,并且剩下2个item,并且向下滑动,则自动加载if (loadMoreListener != null && !isLoadingMore && lastVisibleItem >= totalItemCount -2 && dy > 0) {loadMoreListener.loadMore();isLoadingMore = true;}}}@Overridepublic void onScrollStateChanged(RecyclerView recyclerView, int newState) {if (imageLoader != null) {switch (newState) {case 0:imageLoader.resume();break;case 1:if (pauseOnScroll) {imageLoader.pause();} else {imageLoader.resume();}break;case 2:if (pauseOnFling) {imageLoader.pause();} else {imageLoader.resume();}break;}}}}}
这是主Activity
package com.meyhuan.mytest;import android.content.Intent;import android.content.SharedPreferences;import android.graphics.Bitmap;import android.preference.PreferenceManager;import android.support.v4.widget.SwipeRefreshLayout;import android.support.v7.app.ActionBarActivity;import android.os.Bundle;import android.support.v7.widget.DefaultItemAnimator;import android.support.v7.widget.LinearLayoutManager;import android.support.v7.widget.RecyclerView;import android.util.Log;import android.view.LayoutInflater;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.ViewGroup;import android.view.animation.Animation;import android.view.animation.AnimationUtils;import android.widget.ImageView;import android.widget.LinearLayout;import android.widget.TextView;import com.lidroid.xutils.BitmapUtils;import com.lidroid.xutils.HttpUtils;import com.lidroid.xutils.exception.HttpException;import com.lidroid.xutils.http.ResponseInfo;import com.lidroid.xutils.http.callback.RequestCallBack;import com.lidroid.xutils.http.client.HttpRequest;import com.nostra13.universalimageloader.core.DisplayImageOptions;import com.nostra13.universalimageloader.core.ImageLoader;import java.util.ArrayList;public class MainActivity extends ActionBarActivity { com.socks.jiandan.view.AutoLoadRecyclerView mRecyclerView; SwipeRefreshLayout mSwipeRefreshLayout; private FreshNewsAdapter mAdapter; private LoadFinishCallBack mLoadFinisCallBack; private ImageLoader imageLoader; private DisplayImageOptions options; HttpUtils httpUtils = new HttpUtils(); BitmapUtils bitmapUtils ; //是否是大图模式 private static boolean isLargeMode = false; private int index =1; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bitmapUtils = new BitmapUtils(this); mRecyclerView = (com.socks.jiandan.view.AutoLoadRecyclerView) findViewById(R.id.recycler_view); mSwipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipeRefreshLayout); mRecyclerView.setHasFixedSize(false); mRecyclerView.setItemAnimator(new DefaultItemAnimator()); mLoadFinisCallBack = mRecyclerView; mRecyclerView.setLoadMoreListener(new com.socks.jiandan.view.AutoLoadRecyclerView.onLoadMoreListener() { @Override public void loadMore() { mAdapter.loadNextPage(); } }); mSwipeRefreshLayout.setColorSchemeResources(android.R.color.holo_blue_bright, android.R.color.holo_green_light, android.R.color.holo_orange_light, android.R.color.holo_red_light); mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { mAdapter.loadFirst(); } }); mRecyclerView.setLayoutManager(new LinearLayoutManager(this)); imageLoader = ImageLoader.getInstance();// mRecyclerView.setOnPauseListenerParams(imageLoader, false, true);// SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(getActivity());// isLargeMode = sp.getBoolean(SettingFragment.ENABLE_FRESH_BIG, true); int loadingResource; //大图模式 if (isLargeMode) { loadingResource = R.drawable.ic_loading_large; } else { loadingResource = R.drawable.ic_loading_small; } options = new DisplayImageOptions.Builder() .cacheInMemory(true) .cacheOnDisk(true) .bitmapConfig(Bitmap.Config.RGB_565) .resetViewBeforeLoading(true) .showImageOnLoading(loadingResource) .build(); mAdapter = new FreshNewsAdapter(); mRecyclerView.setAdapter(mAdapter); mAdapter.loadFirst(); } /** * 新鲜事适配器 */ public class FreshNewsAdapter extends RecyclerView.Adapter<ViewHolder> {// private int page; private ArrayList<Goods> freshNewses; private int lastPosition = -1; public FreshNewsAdapter(ArrayList<Goods> freshNewses) { this.freshNewses = freshNewses; } public FreshNewsAdapter() { freshNewses = new ArrayList<Goods>(); } private void setAnimation(View viewToAnimate, int position) { if (position > lastPosition) { Animation animation = AnimationUtils.loadAnimation(viewToAnimate.getContext(), R .anim.item_bottom_in); viewToAnimate.startAnimation(animation); lastPosition = position; } } @Override public void onViewDetachedFromWindow(ViewHolder holder) { super.onViewDetachedFromWindow(holder); holder.ll_content.clearAnimation(); } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { int layoutId; Log.e("Tag", "onCreateViewHolder"); layoutId = R.layout.main_fragment_list_item; View v = LayoutInflater.from(parent.getContext()) .inflate(layoutId, parent, false); return new ViewHolder(v); } @Override public void onBindViewHolder(final ViewHolder holder, final int position) { if(freshNewses != null && freshNewses.size() > 0){ Goods freshNews = freshNewses.get(position);// imageLoader.displayImage(freshNews.getImageUrl(), holder.img, options); bitmapUtils.display( holder.img,freshNews.getImageUrl()); holder.tv_title.setText(freshNews.getAddress()); holder.tv_info.setText(freshNews.getPrice() + "@" ); setAnimation(holder.ll_content, position); } } @Override public int getItemCount() { return freshNewses.size(); } public void loadFirst() { index = 1; loadData(); } public void loadNextPage() { index++; loadData(); } } public static class ViewHolder extends RecyclerView.ViewHolder { private TextView tv_title; private TextView tv_info; private TextView tv_views; private TextView tv_share; private ImageView img; private LinearLayout ll_content; public ViewHolder(View contentView) { super(contentView); tv_title = (TextView) contentView.findViewById(R.id.main_fragment_item_text1); tv_info = (TextView) contentView.findViewById(R.id.main_fragment_item_text2); tv_views = (TextView) contentView.findViewById(R.id.main_fragment_item_text3); img = (ImageView) contentView.findViewById(R.id.main_fragment_item_imageView); ll_content = (LinearLayout) contentView.findViewById(R.id.main_fragment_item_layout); } } private void loadData() { httpUtils.send(HttpRequest.HttpMethod.GET, Goods.URL_FRESH_NEWS + index, new RequestCallBack<String>() { @Override public void onSuccess(ResponseInfo<String> responseInfo) { ArrayList<Goods> freshNewses = Goods.parse(responseInfo.result); if (1 == index) { mAdapter.freshNewses.clear(); mAdapter.freshNewses.addAll(freshNewses); } else { mAdapter.freshNewses.addAll(freshNewses); } mAdapter.notifyDataSetChanged(); if (mSwipeRefreshLayout.isRefreshing()) { mSwipeRefreshLayout.setRefreshing(false); } mLoadFinisCallBack.loadFinish(null); } @Override public void onFailure(HttpException e, String s) { } }); }}代码使用到了xUtils开源框架,关键是在FreshNewsAdapter,的
@Override public void onViewDetachedFromWindow(ViewHolder holder) { super.onViewDetachedFromWindow(holder); holder.ll_content.clearAnimation(); }方法里面要做这样的一步操作,也就是当View滑出屏幕的时候,要取消它的动画
<span style="font-size:18px;color:#ff0000;">holder.ll_content.clearAnimation();</span>
<span style="font-size:18px;color:#ff0000;"></span>
不然会有卡顿的现象,之前为了这个,搞了很久,参考人家的代码后,现在终于正常了。
这里不多说了,想深入的了解,那就下载代码去吧。
点击下载源码
1 1
- RecyclerView实现Item滑动加载进入动画效果
- RecyclerView实现Item滑动加载进入动画效果
- 打造酷炫RecyclerView 进入 item动画效果
- RecyclerView Item加载动画
- recyclerview item的进入动画
- Android中RecyclerView的item实现动画的效果
- Android中RecyclerView的item运用覆盖view的方法实现item的动画效果
- 依次加载listview的每一个item实现动画的效果
- listview如何加载动画,实现每个item都有效果
- recyclerview 实现卡片滑动效果
- 联动滑动效果及不同Item效果的RecyclerView
- 利用RecyclerView实现的一个动画给变item的位置和左右滑动删除该RcyclervView的Item条目
- RecyclerView 实现item点击水波纹动画
- 自定义控件-实现ListView Item进入动画
- ViewPager滑动动画效果实现
- 仿探探的卡片滑动效果-recyclerView实现
- recyclerView实现左右滑动的效果
- ListView及GridView item以特殊动画效果进入屏幕
- CentOS 6.6 Minimal设置VirtualBox的共享文件夹
- Mat - 基本图像容器
- 编译、链接和加载
- weblogic获取客户端真实IP方法
- git submodule的使用
- RecyclerView实现Item滑动加载进入动画效果
- 21分钟 MySQL 入门教程
- 笔记-mysql 过程和触发器
- rman 恢复数据错误案例--ORA-19573 错误
- 参数传递多个SEL选择器
- maven创建spring项目之后,启动报错java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoade
- 让一个端口同时做两件事:http/https和ssh
- 【BZOJ2827】千山鸟飞绝 离散化+splay
- 在创建表时,在表的前面加上#表示临时表