自定义PullToRefreshListView继承ListView,在ListView头部添加一个下拉的头部布局。跟ListView用法完全一致。

此处详细介绍Adapter的详细代码。

1.首先给Adapter绑定ListView布局。

2.其次创建一个层次对应组件的类,将对应的组件和对象进行关联,提高效率。

3.然后跟陆获得的图片路径异步下载图片,由于不知道该微博图片的数量,所以在listview中添加一个GirlView控件或者GirlLayout布局,然后将得到的图片添加到其中,并按指定属性值排列好。

**

* Created by D&LL on 2016/6/2.

*/

public class WeiboAdapter extends BaseAdapter {

/**

* 为提高效率,缓存数据准备的一个自定义类 对应一条微博数据

*/

class WeiboHolder {

public ImageView wbicon;

public TextView wbtext, wbtime, wbuser;

}

private HomeActivity homeActivity = null;

//数据集

public ArrayList weiboList = null;

public WeiboAdapter(HomeActivity homeActivity, ArrayList weiboList) {

this.homeActivity = homeActivity;

this.weiboList = weiboList;

}

//微博图片的异步下载类

AsyncImageLoader asyncImageLoader;

@Override

public View getView(int position, View convertView, ViewGroup parent) {

asyncImageLoader = new AsyncImageLoader();

//记载微博的每条需要显示在什么布局上的布局对象

convertView = LayoutInflater.from(this.homeActivity.getApplicationContext()).inflate(R.layout.listview,

null);

//创建一个层次对应组件的类

WeiboHolder wh = new WeiboHolder();

//将对应的组件和对象进行关联,提高效率

wh.wbicon = (ImageView) convertView.findViewById(R.id.wbicon);

wh.wbtext = (TextView) convertView.findViewById(R.id.wbtext);

wh.wbtime = (TextView) convertView.findViewById(R.id.wbtime);

wh.wbuser = (TextView) convertView.findViewById(R.id.wbuser);

/* wh.wbimage = (ImageView) convertView.findViewById(R.id.wbimage);*/

//获得一条微博数据

WeiBoInfo wb = this.weiboList.get(position);

if (wb != null) {

convertView.setTag(wb.getId());

wh.wbuser.setText(wb.getUserName());

wh.wbtime.setText(wb.getTime());

wh.wbtext.setText(StringUtils.getEmotionContent(convertView.getContext(), wh.wbtext, wb.getText()

), TextView.BufferType.SPANNABLE);

if (wb.getHaveImage()) {

// 是否有图片信息

//异步加载图片内容

Drawable[] wb_image = new Drawable[wb.getImage_context().length];

ImageView[] wbimage = new ImageView[wb.getImage_context().length];

GridLayout layout = (GridLayout) convertView.findViewById(R.id.imagelayout);

//遍历下载所有图片 并添加到listview中

for (int i = 0; i < wb.getImage_context().length; i++) {

wbimage[i] = new ImageView(this.homeActivity.getApplicationContext());

wbimage[i].setPadding(5, 5, 5, 5);

wbimage[i].setScaleType(ImageView.ScaleType.FIT_XY);

GridLayout.Spec row = GridLayout.spec(i / 3);

GridLayout.Spec colum = GridLayout.spec(i % 3);

GridLayout.LayoutParams params = new GridLayout.LayoutParams(row, colum);

params.setGravity(Gravity.FILL);

params.width = 250;

params.height = 250;

wb_image[i] = asyncImageLoader.loadDrawable(wb.getImage_context()[i],

wbimage[i], new AsyncImageLoader.ImageCallback() {

@Override

public void imageLoaded(Drawable imageDrawable, ImageView imageView, String imageUrl) {

imageView.setImageDrawable(imageDrawable);

}

});

wbimage[i].setImageDrawable(wb_image[i]);

layout.addView(wbimage[i], params);

}

}

//异步加载用户头像数据

Drawable cachedImage = asyncImageLoader.loadDrawable(wb.getUserIcon(), wh.wbicon, new AsyncImageLoader.ImageCallback() {

@Override

public void imageLoaded(Drawable imageDrawable, ImageView imageView, String imageUrl) {

imageView.setImageDrawable(imageDrawable);

}

});

if (cachedImage == null) {

} else {

wh.wbicon.setImageDrawable(cachedImage);

}

}

return convertView;

}

@Override

public int getCount() {

return this.weiboList.size();

}

@Override

public Object getItem(int position) {

return this.weiboList.get(position);

}

@Override

public long getItemId(int position) {

return position;

}

}

异步下载图片的方法。使用SoftReference是软引用,是为了系统更好的回收变量;从缓存中获取图片路径后,建立新一个新的线程下载图片。

**

* Created by D&LL on 2016/6/2.

*/

public class AsyncImageLoader {

//SoftReference是软引用,是为了更好的为了系统回收变量

private HashMap> imageCache;

public AsyncImageLoader() {

imageCache = new HashMap>();

}

public Drawable loadDrawable(final String imageUrl, final ImageView imageView, final ImageCallback imageCallback) {

if (imageCache.containsKey(imageUrl)) {

//从缓存中获取

SoftReference softReference = imageCache.get(imageUrl);

Drawable drawable = softReference.get();

if (drawable != null) {

return drawable;

}

}

final Handler handler = new Handler() {

public void handleMessage(Message message) {

imageCallback.imageLoaded((Drawable) message.obj, imageView, imageUrl);

}

};

//建立新一个新的线程下载图片

new Thread() {

@Override

public void run() {

Drawable drawable = loadImageFromUrl(imageUrl);

imageCache.put(imageUrl, new SoftReference(drawable));

Message message = handler.obtainMessage(0, drawable);

handler.sendMessage(message);

}

}.start();

return null;

}

public static Drawable loadImageFromUrl(String url) {

URL m;

InputStream i = null;

try {

m = new URL(url);

i = (InputStream) m.getContent();

} catch (MalformedURLException e1) {

e1.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

Drawable d = Drawable.createFromStream(i, "src");

return d;

}

//回调接口

public interface ImageCallback {

public void imageLoaded(Drawable imageDrawable, ImageView imageView, String imageUrl);

}

}

效果图:

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

Android新浪微博分页加载,Android仿新浪微博自定义ListView下拉刷新(4)相关推荐

