实现根据图片数量不同的多条目加载

例题:实现根据图片数量不同的多条目加载

 

在开始之前记得导jsr包(gson)和(universalimageloader)

加权限:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

 
布局:
<ListView
    android:id="@+id/list_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>
======================================================================
主要代码:(MainActivity)
listView = (ListView) findViewById(R.id.list_view);
    //首先判断是否连接网络
    boolean result=NetStateUtil.isConn(this);
    if(result){
        //进行网络请求
        MyTask myTask=new MyTask();
        myTask.execute("http://v.juhe.cn/toutiao/index?type=top&key=444da40ec8ee43818073d7131c2ffa8f");
    }else{
        //跳转到设置页面
        NetStateUtil.openDg(this);
    }
}
class MyTask extends AsyncTask<String,Void,String> {
    @Override
    protected String doInBackground(String... strings) {
        StringBuilder builder=new StringBuilder();
        //1.根据url创建URL
        try {
            URL url=new URL(strings[0]);
            //2.打开连接
            HttpURLConnection conn =(HttpURLConnection) url.openConnection();
            //3.设置
            conn.setRequestMethod("GET");
            conn.setConnectTimeout(5000);
            conn.setReadTimeout(5000);
            //4.判断结果码
            if(conn.getResponseCode()==200){
                //5.获取数据
                InputStream inputStream = conn.getInputStream();
                BufferedReader reader=new BufferedReader(new InputStreamReader(inputStream));
                String str;
                while ((str=reader.readLine())!=null){
                    builder.append(str);
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        Log.d("zzz",builder.toString());
        return builder.toString();
    }
    //async 执行完 doinbackground..后 马上来执行onPostExecute方法
    @Override
    protected void onPostExecute(String s) {
        Gson gson=new Gson();
        Result result = gson.fromJson(s, Result.class);
        //更新listview
        MyAdapter adapter=new MyAdapter(MainActivity.this,result.getResult().getData());
        listView.setAdapter(adapter);
    }
=========================================================
Result解析类
public class Result {
ALT+S(GsonFormat)json解析
}
=============================================================
NetStateUtil类:
class NetStateUtil {
    public static boolean isConn(Context context){
        ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
        NetworkInfo info = (NetworkInfo) manager.getActiveNetworkInfo();
        if(info!=null && info.isAvailable()){
            return  true;
        }
        return false;
    }
    public  static void openDg(final Context context){
        AlertDialog.Builder builder=new AlertDialog.Builder(context);
        builder.setMessage("是否要进行网络连接设置?");
        builder.setPositiveButton("设置", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialogInterface, int i) {
                Intent intent=null;
                //判断手机系统的版本  即API大于10 就是3.0或以上版本
                if(android.os.Build.VERSION.SDK_INT>10){
                    intent = new Intent(android.provider.Settings.ACTION_WIRELESS_SETTINGS);
                }else{
                    intent = new Intent();
                    ComponentName component = new ComponentName("com.android.settings","com.android.settings.WirelessSettings");
                    intent.setComponent(component);
                    intent.setAction("android.intent.action.VIEW");
                }
                context.startActivity(intent);
            }
        });
        builder.setNegativeButton("取消", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialogInterface, int i) {
            }
        });
        builder.create().show();
    }
}
========================================================
MyAdapter适配器类
class MyAdapter extends BaseAdapter{
    private Context context;
    private List<Result.ResultBean.DataBean> datas;
    private DisplayImageOptions options;
    public MyAdapter(Context context, List<Result.ResultBean.DataBean> datas) {
        this.context = context;
        this.datas = datas;
        options=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)//设置图片色彩模式
                .imageScaleType(ImageScaleType.EXACTLY)//设置图片的缩放模式
                .build();
    }
    //定义三种类型
    private final int THREE_IMAGE=0;
    private final int TWO_IMAGE=1;
    private final int ONE_IMAGE=2;
    @Override
    public int getCount() {
        return datas.size();
    }
    @Override
    public Object getItem(int i) {
        return null;
    }
    @Override
    public long getItemId(int i) {
        return 0;
    }
    @Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        //得到当前条目对应的类型
        int type = getItemViewType(i);
        if(type==THREE_IMAGE){
            ViewHolder3 viewHolder3;
            if(view==null){
                view=View.inflate(context,R.layout.item_three_image,null);
                viewHolder3=new ViewHolder3();
                viewHolder3.textView=view.findViewById(R.id.tv_title);
                viewHolder3.img1=view.findViewById(R.id.img1);
                viewHolder3.img2=view.findViewById(R.id.img2);
                viewHolder3.img3=view.findViewById(R.id.img3);
                view.setTag(viewHolder3);
            }else{
                viewHolder3=(ViewHolder3) view.getTag();
            }
            viewHolder3.textView.setText(datas.get(i).getTitle());
            //下载图片
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s(),viewHolder3.img1,options);
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s02(),viewHolder3.img2,options);
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s03(),viewHolder3.img3,options);
            return  view;
        }else if(type==TWO_IMAGE){
            ViewHolder2 viewHolder2;
            if(view==null){
                view=View.inflate(context,R.layout.item_two_image,null);
                viewHolder2=new ViewHolder2();
                viewHolder2.textView=view.findViewById(R.id.tv_title);
                viewHolder2.img1=view.findViewById(R.id.img1);
                viewHolder2.img2=view.findViewById(R.id.img2);
                view.setTag(viewHolder2);
            }else{
                viewHolder2=(ViewHolder2) view.getTag();
            }
            viewHolder2.textView.setText(datas.get(i).getTitle());
            //下载图片
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s(),viewHolder2.img1,options);
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s02(),viewHolder2.img2,options);
            return  view;
        }else{
            ViewHolder1 viewHolder1;
            if(view==null){
                view=View.inflate(context,R.layout.item_one_image,null);
                viewHolder1=new ViewHolder1();
                viewHolder1.textView=view.findViewById(R.id.tv_title);
                viewHolder1.img1=view.findViewById(R.id.img1);
                view.setTag(viewHolder1);
            }else{
                viewHolder1=(ViewHolder1) view.getTag();
            }
            viewHolder1.textView.setText(datas.get(i).getTitle());
            //下载图片
            ImageLoader.getInstance().displayImage(datas.get(i).getThumbnail_pic_s(),viewHolder1.img1,options);
            return  view;
        }
    }
    @Override
    public int getViewTypeCount() {
        return 3;
    }
    //position:条目的下标
    @Override
    public int getItemViewType(int position) {
        //得到图片地址
        String pics = datas.get(position).getThumbnail_pic_s();
        String pic02 = datas.get(position).getThumbnail_pic_s02();
        String pic03 = datas.get(position).getThumbnail_pic_s03();
        if(pics!=null && pic02!=null && pic03!=null){
            return THREE_IMAGE;//三张图类型
        }else if(pics!=null && pic02!=null && pic03==null){
            return TWO_IMAGE;//两张图的类型
        }else if(pics!=null && pic02==null && pic03==null){
            return ONE_IMAGE;//一张图的类型
        }else{
            return ONE_IMAGE;
        }
    }

    class ViewHolder1{
        TextView textView;
        ImageView img1;
    }
    class ViewHolder2{
        TextView textView;
        ImageView img1;
        ImageView img2;
    }
    class ViewHolder3{
        TextView textView;
        ImageView img1;
        ImageView img2;
        ImageView img3;
    }
}
====================================================================
适配器中的布局:

