PullToRefreshListView实现多条目加载上拉刷新和下拉加载

本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下

XML布局

主页面main布局

<com.handmark.pulltorefresh.library.PullToRefreshListView
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:id="@+id/pull"
  >
</com.handmark.pulltorefresh.library.PullToRefreshListView>

pulllist布局

<ImageView
  android:layout_width="120dp"
  android:layout_height="100dp"
  android:id="@+id/iv"
  />
<TextView
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:id="@+id/tv"
  />

java代码

App页面

package com.example.duanpengpenglx20171108;

import android.app.Application;

import com.nostra13.universalimageloader.cache.memory.impl.UsingFreqLimitedMemoryCache;
import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;
import com.nostra13.universalimageloader.core.assist.QueueProcessingType;
import com.nostra13.universalimageloader.core.download.BaseImageDownloader;

/**
 * Created by 朋 on 2017/11/8.
 */

public class App extends Application {
  @Override
  public void onCreate() {
    super.onCreate();
    ImageLoaderConfiguration config = new ImageLoaderConfiguration
        .Builder(this)
        .memoryCacheExtraOptions(480,800)
        .threadPoolSize(5)
        .threadPriority(Thread.NORM_PRIORITY - 2)
        .denyCacheImageMultipleSizesInMemory()
        .memoryCache(new UsingFreqLimitedMemoryCache(2 * 1024 * 1024)) // You can pass your own memory cache implementation/你可以通过自己的内存缓存实现
        .memoryCacheSize(2 * 1024 * 1024)
        .tasksProcessingOrder(QueueProcessingType.LIFO)
        .defaultDisplayImageOptions(DisplayImageOptions.createSimple())
        .imageDownloader(new BaseImageDownloader(this, 5 * 1000, 30 * 1000)) // connectTimeout (5 s), readTimeout (30 s)超时时间
        .writeDebugLogs() // Remove for release app
        .build();//开始构建
//初始化imageloader;
    ImageLoader.getInstance().init(config);
  }
}

MainActivity页面

public class MainActivity extends AppCompatActivity {

  List<Jbean.DataBean> arr = new ArrayList();
  private View view;
  private ListView lv;
  private Adapter adapter;
  int i = 0;
  private PullToRefreshListView pull;
  private Adapter adapter1;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    pull = (PullToRefreshListView) findViewById(R.id.pull);
    pull.setMode(PullToRefreshBase.Mode.BOTH);
    ListView lv = pull.getRefreshableView();
    adapter1 = new Adapter();
    lv.setAdapter(adapter1);

