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
原创粉丝点击