MyAdapter

package zhanghaijiao.bawei.com.async_getpic;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.assist.ImageScaleType;
import com.nostra13.universalimageloader.core.display.RoundedBitmapDisplayer;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.List;
/**
 * Created by jane on 2018/4/10.
 */
public class MyAdapter extends BaseAdapter {
    //数据源
    private List<ResultData.NewslistBean> data;
    private Context context;
    private  DisplayImageOptions imageOptions;

    //定义常量值,指示不同的类型。注意:值不能大于等于getViewTypeCount方法返回的值,否则会报数组越界的问题
    private final  int ITEM_IMG=0;
    private final  int ITEM_TITLE=1;


    //alt+insert 生成构造方法
    public MyAdapter(List<ResultData.NewslistBean> data, Context context) {
        this.data = data;
        this.context = context;
        //2.显示配置
        imageOptions= new DisplayImageOptions.Builder()
                .cacheInMemory(true)//使用内存缓存
                .cacheOnDisk(true)//使用磁盘缓存
                .showImageOnLoading(R.mipmap.ic_launcher)//设置正在下载的图片
                .showImageForEmptyUri(R.mipmap.ic_launcher)//url为空或请求的资源不存在时
                .showImageOnFail(R.mipmap.ic_launcher)//下载失败时显示的图片
                .bitmapConfig(Bitmap.Config.RGB_565)//设置图片色彩模式  1px=2个字节  ARGB_8888 1px=4个字节   ARGB_4444 1px=2个字节  ALPHA_8 1px=1个字节
                .imageScaleType(ImageScaleType.EXACTLY)//设置图片的缩放模式
                .displayer(new RoundedBitmapDisplayer(100))//设置图片的圆角 注意:控件必须要设定宽度与高度
                .build();
    }

    //得到不同类型的视图总数量
    @Override
    public int getViewTypeCount() {
        return 2;
    }
    //根据下标确定当前view的条目类型
    @Override
    public int getItemViewType(int position) {
        if(position%2==0){//偶数行
            return ITEM_IMG;
        }else{
            return ITEM_TITLE;
        }
    }
    @Override
    public int getCount() {
        return data.size();
    }
    @Override
    public Object getItem(int i) {
        return data.get(i);
    }
    @Override
    public long getItemId(int i) {
        return i;
    }
    @Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        //1.调用getItemViewType,确定当条目展示的类型,然后加载不同的布局文件
        int itemViewType = getItemViewType(i);
        if(itemViewType==ITEM_IMG){
            ViewHolder holder;
            if(view==null){
                view=View.inflate(context,R.layout.item,null);
                holder=new ViewHolder();
                holder.tvTitle=view.findViewById(R.id.tv_title);
                holder.tvDesc=view.findViewById(R.id.tv_description);
                holder.imageView=view.findViewById(R.id.img);
                view.setTag(holder);
            }else {
                holder= (ViewHolder) view.getTag();
            }
            holder.tvTitle.setText(data.get(i).getTitle());
            holder.tvDesc.setText(data.get(i).getDescription());
            //开启异步任务,去下载图片
            if(data.get(i).getPicUrl()!=null && data.get(i).getPicUrl().length()>0){
                ImageLoader.getInstance().displayImage(data.get(i).getPicUrl(),holder.imageView,imageOptions);
            }else{
                holder.imageView.setImageResource(R.mipmap.ic_launcher);
            }
            return view;

        }else {
            ViewHolder1 viewHolder1;
            if(view==null){
                viewHolder1=new ViewHolder1();
                view=View.inflate(context,R.layout.item1,null);
                viewHolder1.tv1=view.findViewById(R.id.tv_title);
                view.setTag(viewHolder1);
            }else {
                viewHolder1= (ViewHolder1) view.getTag();
            }
            viewHolder1.tv1.setText(data.get(i).getTitle());
            return  view;

        }



    }
    class ViewHolder{
        TextView tvTitle;
        TextView tvDesc;
        ImageView imageView;
    }
    class ViewHolder1{
        TextView tv1;
    }


}
MyAdapter 是一个自定义的适配器类,用于将数据源绑定到RecyclerView上。它需要继承自RecyclerView.Adapter类,并实现其中的三个方法:onCreateViewHolder、onBindViewHolder和getItemCount。 其中,onCreateViewHolder 方法用于创建ViewHolder实例,该方法需要返回一个继承自RecyclerView.ViewHolder的实例,该实例需要通过LayoutInflater将布局文件转换成View,并传入ViewHolder中。 onBindViewHolder 方法用于绑定ViewHolder和数据源,该方法需要将数据源中的数据绑定到ViewHolder的对应控件上。 getItemCount 方法用于返回数据源的大小,即RecyclerView中包含的列表项数。 下面是一个简单的MyAdapter类的示例代码: ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mDataList; public MyAdapter(List<String> dataList) { mDataList = dataList; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { holder.mTextView.setText(mDataList.get(position)); } @Override public int getItemCount() { return mDataList.size(); } static class ViewHolder extends RecyclerView.ViewHolder { TextView mTextView; ViewHolder(@NonNull View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } } } ``` 在上述代码中,我们假设item_layout是RecyclerView列表项的布局文件,其中包含一个id为text_view的TextView控件,用于显示列表项的数据。MyAdapter类的构造函数中需要传入一个List<String>类型的数据源,并将其赋值给成员变量mDataList。在onCreateViewHolder方法中,我们通过LayoutInflater将item_layout布局文件转换成View,并传入ViewHolder中。在onBindViewHolder方法中,我们将数据源中对应位置的数据绑定到ViewHolder的mTextView控件上。在getItemCount方法中,我们返回数据源的大小,即RecyclerView列表项的数量。最后,我们定义了一个ViewHolder内部类,用于持有列表项中的控件实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值