上拉刷新 下拉加载

本文介绍了一个使用Android平台从远程API加载电影热榜数据的应用案例。通过AsyncTask实现异步数据请求,利用Gson库解析JSON响应,并使用XListView进行数据展示。文章详细展示了如何配置ImageLoader进行图片缓存,以及自定义适配器处理数据列表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主页

在这里插入代码片package com.example.dell.myapplicationday1207;

import android.annotation.SuppressLint;
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.google.gson.Gson;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.List;

import me.maxwin.view.XListView;

public class MainActivity extends AppCompatActivity {

    private XListView lists;
    private NewsAdapter adapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //寻找资源
        lists = findViewById(R.id.list_item);
        //设置适配器
        adapter = new NewsAdapter(this);
        lists.setAdapter(adapter);

        //下啦刷新
        lists.setPullLoadEnable(true);
        //给Xlist 设置监听事件
        lists.setXListViewListener(new XListView.IXListViewListener() {
            @Override
            public void onRefresh() {//刷新
               page=1;
               //初始化数据
               initData();
            }

            @Override
            public void onLoadMore() { //下载
              initData();
            }
        });
        page=1;
        initData();
    }
    //接口的 位置
    private int page=1;
    private final int count=10;
    private String apiURL="http://172.17.8.100/movieApi/movie/v1/findHotMovieList?";
    @SuppressLint("StaticFieldLeak")
    private void initData() {
        AsyncTask<String, Void, List<Bean.Data>>  asyncTask = new AsyncTask<String, Void, List<Bean.Data>>() {
            @Override
            protected List<Bean.Data> doInBackground(String... strings) {
                try {
                    URL url = new URL(strings[0]);
                    HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
                    urlConnection.setConnectTimeout(5000);
                    urlConnection.setReadTimeout(5000);
                    int responseCode = urlConnection.getResponseCode();
                    if (responseCode==200){
                        String result=stream2String(urlConnection.getInputStream());
                        Gson gson = new Gson();
                        Bean bean = gson.fromJson(result, Bean.class);

                        return bean.getResult();
                    }
                } catch (MalformedURLException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                return null;
            }

            @Override
            protected void onPostExecute(List<Bean.Data> datas) {
                  //数据进行判断
                if (datas==null){
                    lists.stopLoadMore();
                    lists.stopRefresh();
                    return;
                }
                if (page==1){//刷新
                    adapter.setList(datas);
                }else{//下载
                    adapter.addData(datas);
                }
                //如果没有下一页了 则停止加载
                lists.setPullLoadEnable(datas.size()>=count);
                lists.stopRefresh();
                lists.stopLoadMore();
                page++;
            }
        }.execute(apiURL+"page="+page+"&count="+count);
    }

    private String stream2String(InputStream inputStream) throws IOException {
        StringBuilder stringBuilder = new StringBuilder();
        InputStreamReader ir = new InputStreamReader(inputStream);
        BufferedReader br = new BufferedReader(ir);
        for (String tmp=br.readLine();tmp!=null;tmp=br.readLine()){
            stringBuilder.append(tmp);
        }
        return stringBuilder.toString();
    }
}

图片设置

package com.example.dell.myapplicationday1207;

import android.app.Application;
import android.graphics.Bitmap;

import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;

public class App extends Application {
    @Override
    public void onCreate() {
        super.onCreate();

        ImageLoaderConfiguration configuration = new ImageLoaderConfiguration.Builder(this)
                .memoryCacheSize(10)
                .diskCacheSize(10*1024*1024)
                .defaultDisplayImageOptions(new DisplayImageOptions.Builder()
                   .bitmapConfig(Bitmap.Config.RGB_565)
                        .showImageOnFail(R.mipmap.ic_launcher)
                        .showImageForEmptyUri(R.mipmap.ic_launcher)
                        .showImageOnLoading(R.mipmap.ic_launcher)
                        .cacheInMemory(true)
                        .cacheOnDisk(true)
                        .build()
                ).build();
        ImageLoader.getInstance().init(configuration);
    }
}

Bean类

package com.example.dell.myapplicationday1207;

import java.io.Serializable;
import java.util.List;

