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;
    }


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值