    new MyAsyncTask().execute("http://www.93.gov.cn/93app/data.do?channelId=0&startNum=0");
    pull.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2<ListView>() {
      @Override
      //上拉
      public void onPullDownToRefresh(PullToRefreshBase<ListView> refreshView) {
        arr.clear();
        i = 0;
        new MyAsyncTask().execute("http://www.93.gov.cn/93app/data.do?channelId=0&startNum=" + i);
      }
      @Override
      //下拉加载20条
      public void onPullUpToRefresh(PullToRefreshBase<ListView> refreshView) {
        i = i + 20;new MyAsyncTask().execute("http://www.93.gov.cn/93app/data.do?channelId=0&startNum=" + i);

      }
    });
  }
  class MyAsyncTask extends AsyncTask<String, Void, String> {

    @Override
    protected String doInBackground(String... params) {
      String string = "";
      StringBuffer stringBuffer = new StringBuffer();
      try {
        URL url = new URL(params[0]);
        URLConnection urlConnection = url.openConnection();
        InputStream inputStream = urlConnection.getInputStream();
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
        while ((string = bufferedReader.readLine()) != null) {
          stringBuffer.append(string);
        }
      } catch (Exception e) {
        e.printStackTrace();
      }
      return stringBuffer.toString();
    }

    @Override
    protected void onPostExecute(String s) {
      super.onPostExecute(s);
      Jbean fragone_bean = new Gson().fromJson(s, Jbean.class);
      List<Jbean.DataBean> data = fragone_bean.getData();
      arr.addAll(data);
      adapter1.notifyDataSetChanged();
      pull.onRefreshComplete();
    }
  }

  class Adapter extends BaseAdapter {

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

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

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
      Sj sj = new Sj();
      Jbean.DataBean dataBean = arr.get(position);
      if (convertView==null){
        convertView = View.inflate(MainActivity.this,R.layout.pulllist,null);
        sj.image=convertView.findViewById(R.id.iv);
        sj.tv=convertView.findViewById(R.id.tv);
        convertView.setTag(sj);
      }else {
        sj =(Sj) convertView.getTag();
      }
      sj.tv.setText(dataBean.getSUBTITLE());
      DisplayImageOptions options = new DisplayImageOptions.Builder()
          .cacheInMemory(true)
          .cacheOnDisk(true)
          .showImageOnLoading(R.drawable.zhengzaijiazai)
          .showImageForEmptyUri(R.drawable.zhengzaijiazai)
          .showImageOnFail(R.drawable.zhengzaijiazai)
          .bitmapConfig(Bitmap.Config.RGB_565)
          .build();
      ImageLoader.getInstance().displayImage((String) dataBean.getIMAGEURL(),sj.image,options);

      return convertView;
    }
  }
  class Sj{
    ImageView image;
    TextView tv;
  }
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android ListView结合xutils3仿微信实现下拉加载更多

    前言:最近涉及到和QQ打交道,定义所有的好友一共只能有300条消息,如果一次性从数据库读取300条或者更多,界面会有细微的卡顿.所以考虑了下分页,第一次进来只显示20条(仿微信),当用户滑到第一条后,如果数据库有消息,则再加载20条. 步骤-问把大象关冰箱,总共分几步? 1.自定义absListview.scrollListerner 核心的东西是监听ListView的scrollListerner,这里采取拿来主义 原文连接找不到了,如果原作者看到,请联系青楼爱小生,将您的文章链接更新出来 ,

  • Android RecyclerView 上拉加载更多及下拉刷新功能的实现方法

    RecyclerView 已经出来很久了,但是在项目中之前都使用的是ListView,最近新的项目上了都大量的使用了RecycleView.尤其是瀑布流的下拉刷新,网上吧啦吧啦没有合适的自己总结了一哈. 先贴图上来看看: 使用RecyclerView实现上拉加载更多和下拉刷新的功能我自己有两种方式: 1.使用系统自带的Android.support.v4.widget.SwipeRefreshLayout这个控价来实现. 2.自定义的里面带有RecyleView的控件. 使用RecycleVie

  • Android中使用RecyclerView实现下拉刷新和上拉加载

    推荐阅读:使用RecyclerView添加Header和Footer的方法                       RecyclerView的使用之HelloWorld RecyclerView 是Android L版本中新添加的一个用来取代ListView的SDK,它的灵活性与可替代性比listview更好.本文给大家介绍如何为RecyclerView添加下拉刷新和上拉加载,过去在ListView当中添加下拉刷新和上拉加载是非常方便的利用addHeaderView和addFooterVie

  • android开发教程之实现listview下拉刷新和上拉刷新效果

    复制代码 代码如下: public class PullToLoadListView extends ListView implements OnScrollListener { private static final String TAG = PullToLoadListView.class.getSimpleName(); private static final int STATE_NON = 0; private static final int STATE_PULL_TO_REFRE

  • Android实现上拉加载更多以及下拉刷新功能(ListView)

    首先为大家介绍Andorid5.0原生下拉刷新简单实现. 先上效果图: 相对于上一个19.1.0版本中的横条效果好看了很多.使用起来也很简单. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" and

  • Android下拉刷新上拉加载控件(适用于所有View)

    前面写过一篇关于下拉刷新控件的文章下拉刷新控件终结者:PullToRefreshLayout,后来看到好多人还有上拉加载更多的需求,于是就在前面下拉刷新控件的基础上进行了改进,加了上拉加载的功能.不仅如此,我已经把它改成了对所有View都通用!可以随心所欲使用这两个功能~~ 我做了一个大集合的demo,实现了ListView.GridView.ExpandableListView.ScrollView.WebView.ImageView.TextView的下拉刷新和上拉加载.后面会提供demo的

  • Android RecyclerView实现下拉刷新和上拉加载

    RecyclerView已经出来很久了,许许多多的项目都开始从ListView转战RecyclerView,那么,上拉加载和下拉刷新是一件很有必要的事情. 在ListView上,我们可以通过自己添加addHeadView和addFootView去添加头布局和底部局实现自定义的上拉和下拉,或者使用一些第三方库来简单的集成,例如Android-pulltorefresh或者android-Ultra-Pull-to-Refresh,后者的自定义更强,但需要自己实现上拉加载. 而在下面我们将用两种方式

  • Android ListView实现下拉加载功能

    本文实例为大家分享了ListView下拉加载展示的具体代码,供大家参考,具体内容如下 1.MyListView.Java public class MyListView extends ListView implements OnScrollListener { private final static int RELEASE_To_REFRESH = 0;// 下拉过程的状态值 private final static int PULL_To_REFRESH = 1; // 从下拉返回到不刷新

  • Android实现仿慕课网下拉加载动画

    具体实现方法就不多介绍了先附上源码,相信大家都容易看的懂: 这里为了让这个动画效果可被复用,于是就继承了ImageView 去实现某些方法 package com.example.loading_drawable; import android.content.Context; import android.graphics.drawable.AnimationDrawable; import android.util.AttributeSet; import android.util.Log;

  • Android仿网易一元夺宝客户端下拉加载动画效果(一)

    上上周写的一个demo,仿照网易一元夺宝的下拉刷新效果. 原效果是(第一部分)一个小太阳拉下来,然后松开回弹上去, (第二部分)再掉下来一个硬币进行中轴旋转. 本文实现的效果的是第一部分的,效果演示图如下: Gif图看起来比较卡顿...其实真机演示效果还是很流畅的. 下面分析实现过程: 当时因为时间有限没有写在下拉刷新的组件中,也没有封装成一个单独的组件,只是在主布局后面写了一个View然后实现相应的操作,进行封装并不难,这里就不花时间BB了,下面是布局文件: <RelativeLayout x

随机推荐