Android新浪微博分页加载,Android仿新浪微博自定义ListView下拉刷新(4)
自定义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)相关推荐
- android中上拉下滑布局,3年以上勿进!最简单的Android自定义ListView下拉刷新与上拉加载,代码直接拿去用~...
本文主要针对开发新手,手写实现一个最简单Android自定义listview下拉刷新和上拉加载demo. 不喜可喷,欢迎大佬留言指点. 效果图 一:编写需要在ListView中增加头加载的布局文件,与 ...
- 下拉刷新和上拉加载 php,基于iscroll.js实现下拉刷新和上拉加载效果
现在已经不是纯Android独霸天下的时代了,H5嵌入Android的Hybrid混合开发是大势所趋.今天给大家带来的就是移动端中常见的"上拉刷新,下拉加载"特效,这个特效将会基于 ...
- vant实现下拉刷新和上拉加载_微信小程序 - 实现下拉刷新、上拉加载
在小程序开发中使用下拉刷新和上拉加载非常多,比如常用的展示型首页,而实现这个功能有两种形式,第一种是使用 scroll-view 组件,第二种是不使用 scroll-view 组件而让整个页面刷新,那 ...
- Android模仿新浪微博(自定义ListView下拉刷新)
自定义PullToRefreshListView继承ListView,在ListView头部添加一个下拉的头部布局.跟ListView用法完全一致. 该自定义Listview代码详解具体可参考: ht ...
- Flutter 21: 图解 ListView 下拉刷新与上拉加载 (三)【RefreshIndicator】
小菜前段时间整理了两种 ListView 的异步加载数据时,下拉刷新与上滑加载更多的方式,每种方式都有自己的优势,网上也有很多大神讲解过 ListView 数据流的种种处理方式,小菜根据实际遇到的情况 ...
- android-ultra-pull-to-refresh list,[Android]Ultra-Pull-To-Refresh之listview下拉刷新、上拉加载的用例...
前言 app中最常见的场景莫过于下拉刷新和自动加载的功能了,最经典的开源组件就是 本次demo的编辑环境为android studio,java1.8 截图 使用 1.本示例依赖jar如下: depe ...
- listview下拉刷新上拉加载扩展(二)-仿美团外卖
经过前几篇的listview下拉刷新上拉加载讲解,相信你对其实现机制有了一个深刻的认识了吧,那么这篇文章我们来实现一个高级的listview下拉刷新上拉加载-仿新版美团外卖的袋鼠动画: 项目结构: 是 ...
- Android开发笔记(一百六十四)仿京东首页的下拉刷新
上一篇文章介绍了高仿京东的沉浸式状态栏,可是跟京东首页的头部轮播图相比,依然有三处缺憾: 1.京东的头部Banner上方,除了有悬浮着的状态栏,状态栏下面还有一行悬浮工具栏,内嵌扫一扫图标.搜索框,以 ...
- listview下拉刷新上拉加载扩展(三)-仿最新版美团外卖
本篇是基于上篇listview下拉刷新上拉加载扩展(二)-仿美团外卖改造而来,主要调整了headview的布局,并加了两个背景动画,看似高大上,其实很简单: as源码地址:http://downloa ...
最新文章
- 从配置说tomcat和nginx调优
- openresty nginx升级版
- 准确率不变 损失率下降_最新斯诺克排名奥沙利文排在第二,丁俊晖排第十,第一保持不变...
- Linux文件特殊权限、FACL、sudo
- SAP Spartacus central Travis build的lint环节
- 新起点!新征程!微软技术俱乐部(苏州)成立大会暨微软技术交流会
- 04-1.jQuery事件与补充each/data
- leetcode61 旋转链表
- STM32学习——ADC采集
- 专访谷歌医疗AI LilyPeng:吴恩达的医生“失业论”不妥
- Modeling Deformable Objects from a Single Depth Camera
- nuget 下载nupkg 以及依赖包
- 计算机如何取消自动关机,如何取消自动关机命令
- c语言十六进制字母,c语言读取十六进制文件
- unity材质球发光_Unity3D中使物体自发光
- 如何为word增加页码,且第一页不显示页码?
- Rokid Pebble若琪月石AI音响支持root
- 数据库应用(mysql)数据库编程
- Google Filament引擎编译记录
- Linux:NFS服务器
热门文章
- gcc与cuda的关系
- 计算机桌面维护介绍,电脑显示器的维护
- ​你在淘宝剁手,钱却可能进入黑客的口袋
- 打开HFSS出现Unable to detect installed products的报错,要求make sure that config/admin.xml exists
- Python安全工具编写-pcap流量包重放
- SPSS免费安装教程(详细版)
- java coverage_Java Coverage(Cobertura)工具
- [VCS]Coverage Options Introduction
- php去除英文和标点,php实现过滤中文标点符号及过滤英文标点符号的示例代码
- 等待输入超时:自动登出