PullToRefresh引入依赖,布局,适配器ListView上拉加载下拉刷新

本文主要是介绍PullToRefresh引入依赖,布局,适配器ListView上拉加载下拉刷新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用PullToRefreshListView前 先在File-New-import Module 导入pulltoRefreshLibrary,
然后给项目 添加 module的依赖,
 
选择pulltoRefreshLibrary

activity_main.xml 
 
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"><com.handmark.pulltorefresh.library.PullToRefreshListViewxmlns:ptr="http://schemas.android.com/apk/res-auto"android:layout_height="match_parent"android:layout_width="match_parent"android:id="@+id/refresh_list_view"ptr:ptrDrawable="@drawable/default_ptr_flip"ptr:ptrAnimationStyle="flip"ptr:ptrHeaderBackground="#383838"ptr:ptrHeaderTextColor="#FFFFFF">
</com.handmark.pulltorefresh.library.PullToRefreshListView>
</RelativeLayout>
适配器里面的

public class MyAdapter extends BaseAdapter{List<DBean.NewslistBean> list;Context context;public MyAdapter(List<DBean.NewslistBean> list, Context context) {this.context = context;this.list = list;ImageLoaderConfiguration configuration = ImageLoaderConfiguration.createDefault(context);ImageLoader.getInstance().init(configuration);}@Overridepublic int getCount() {return list.size();}@Overridepublic Object getItem(int i) {return list.get(i);}@Overridepublic long getItemId(int i) {return i;}@Overridepublic View getView(int i, View view, ViewGroup viewGroup) {ViewHolder holder;if (view==null){view = View.inflate(context,R.layout.list_item,null);holder = new ViewHolder();holder.imageView = view.findViewById(R.id.list_image);holder.textView = view.findViewById(R.id.list_text);view.setTag(holder);}else{holder = (ViewHolder) view.getTag();}holder.textView.setText(list.get(i).getTitle());ImageLoader.getInstance().displayImage(list.get(i).getPicUrl(),holder.imageView);return view;}class ViewHolder{ImageView imageView;TextView textView;}
}
MainActivity里面的
public class MainActivity extends AppCompatActivity { private List<DBean.NewslistBean> list = new ArrayList<>(); private PullToRefreshListView refreshListView;int num = 1;   private MyAdapter myAdapter;    private ILoadingLayout endlabels; private ILoadingLayout startlabels; @Override  protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);       setContentView(R.layout.activity_main);     refreshListView = (PullToRefreshListView) findViewById(R.id.refresh_list_view);       getDataFromNet();        //设置PullToRefreshListView刷新模式,上拉下拉都可以       refreshListView.setMode(PullToRefreshBase.Mode.BOTH);        //设置刷新显示的状态,可以下拉,不能上拉      startlabels = refreshListView.getLoadingLayoutProxy(true,false);    startlabels.setRefreshingLabel("正在刷新");      startlabels.setPullLabel("下拉刷新");       startlabels.setReleaseLabel("松开刷新");     endlabels = refreshListView.getLoadingLayoutProxy(false,true);      endlabels.setRefreshingLabel("正在加载");       endlabels.setPullLabel("上拉加载");       endlabels.setReleaseLabel("松开加载");       //设置监听事件       refreshListView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {   @Override           //下拉刷新调用          public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {             num =1;              //获取数据            getDataFromNetxiala();            setAdapter();           }         @Override        //上拉加载调用     public void onPullUpToRefresh(PullToRefreshBase<ListView> refreshView) {   num++;    getDataFromNet();       setAdapter();         }     });  }   private void setAdapter() {      if (myAdapter==null) {        myAdapter = new MyAdapter(list, MainActivity.this);     refreshListView.setAdapter(myAdapter);      }else{     myAdapter.notifyDataSetChanged();     }   }   private void getDataFromNet() {   AsyncTask<Void, Void, String> asyncTask = new AsyncTask<Void, Void, String>() {  @Override          protected String doInBackground(Void... voids) {   String path = "https://api.tianapi.com/wxnew/?key=8d6e3228d25298f13af4fc40ce6c9679&num=10&page="+num;        try {                  URL url = new URL(path);                HttpURLConnection connection = (HttpURLConnection) url.openConnection();  connection.setRequestMethod("GET");          connection.setConnectTimeout(5000);                 connection.setReadTimeout(5000);                  int responseCode = connection.getResponseCode();             if (responseCode==200){                    InputStream inputStream = connection.getInputStream();                 String json = streamtoString(inputStream,"utf-8");                 Thread.sleep(2000);                 return json;                }             } catch (Exception e) {  e.printStackTrace();             }              return null;     }         @Override   protected void onPostExecute(String json) {    Gson gson = new Gson();             DBean dBean = gson.fromJson(json, DBean.class);     list.addAll(dBean.getNewslist());              long currentTimeMillis = System.currentTimeMillis();      Date date2= new Date(currentTimeMillis);             SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm");      String format = dateFormat.format(date2);              //设置刷新的时间              endlabels.setLastUpdatedLabel(format);        //停止刷新              refreshListView.onRefreshComplete();    setAdapter();      }       };      asyncTask.execute(); }  private void getDataFromNetxiala() {   AsyncTask<Void, Void, String> asyncTask = new AsyncTask<Void, Void, String>() {  @Override        protected String doInBackground(Void... voids) {       String path = "https://api.tianapi.com/wxnew/?key=8d6e3228d25298f13af4fc40ce6c9679&num=10&page="+num;       try {              URL url = new URL(path);                 HttpURLConnection connection = (HttpURLConnection) url.openConnection();        connection.setRequestMethod("GET");              connection.setConnectTimeout(5000);               connection.setReadTimeout(5000);                 int responseCode = connection.getResponseCode();              if (responseCode==200){                     InputStream inputStream = connection.getInputStream();           String json = streamtoString(inputStream,"utf-8");                    Thread.sleep(2000);                     return json;                   }              } catch (Exception e) {     e.printStackTrace();       }              return null;      }          @Override         protected void onPostExecute(String json) {   Gson gson = new Gson();           DBean dBean = gson.fromJson(json, DBean.class);     list.addAll(0,dBean.getNewslist());             long currentTimeMillis = System.currentTimeMillis();  Date date2= new Date(currentTimeMillis);            SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm");   String format = dateFormat.format(date2);             //设置刷新的时间            startlabels.setLastUpdatedLabel(format);     //停止刷新               refreshListView.onRefreshComplete();     setAdapter();          }     };      asyncTask.execute();  }   private String streamtoString(InputStream inputStream, String charset) {    try {    InputStreamReader inputStreamReader = new InputStreamReader(inputStream, charset);        BufferedReader bufferedReader = new BufferedReader(inputStreamReader);      String s= null;        StringBuilder builder = new StringBuilder();      while((s=bufferedReader.readLine())!=null){     builder.append(s);           }           return builder.toString();     } catch (Exception e) {   e.printStackTrace();      }        return charset;   }}