public class Bean {
    private String message;
    private String status;
    private List<Data> result;

    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }

    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }

    public List<Data> getResult() {
        return result;
    }

    public void setResult(List<Data> result) {
        this.result = result;
    }

    class Data{
        private String name;
        private String summary;
        private String imageUrl;

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public String getSummary() {
            return summary;
        }

        public void setSummary(String summary) {
            this.summary = summary;
        }

        public String getImageUrl() {
            return imageUrl;
        }

        public void setImageUrl(String imageUrl) {
            this.imageUrl = imageUrl;
        }
    }
}

适配器

在这里插入代码片package com.example.dell.myapplicationday1207;

import android.content.Context;
import android.support.v4.app.FragmentManager;
import android.view.LayoutInflater;
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.ImageLoader;

import java.util.ArrayList;
import java.util.List;
import java.util.TreeMap;

public class NewsAdapter extends BaseAdapter {
   private Context context;
   private List<Bean.Data> list;

    public NewsAdapter(Context context) {
        this.context = context;
        list=new ArrayList<>();
    }
//更新放法
    public void setList(List<Bean.Data> list) {
        if (list!=null){
            this.list = list;
        }
         notifyDataSetChanged();
    }
    //追加数据
    public void addData(List<Bean.Data> b){
        if (b!=null){
            list.addAll(b);
        }
        notifyDataSetChanged();
    }

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

    @Override
    public Bean.Data 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) {
        ViewHolder viewHolder;
        if (convertView==null){
            viewHolder = new ViewHolder();
            convertView=LayoutInflater.from(context).inflate(R.layout.xlist,parent,false);
            viewHolder.text = convertView.findViewById(R.id.text1);
            viewHolder.title = convertView.findViewById(R.id.title1);
            viewHolder.img = convertView.findViewById(R.id.image01);
            convertView.setTag(viewHolder);
        }else{
            viewHolder = (ViewHolder) convertView.getTag();
        }
        viewHolder.title.setText(list.get(position).getName());
        viewHolder.text.setText(list.get(position).getSummary());
        ImageLoader.getInstance().displayImage(list.get(position).getImageUrl(),viewHolder.img);
        return convertView;
    }
    class ViewHolder{
        TextView text;
        TextView title;
        ImageView img;
    }
}

资源下载链接为: https://pan.quark.cn/s/9648a1f24758 这个HTML文件是一个专门设计的网页,适合在告白或纪念日这样的特殊时刻送给女朋友,给她带来惊喜。它通过HTML技术,将普通文字转化为富有情感和创意的表达方式,让数字媒体也能传递深情。HTML(HyperText Markup Language)是构建网页的基础语言,通过标签描述网页结构和内容,让浏览器正确展示页面。在这个特效网页中,开发者可能使用了HTML5的新特性,比如音频、视频、Canvas画布或WebGL图形,来提升视觉效果和交互体验。 原本这个文件可能是基于ASP.NET技术构建的,其扩展名是“.aspx”。ASP.NET是微软开发的一个服务器端Web应用程序框架,支持多种编程语言(如C#或VB.NET)来编写动态网页。但为了在本地直接运行,不依赖服务器,开发者将其转换为纯静态的HTML格式,只需浏览器即可打开查看。 在使用这个HTML特效页时,建议使用Internet Explorer(IE)浏览器,因为一些老的或特定的网页特效可能只在IE上表现正常,尤其是那些依赖ActiveX控件或IE特有功能的页面。不过,由于IE逐渐被淘汰,现代网页可能不再对其进行优化,因此在其他现代浏览器上运行可能会出现问题。 压缩包内的文件“yangyisen0713-7561403-biaobai(html版本)_1598430618”是经过压缩的HTML文件,可能包含图片、CSS样式表和JavaScript脚本等资源。用户需要先解压,然后在浏览器中打开HTML文件,就能看到预设的告白或纪念日特效。 这个项目展示了HTML作为动态和互动内容载体的强大能力,也提醒我们,尽管技术在进步,但有时复古的方式(如使用IE浏览器)仍能唤起怀旧之情。在准备类似的个性化礼物时,掌握基本的HTML和网页制作技巧非常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值