XListView下拉刷新,上拉加载和ListView多条目加载

本文介绍了一种自定义Android应用程序的方法,通过继承Application类来初始化全局资源,并展示了如何使用ImageLoader进行图片缓存配置。此外,还实现了一个带有下拉刷新和上拉加载功能的MainActivity,包括异步获取数据、解析JSON以及自定义适配器的过程。
自定义类,继承Application,加载缓冲
public class MyApplication extends Application {

    @Override
    public void onCreate() {
        super.onCreate();
        File file = new File(Environment.getExternalStorageDirectory().getPath()+"Images0718");
        ImageLoaderConfiguration build = new ImageLoaderConfiguration.Builder(this)
                .memoryCacheExtraOptions(80, 80)
                .memoryCacheSize(2 * 1024 * 1024)
                .threadPoolSize(3)
                .threadPriority(1000)
                .diskCacheFileNameGenerator(new Md5FileNameGenerator())
                .diskCacheSize(50 * 1024 * 1024)
                .diskCache(new UnlimitedDiskCache(file))
                .build();
        ImageLoader.getInstance().init(build);
    }
}
public class MainActivity extends AppCompatActivity implements XListView.IXListViewListener {

    private XListView xlistview;
    private int index = 1;
    private boolean boo = false;
    private MyBaseAdapter adapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        xlistview = (XListView) findViewById(R.id.xlistview);
        xlistview.setPullLoadEnable(true);
        xlistview.setXListViewListener(this);