这篇关于PullToRefresh引入依赖,布局,适配器ListView上拉加载下拉刷新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/869310

相关文章

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

javacv依赖太大导致jar包也大的解决办法

《javacv依赖太大导致jar包也大的解决办法》随着项目的复杂度和依赖关系的增加,打包后的JAR包可能会变得很大,:本文主要介绍javacv依赖太大导致jar包也大的解决办法,文中通过代码介绍的... 目录前言1.检查依赖2.更改依赖3.检查副依赖总结 前言最近在写项目时,用到了Javacv里的获取视频

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Spring-DI依赖注入全过程

《Spring-DI依赖注入全过程》SpringDI是核心特性,通过容器管理依赖注入,降低耦合度,实现方式包括组件扫描、构造器/设值/字段注入、自动装配及作用域配置,支持灵活的依赖管理与生命周期控制,... 目录1. 什么是Spring DI?2.Spring如何做的DI3.总结1. 什么是Spring D

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

SpringBoot加载profile全面解析

《SpringBoot加载profile全面解析》SpringBoot的Profile机制通过多配置文件和注解实现环境隔离,支持开发、测试、生产等不同环境的灵活配置切换,无需修改代码,关键点包括配置文... 目录题目详细答案什么是 Profile配置 Profile使用application-{profil

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二