XListView实现网络加载图片和下拉刷新

 更新时间:2018年11月23日 14:48:45   作者:FanRQ_  
这篇文章主要为大家详细介绍了XListView实现网络加载图片和下拉刷新,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

 本文实例为大家分享了XListView实现网络加载图片,和下拉刷新的功能,供大家参考,具体内容如下

MainActivity.java

public class MainActivity extends AppCompatActivity {

 private XListView contents;

 private int page = 0;
 private MyBaseAdapter adapter;

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

  contents = findViewById(R.id.contents);
  adapter = new MyBaseAdapter(getLayoutInflater());
  contents.setAdapter(adapter);

  //是否开启下拉刷新 上拉加载
  //contents.setPullRefreshEnable(false);
  contents.setPullLoadEnable(true);

  contents.setXListViewListener(new XListView.IXListViewListener() {
   @Override public void onRefresh() {
    page = 0;
    loadData(page);
    //加载刷新数据
   }

   @Override public void onLoadMore() {
    loadData(page);
   }
  });

  //一进来就去加载第一页数据
  loadData(page);
 }

 private String url =
   "http://apis.juhe.cn/cook/query?key=3ec004200a6a2f4cf4774e480c006375&menu=%E8%A5%BF%E7%BA%A2%E6%9F%BF&rn=10&pn=";

 private void loadData(int page) {
  String requestUrlWithPageNum = url + page;

  //加载网络数据
  new AsyncTask<String, Void, List<DataItem>>() {

   @Override protected List<DataItem> doInBackground(String... strings) {
    ResponseBean responseBean = null;
    try {
     URL url = new URL(strings[0]);
     HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
     urlConnection.setRequestMethod("GET");
     urlConnection.setConnectTimeout(5000);
     urlConnection.setReadTimeout(5000);

     int responseCode = urlConnection.getResponseCode();
     if (responseCode == 200) {
      String str = stream2String(urlConnection.getInputStream());
      responseBean = new Gson().fromJson(str, ResponseBean.class);
     } else {
      //
     }
     return responseBean == null ? null : responseBean.getResult().getData();
    } catch (MalformedURLException e) {
     e.printStackTrace();
    } catch (IOException e) {
     e.printStackTrace();
    }

    return null;
   }

   @Override protected void onPostExecute(List<DataItem> dataItems) {
    if (dataItems == null) {
     Toast.makeText(MainActivity.this, "请求数据错误", Toast.LENGTH_LONG).show();
     return;
    }

    //更新数据
    updateData(dataItems);
    loadCompleted();
   }
  }.execute(url);
 }

 private String stream2String(InputStream is) throws IOException {
  BufferedReader br = new BufferedReader(new InputStreamReader(is));
  StringBuilder sb = new StringBuilder();
  for (String tmp = br.readLine(); tmp != null; tmp = br.readLine()) {
   sb.append(tmp);
  }

  return sb.toString();
 }

 private void updateData(List<DataItem> datas) {
  if (page == 0) {
   adapter.setDatas(datas);
  } else {
   adapter.addDatas(datas);
  }
 }

 //通过 加载 / 刷新 完成
 private void loadCompleted() {
  //通过ListView:刷新、加载完成
  page++;
  contents.stopLoadMore();
  contents.stopRefresh();
 }
}

MyBaseAdapter.java

public class MyBaseAdapter extends BaseAdapter {

 private List<DataItem> mDatas;
 protected LayoutInflater mInflater;

 /**
  * 更新数据
  */
 public void setDatas(List<DataItem> datas) {
  mDatas.clear();
  if (datas != null) {
   mDatas.addAll(datas);
  }
  notifyDataSetChanged();
 }

 /**
  * 追加数据
  */
 public void addDatas(List<DataItem> datas) {
  if (datas != null) {
   mDatas.addAll(datas);
   notifyDataSetChanged();
  }
 }

 public MyBaseAdapter(LayoutInflater mInflater) {
  this.mInflater = mInflater;
  mDatas = new ArrayList<>();
 }

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

 @Override public DataItem getItem(int position) {
  return mDatas.get(position);
 }

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

 @Override public View getView(int position, View convertView, ViewGroup parent) {
  BaseViewHolder viewHolder = null;

  if (convertView == null) {
   convertView = mInflater.inflate(R.layout.item, parent, false);
   viewHolder = new BaseViewHolder(convertView);
  } else {
   viewHolder = (BaseViewHolder) convertView.getTag();
  }

  viewHolder.bindData(getItem(position));

  return convertView;
 }

 public class BaseViewHolder {
  private View itemView;

  private ImageView icon;
  private TextView title;
  private TextView date;

  public BaseViewHolder(View itemView) {
   this.itemView = itemView;
   title = itemView.findViewById(R.id.title);
   date = itemView.findViewById(R.id.date);
   icon = itemView.findViewById(R.id.icon);

   itemView.setTag(this);
  }