        getData("http://apis.juhe.cn/cook/query.php", "26ef57b6568ddb188773d1c683879566", index +
                "", 5 + "", "鱼香肉丝");
    }

    private void getData(String path, String key, String pn, String rn, String name) {
        new AsyncTask<String, Void, String>() {
            @Override
            protected void onPostExecute(String s) {
                super.onPostExecute(s);
                if (s != null) {
                    Gson gson = new Gson();
                    MenuInfo info = gson.fromJson(s, MenuInfo.class);//MenuInfo是自定义JAVABean

                    List<MenuInfo.ResultBean.DataBean> list = info.getResult().getData();
                    if (adapter == null) {
                        adapter = new MyBaseAdapter(list);
                        xlistview.setAdapter(adapter);
                    } else {
                        adapter.addData(list, boo);
                        adapter.notifyDataSetChanged();
                    }
                }
            }

            @Override
            protected String doInBackground(String... params) {
                try {
                    String path = params[0];
                    String key = params[1];
                    String pn = params[2];
                    String rn = params[3];
                    String name = params[4];
                    URL url = new URL(path);
                    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
                    connection.setRequestMethod("POST");
                    connection.setConnectTimeout(5000);
                    connection.setReadTimeout(5000);
                    OutputStream os = connection.getOutputStream();
                    os.write(("menu=" + name + "&key=" + key + "&pn=" + pn + "&rn=" + rn).getBytes());
                    os.flush();
                    os.close();
                    if (connection.getResponseCode() == HttpURLConnection.HTTP_OK) {
                        InputStream is = connection.getInputStream();
                        return StringTools.getJson(is);
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return null;
            }
        }.execute(path, key, pn, rn, name);
    }

    //    下拉刷新
    @Override
    public void onRefresh() {
        ++index;
        getData("http://apis.juhe.cn/cook/query.php", "26ef57b6568ddb188773d1c683879566", index +
                "", 5 + "", "鱼香肉丝");
        boo = true;
        xlistview.stopRefresh(true);
    }

    //    上啦加载
    @Override
    public void onLoadMore() {
        ++index;
        getData("http://apis.juhe.cn/cook/query.php", "26ef57b6568ddb188773d1c683879566", index +
                "", 5 + "", "鱼香肉丝");
        boo = false;
        xlistview.stopLoadMore();
    }

    //    自定义适配器
    class MyBaseAdapter extends BaseAdapter {
        private List<MenuInfo.ResultBean.DataBean> list;

        public MyBaseAdapter(List<MenuInfo.ResultBean.DataBean> list) {
            this.list = list;
        }

        //        自定义方法增加数据,true的时候从0下标开始增加,否则默认从listview的最后面加载数据
        public void addData(List<MenuInfo.ResultBean.DataBean> data, boolean b) {
            for (MenuInfo.ResultBean.DataBean bean : data) {
                if (b)
                    list.add(0, bean);
                else
                    list.add(bean);
            }
        }

        @Override
        public int getCount() {
            return list.size();
        }

        @Override
        public Object getItem(int position) {
            return list.get(position);
        }

        @Override
        public long getItemId(int position) {
            return position;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            ViewHolder0 holder0 = null;
            ViewHolder1 holder1 = null;
//            得到布局类型
            int type = getItemViewType(position);
//            设置布局
            switch (type) {
                case 0:
                    if (convertView == null) {
                        convertView = View.inflate(MainActivity.this, R.layout.item0, null);
                        holder0 = new ViewHolder0();
                        holder0.img = (ImageView) convertView.findViewById(R.id.img);
                        holder0.tv = (TextView) convertView.findViewById(R.id.textview);
                        convertView.setTag(holder0);
                    } else {
                        holder0 = (ViewHolder0) convertView.getTag();
                    }
                    break;
                case 1:
                    if (convertView == null) {
                        convertView = View.inflate(MainActivity.this, R.layout.item1, null);
                        holder1 = new ViewHolder1();
                        holder1.img = (ImageView) convertView.findViewById(R.id.img);
                        holder1.tv = (TextView) convertView.findViewById(R.id.textview);
                        convertView.setTag(holder1);
                    } else {
                        holder1 = (ViewHolder1) convertView.getTag();
                    }
                    break;
            }
//            给每一个布局设置数据
            switch (type) {
                case 0:
                    holder0.tv.setText(list.get(position).getIngredients());
                    DisplayImageOptions build = new DisplayImageOptions.Builder()
                            .cacheInMemory(true)
                            .cacheOnDisk(true)
                            .displayer(new CircleBitmapDisplayer())//设置显示的图片成圆形
                            .build();
                    ImageLoader.getInstance().displayImage(list.get(position).getAlbums().get(0),
                            holder0.img, build);
                    break;
                case 1:
                    holder1.tv.setText(list.get(position).getIngredients());
                    DisplayImageOptions build1 = new DisplayImageOptions.Builder()
                            .cacheInMemory(true)
                            .cacheOnDisk(true)
                            .displayer(new CircleBitmapDisplayer())//设置显示的图片成圆形
                            .build();
                    ImageLoader.getInstance().displayImage(list.get(position).getAlbums().get(0),
                            holder1.img, build1);
                    break;
            }
            return convertView;
        }

        // 设置每一个item的布局
        @Override
        public int getItemViewType(int position) {
            if (position % 2 == 0)
                return 0;
            else
                return 1;
        }

        //        这是布局类型的总数
        //这是return 2的话,下标就是0,1;
        @Override
        public int getViewTypeCount() {
            return 2;
        }
    }

    class ViewHolder0 {
        ImageView img;
        TextView tv;
    }

    class ViewHolder1 {
        ImageView img;
        TextView tv;
    }
}

乐播投屏是一款简单好用、功能强大的专业投屏软件,支持手机投屏电视、手机投电脑、电脑投电视等种投屏方式。 端兼容与跨网投屏:支持手机、平板、电脑等种设备之间的自由组合投屏,且无需连接 WiFi,通过跨屏技术打破网络限制,扫一扫即可投屏。 广泛的应用支持:支持 10000+APP 投屏,包括综合视频、网盘与浏览器、美韩剧、斗鱼、虎牙等直播平台,还能将央视、湖南卫视等各大卫视的直播内容一键投屏。 高清流畅投屏体验:腾讯独家智能音画调校技术,支持 4K 高清画质、240Hz 超高帧率,低延迟不卡顿,能为用户提供更高清、流畅的视觉享受。 会议办公功能强大:拥有全球唯一的 “超级投屏空间”,扫码即投,无需安装。支持人共享投屏、远程协作批注,PPT、Excel、视频等文件都能流畅展示,还具备企业级安全加密,保障会议资料不泄露。 人互动功能:支持人投屏,邀请好友加入投屏互动,远程也可加入。同时具备一屏显、语音互动功能,支持人连麦,实时语音交流。 文件支持全面:支持 PPT、PDF、Word、Excel 等办公文件,以及视频、图片等种类型文件的投屏,还支持网盘直投,无需下载转格式。 特色功能丰富:投屏时可同步录制投屏画面,部分版本还支持通过触控屏或电视端外接鼠标反控电脑,以及在投屏过程中用画笔实时标注等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值