RecyclerView的使用和优化

1.RecyclerView的使用:

mRecyclerView = (RecyclerView)findViewById(R.id.recyclerView);
	// 设置成水平方向,2列.比起Listview来讲,非常方便	
	mRecyclerView.setLayoutManager(new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.HORIZONTAL));
	//设置adapter
	mRecyclerView.setAdapter(adapter)
	//设置Item增加、移除动画
	mRecyclerView.setItemAnimator(new DefaultItemAnimator());
	//RecycleView 增加边距
	int spacingInPixels = 43;
	mRecyclerView.addItemDecoration(new SpacesItemDecorationLarge(spacingInPixels));


2.自定义点击事件:

1>adapter中:

public static interface OnRecyclerViewItemClickListener {
	//自定义接口,设置参数,如有需要可把位置设置进去
    void onItemClick(View view);
}

private OnRecyclerViewItemClickListener mOnItemClickListener = null;

public void setOnItemClickListener(OnRecyclerViewItemClickListener listener) {
    mOnItemClickListener = listener;
}

       2>在onCreateViewHolder中,设置点击事件:

//将创建的View注册点击事件
        view.setOnClickListener(this);
        return new ViewHolder(view) ;


3>在onclick中:设置未实现的方法

@Override
    public void onClick(View v) {
        if (mOnItemClickListener != null) {

            mOnItemClickListener.onItemClick(v);
        }

    }



优化:

//第一步 Adapter自定义的Adapter
   public static class ViewHolder extends RecyclerView.ViewHolder {
        RelativeLayout layout_close;
        RelativeLayout layout_open;
        TextView       how_much_num;
}
// 构造函数中,找到控件
public ViewHolder(View view) {
            super(view);
            layout_close = (RelativeLayout) view.findViewById(R.id.reLayout_close);
            layout_open = (RelativeLayout) view.findViewById(R.id.relayout_open);
            how_much_num = (TextView) view.findViewById(R.id.how_much_num);
}

//在onBindViewHolder中设置控件
 	holder.how_much_num.setText(luckMoney.getGiftNum());
          holder.tv1_open.setText(luckMoney.getExecutionName());





RecyclerView 加载图片时,存在一些优化的方法和技巧,以提升用户体验和性能方面的需求。 1. 图片压缩:在加载图片前,可以对图片进行压缩处理,减小图片的大小。可以使用图片处理库,如Glide、Picasso等,在加载图片时进行压缩处理。 2. 图片缓存:图片缓存可以减少网络请求,提高加载速度和用户体验。可以使用内存缓存和磁盘缓存,通过缓存已加载的图片,避免重复下载。 3. 图片懒加载:RecyclerView 在滑动过程中,可能会加载大量的图片,导致卡顿和性能下降。可以通过图片懒加载的方式,只在用户停止滑动时加载可见区域的图片,提升性能。 4. 使用合适的图片尺寸:为了减小图片的大小和加载时间,可以根据不同的屏幕密度和展示大小,选择合适的图片尺寸进行加载。可以通过定义多套资源文件,使用不同的图片尺寸。 5. 预加载:可以预先加载接下来的一些图片,以提前获取图片资源,减少加载等待时间。 6. 延迟加载:可以延迟加载图片,等待RecyclerView停止滑动后再加载,避免一次性加载过多的图片。可以通过监听RecyclerView的滑动状态和位置,判断何时加载图片。 7. 使用网络库:选择合适的网络请求库,如OkHttp、Retrofit等,可以提供更快速度、更稳定的网络请求,提高图片加载速度和用户体验。 8. 图片优化:在图片加载之前,可以对图片进行优化处理,如压缩图片、加密等操作,以减小图片大小和加快加载速度。 通过以上的优化方法和技巧,可以提高RecycleView加载图片的效率和用户体验,减少资源占用和流量消耗。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值