  1. android中上拉下滑布局,3年以上勿进!最简单的Android自定义ListView下拉刷新与上拉加载,代码直接拿去用~...

    本文主要针对开发新手,手写实现一个最简单Android自定义listview下拉刷新和上拉加载demo. 不喜可喷,欢迎大佬留言指点. 效果图 一:编写需要在ListView中增加头加载的布局文件,与 ...

  2. 下拉刷新和上拉加载 php,基于iscroll.js实现下拉刷新和上拉加载效果

    现在已经不是纯Android独霸天下的时代了,H5嵌入Android的Hybrid混合开发是大势所趋.今天给大家带来的就是移动端中常见的"上拉刷新,下拉加载"特效,这个特效将会基于 ...

  3. vant实现下拉刷新和上拉加载_微信小程序 - 实现下拉刷新、上拉加载

    在小程序开发中使用下拉刷新和上拉加载非常多,比如常用的展示型首页,而实现这个功能有两种形式,第一种是使用 scroll-view 组件,第二种是不使用 scroll-view 组件而让整个页面刷新,那 ...

  4. Android模仿新浪微博(自定义ListView下拉刷新)

    自定义PullToRefreshListView继承ListView,在ListView头部添加一个下拉的头部布局.跟ListView用法完全一致. 该自定义Listview代码详解具体可参考: ht ...

  5. Flutter 21: 图解 ListView 下拉刷新与上拉加载 (三)【RefreshIndicator】

    小菜前段时间整理了两种 ListView 的异步加载数据时,下拉刷新与上滑加载更多的方式,每种方式都有自己的优势,网上也有很多大神讲解过 ListView 数据流的种种处理方式,小菜根据实际遇到的情况 ...

  6. android-ultra-pull-to-refresh list,[Android]Ultra-Pull-To-Refresh之listview下拉刷新、上拉加载的用例...

    前言 app中最常见的场景莫过于下拉刷新和自动加载的功能了,最经典的开源组件就是 本次demo的编辑环境为android studio,java1.8 截图 使用 1.本示例依赖jar如下: depe ...

  7. listview下拉刷新上拉加载扩展(二)-仿美团外卖

    经过前几篇的listview下拉刷新上拉加载讲解,相信你对其实现机制有了一个深刻的认识了吧,那么这篇文章我们来实现一个高级的listview下拉刷新上拉加载-仿新版美团外卖的袋鼠动画: 项目结构: 是 ...

  8. Android开发笔记(一百六十四)仿京东首页的下拉刷新

    上一篇文章介绍了高仿京东的沉浸式状态栏,可是跟京东首页的头部轮播图相比,依然有三处缺憾: 1.京东的头部Banner上方,除了有悬浮着的状态栏,状态栏下面还有一行悬浮工具栏,内嵌扫一扫图标.搜索框,以 ...

  9. listview下拉刷新上拉加载扩展(三)-仿最新版美团外卖

    本篇是基于上篇listview下拉刷新上拉加载扩展(二)-仿美团外卖改造而来,主要调整了headview的布局,并加了两个背景动画,看似高大上,其实很简单: as源码地址:http://downloa ...

最新文章

  1. 从配置说tomcat和nginx调优
  2. openresty nginx升级版
  3. 准确率不变 损失率下降_最新斯诺克排名奥沙利文排在第二,丁俊晖排第十,第一保持不变...
  4. Linux文件特殊权限、FACL、sudo
  5. SAP Spartacus central Travis build的lint环节
  6. 新起点!新征程!微软技术俱乐部(苏州)成立大会暨微软技术交流会
  7. 04-1.jQuery事件与补充each/data
  8. leetcode61 旋转链表
  9. STM32学习——ADC采集
  10. 专访谷歌医疗AI LilyPeng:吴恩达的医生“失业论”不妥
  11. Modeling Deformable Objects from a Single Depth Camera
  12. nuget 下载nupkg 以及依赖包
  13. 计算机如何取消自动关机,如何取消自动关机命令
  14. c语言十六进制字母,c语言读取十六进制文件
  15. unity材质球发光_Unity3D中使物体自发光
  16. 如何为word增加页码,且第一页不显示页码?
  17. Rokid Pebble若琪月石AI音响支持root
  18. 数据库应用(mysql)数据库编程
  19. Google Filament引擎编译记录
  20. Linux:NFS服务器

热门文章

  1. gcc与cuda的关系
  2. 计算机桌面维护介绍,电脑显示器的维护
  3. ​你在淘宝剁手,钱却可能进入黑客的口袋
  4. 打开HFSS出现Unable to detect installed products的报错,要求make sure that config/admin.xml exists
  5. Python安全工具编写-pcap流量包重放
  6. SPSS免费安装教程(详细版)
  7. java coverage_Java Coverage(Cobertura)工具
  8. [VCS]Coverage Options Introduction
  9. php去除英文和标点,php实现过滤中文标点符号及过滤英文标点符号的示例代码
  10. 等待输入超时:自动登出