item_one_image

<RelativeLayout android:layout_height="match_parent" android:layout_width="match_parent" xmlns:android="http://schemas.android.com/apk/res/android">

  <TextView android:layout_height="wrap_content" android:layout_width="match_parent" android:id="@+id/tv_title"/>

  <ImageView android:layout_height="80dp" android:layout_width="match_parent" android:id="@+id/img1" android:layout_centerHorizontal="true" android:layout_below="@+id/tv_title"/>

</RelativeLayout>

item_two_image

<RelativeLayout android:layout_height="match_parent" android:layout_width="match_parent" xmlns:android="http://schemas.android.com/apk/res/android">

  <TextView android:layout_height="wrap_content" android:layout_width="match_parent" android:id="@+id/tv_title"/>

  <LinearLayout android:layout_height="wrap_content" android:layout_width="match_parent" android:layout_below="@+id/tv_title" android:layout_centerHorizontal="true" android:orientation="horizontal">

    <ImageView android:layout_height="80dp" android:layout_width="0dp" android:id="@+id/img1" android:layout_weight="1"/>

    <ImageView android:layout_height="80dp" android:layout_width="0dp" android:id="@+id/img2" android:layout_weight="1"/>

  </LinearLayout>

</RelativeLayout>

item_three_image

<RelativeLayout android:layout_height="match_parent" android:layout_width="match_parent" xmlns:android="http://schemas.android.com/apk/res/android">

  <TextView android:layout_height="wrap_content" android:layout_width="match_parent" android:id="@+id/tv_title"/>

  <LinearLayout android:layout_height="wrap_content" android:layout_width="match_parent" android:layout_below="@+id/tv_title" android:layout_centerHorizontal="true" android:orientation="horizontal">

    <ImageView android:layout_height="80dp" android:layout_width="0dp" android:id="@+id/img1" android:layout_weight="1"/>

    <ImageView android:layout_height="80dp" android:layout_width="0dp" android:id="@+id/img2" android:layout_weight="1"/>

    <ImageView android:layout_height="80dp" android:layout_width="0dp" android:id="@+id/img3" android:layout_weight="1"/>

  </LinearLayout>

</RelativeLayout>

==============================================================================================

imageloader:(记得导jar包universalimageloader

public class MyApplication extends Application {
    @Override
    public void onCreate() {
        super.onCreate();
//        File file=getExternalCacheDir();//...data
        File file= new File(Environment.getExternalStorageDirectory().getPath()+"/aaa");
        //imgeloader的初使化
        ImageLoaderConfiguration configuration=new ImageLoaderConfiguration.Builder(this)
                .memoryCacheExtraOptions(480, 800)//缓存图片最大的长和宽
                .threadPoolSize(2)//线程池的数量
                .threadPriority(4)
                .memoryCacheSize(5*1024*1024)//设置内存缓存区大小
                .diskCacheSize(50*1024*1024)//设置sd卡缓存区大小
                .diskCache(new UnlimitedDiscCache(file))//自定义sd缓存目录
                .writeDebugLogs()//打印日志内容
                .diskCacheFileNameGenerator(new Md5FileNameGenerator())//给缓存的文件名进行md5加密处理
                .build();
        ImageLoader.getInstance().init(configuration);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值