  public void bindData(DataItem dataItem) {
   title.setText(dataItem.getTitle());
   date.setText(dataItem.getId());
   ImageLoader.getInstance().displayImage(dataItem.getFirstImageUrl(), icon,
     ImageLoaderConfigs.getDefaultDisplayImageOptions(icon.getContext()));
  }
 }
}
ImageLoader.java
  public class ImageLoaderConfigs {
 public static ImageLoaderConfiguration getImageLoaderConfiguration(Context context) {
  ImageLoaderConfiguration configuration = new ImageLoaderConfiguration.Builder(context)
    //内在缓存额外选项, 最大的宽度,高度
    //.memoryCacheExtraOptions(480, 800) // default = device screen dimensions 内存缓存文件的最大长宽
    //.diskCacheExtraOptions(480, 800, null) // 本地缓存的详细信息(缓存的最大长宽),最好不要设置这个
    //线程池配置
    //.taskExecutor()
    //.taskExecutorForCachedImages()
    //.threadPoolSize(3) // default 线程池内加载的数量
    //.threadPriority(Thread.NORM_PRIORITY - 2) // default 设置当前线程的优先级
    //任务处理优先级 Fist In Fist Out
    //.tasksProcessingOrder(QueueProcessingType.FIFO) // default
    //内存中不缓存一张图片的多个尺寸大小
    //.denyCacheImageMultipleSizesInMemory()
    //内在缓存策略
    //.memoryCache(new LruMemoryCache(2 * 1024 * 1024)) //可以通过自己的内存缓存实现
    //内存缓存大小
    //.memoryCacheSize(2 * 1024 * 1024) // 内存缓存的最大值
    //内在缓存大小:占用百分比
    .memoryCacheSizePercentage(13) // default
    //磁盘缓存策略
    //.diskCache(new LruDiskCache()) // default 可以自定义缓存路径
    //磁盘缓存大小
    .diskCacheSize(50 * 1024 * 1024) // 50 Mb sd卡(本地)缓存的最大值
    //.diskCacheFileCount(100) // 可以缓存的文件数量
    // default为使用HASHCODE对UIL进行加密命名, 还可以用MD5(new Md5FileNameGenerator())加密
    //.diskCacheFileNameGenerator(new HashCodeFileNameGenerator())
    //.imageDownloader(new BaseImageDownloader(context)) // default
    //(new BaseImageDecoder(false)) // default
    //加载具体图片时的一些配置
    .defaultDisplayImageOptions(DisplayImageOptions.createSimple()) // default
    .writeDebugLogs() // 打印debug log
    .build();

  return configuration;
 }

 public static DisplayImageOptions getDefaultDisplayImageOptions(Context context) {
  DisplayImageOptions displayImageOptions = new DisplayImageOptions.Builder()
    //是否缓存
    .cacheInMemory(true)
    .cacheOnDisk(true)
    //RGB 565  r红色占5  g绿色占6  b蓝色占5 -> 2字节
    //alpha
    //ARGB 4444  4 4 4 4 -> 2字节
    //ARGB 8888  -> 4字节

    //10 * 10 用rgb565 -> 10*10*2

    .bitmapConfig(Bitmap.Config.RGB_565)
    //加载时、加载错误时展示什么内容
    .showImageOnLoading(R.mipmap.ic_launcher)
    .showImageOnFail(R.mipmap.ic_launcher)
    //
    .imageScaleType(ImageScaleType.EXACTLY_STRETCHED)

    //加载效果
    //ctrl + p
    .displayer(new CircleBitmapDisplayer())
    .build();

  //ctrl + h
  //BitmapDisplayer;
  return displayImageOptions;
 }
}

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

相关文章

  • FFmpeg 音频可视化解码流程详解

    FFmpeg 音频可视化解码流程详解

    这篇文章主要为大家介绍了FFmpeg 音频可视化解码流程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Android中ActionBar以及menu的代码设置样式

    Android中ActionBar以及menu的代码设置样式

    这篇文章主要介绍了Android中ActionBar以及menu的代码设置样式的相关资料,需要的朋友可以参考下
    2015-07-07
  • 从0快速搭建一个实用的MVVM框架(超详细)

    从0快速搭建一个实用的MVVM框架(超详细)

    这篇文章主要介绍了从0搭建一个实用的MVVM框架,结合Jetpack,构建快速开发的MVVM框架,支持快速生成ListActivity、ListFragment,主要是基于MVVM进行快速开发上手即用,需要的朋友可以参考下
    2022-03-03
  • Android中使用GridView和ImageViewSwitcher实现电子相册简单功能实例

    Android中使用GridView和ImageViewSwitcher实现电子相册简单功能实例

    本篇文章主要介绍了Android中使用GridView和ImageViewSwitcher实现电子相册简单功能实例,具有一定的参考价值,有需要的可以了解一下。
    2016-12-12
  • Android 通用型手电筒代码

    Android 通用型手电筒代码

    说到手机手电筒功能,很多人都是直接调用闪光灯,而本文给大家介绍的是用相机功能来实现的,有需要的小伙伴可以参考下。
    2015-06-06
  • Android内存泄漏导致原因深入探究

    Android内存泄漏导致原因深入探究

    内存管理的目的就是让我们在开发过程中有效避免我们的应用程序出现内存泄露的问题。内存泄露相信大家都不陌生,我们可以这样理解:没有用的对象无法回收的现象就是内存泄露
    2023-02-02
  • Kotlin coroutineContext源码层深入分析

    Kotlin coroutineContext源码层深入分析

    表示一个元素或者是元素集合的接口。它有一个Key(索引)的Element实例集合,每一个Element的实例也是一个CoroutineContext,即集合中每个元素也是集合
    2022-11-11
  • Android自定义状态栏颜色与APP风格保持一致的实现方法

    Android自定义状态栏颜色与APP风格保持一致的实现方法

    我们知道iOS上的应用,状态栏的颜色总能与应用标题栏颜色保持一致,用户体验很不错,那安卓是否可以呢?下面小编给大家带来了Android自定义状态栏颜色与APP风格保持一致的实现方法,跟着小编一起学习吧
    2016-10-10
  • android自定义加减按钮

    android自定义加减按钮

    这篇文章主要为大家详细介绍了android自定义加减按钮,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • Android实现京东App分类页面效果

    Android实现京东App分类页面效果

    这篇文章主要为大家详细介绍了Android实现京东App分类页面效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02

最新评论