图片加载ImageLoader
https://github.com/nostra13/Android-Universal-Image-Loader
public class AtguiguApplication extends Application { @Override public void onCreate() { super.onCreate(); //xUtils3初始化 x.Ext.init(this); // 是否输出debug日志, 开启debug会影响性能. x.Ext.setDebug(true); // 初始化Imageloader initImageloader(this); } private void initImageloader(Context context) { // 初始化参数 ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context) .threadPriority(Thread.NORM_PRIORITY - 2) // 线程优先级 .denyCacheImageMultipleSizesInMemory() // 当同一个Uri获取不同大小的图片,缓存到内存时,只缓存一个。默认会缓存多个不同的大小的相同图片 .discCacheFileNameGenerator(new Md5FileNameGenerator()) // 将保存的时候的URI名称用MD5 .tasksProcessingOrder(QueueProcessingType.LIFO) // 设置图片下载和显示的工作队列排序 .writeDebugLogs() // 打印debug log .build(); // 全局初始化此配置 ImageLoader.getInstance().init(config); } }
public class ImageloaderListviewActivity extends Activity { @Bind(R.id.tv_title) TextView tvTitle; @Bind(R.id.lv_imageloader) ListView lvImageloader; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_imageloader_listview); ButterKnife.bind(this); initData(); } private void initData() { // 初始化标题 tvTitle.setText("Imageloader应用在Listview中"); ImageloaderListviewAdapter imageloaderListviewAdapter = new ImageloaderListviewAdapter(this); lvImageloader.setAdapter(imageloaderListviewAdapter); } }
public class ImageloaderListviewAdapter extends BaseAdapter { private Context mContext; private final ImageLoader imageLoader; private DisplayImageOptions options = new DisplayImageOptions.Builder() .showStubImage(R.drawable.atguigu_logo) // 设置图片下载期间显示的图片 .showImageForEmptyUri(R.drawable.atguigu_logo) // 设置图片Uri为空或是错误的时候显示的图片 .showImageOnFail(R.drawable.atguigu_logo) // 设置图片加载或解码过程中发生错误显示的图片 .cacheInMemory(true) // 设置下载的图片是否缓存在内存中 .cacheOnDisk(true) // 设置下载的图片是否缓存在SD卡中 .displayer(new RoundedBitmapDisplayer(20)) // 设置成圆角图片 .build(); // 创建配置过得DisplayImageOption对象; public ImageloaderListviewAdapter(Context context) { mContext = context; // 初始化imageloader imageLoader = ImageLoader.getInstance(); } @Override public int getCount() { return Constants.IMAGES.length; } @Override public Object getItem(int position) { return Constants.IMAGES[position]; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { // 获取或创建viewhoder Viewholder holder; if(convertView == null) { convertView = View.inflate(mContext, R.layout.item_imageloader_listview, null); holder = new Viewholder(convertView); convertView.setTag(holder); }else { holder = (Viewholder) convertView.getTag(); } // 获取当前item数据 // 显示数据 holder.name.setText("item"+(position + 1)); imageLoader.displayImage(Constants.IMAGES[position],holder.iv,options); return convertView; } class Viewholder{ @Bind(R.id.iv_imageloader_listview) ImageView iv; @Bind(R.id.tv_imageloader_name) TextView name; public Viewholder(View view) { ButterKnife.bind(this,view); } } }
import android.app.Activity; import android.os.Bundle; import android.support.v4.view.ViewPager; import android.widget.TextView; import com.atguigu.android.R; import com.atguigu.android.imageloader.adapter.ImageloaderViewpagerAdapter; import butterknife.Bind; import butterknife.ButterKnife; public class ImageloaderViewpagerActivity extends Activity { @Bind(R.id.tv_title) TextView tvTitle; @Bind(R.id.vp_imageloader_viewpager) ViewPager vpImageloaderViewpager; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_imageloader_viewpager); ButterKnife.bind(this); initData(); } private void initData() { // 标题 tvTitle.setText("Imageloader应用在viewpager中"); // 初始化viewpager ImageloaderViewpagerAdapter imageloaderViewpagerAdapter = new ImageloaderViewpagerAdapter(this); vpImageloaderViewpager.setAdapter(imageloaderViewpagerAdapter); // 显示第一个条目 vpImageloaderViewpager.setCurrentItem(1); } } public class ImageloaderViewpagerAdapter extends PagerAdapter { private Context mContext; private final ImageLoader imageLoader; private DisplayImageOptions options = new DisplayImageOptions.Builder() .showImageForEmptyUri(R.drawable.atguigu_logo) // 设置图片Uri为空或是错误的时候显示的图片 .showImageOnFail(R.drawable.atguigu_logo) // 设置图片加载或解码过程中发生错误显示的图片 .resetViewBeforeLoading(true) // 设置图片在下载前是否重置,复位 .cacheOnDisc(true) // 设置下载的图片是否缓存在SD卡中 .imageScaleType(ImageScaleType.EXACTLY) // 设置图片以如何的编码方式显示 .bitmapConfig(Bitmap.Config.RGB_565) // 设置图片的解码类型 .displayer(new FadeInBitmapDisplayer(300)) // 设置图片渐变显示 .build(); ; public ImageloaderViewpagerAdapter(Context context) { mContext = context; // 初始化Imageloader imageLoader = ImageLoader.getInstance(); } @Override public Object instantiateItem(ViewGroup container, int position) { // 添加布局文件 View view = View.inflate(mContext, R.layout.item_imageloader_viewpager, null); // 获取控件对象 ImageView iv = (ImageView) view.findViewById(R.id.iv_imageloader_viewpager); // 显示图片 imageLoader.displayImage(Constants.IMAGES[position], iv, options); ((ViewPager) container).addView(view, 0); return view; } @Override public void destroyItem(ViewGroup container, int position, Object object) { ((ViewPager) container).removeView((View) object); } @Override public int getCount() { return Constants.IMAGES.length; } @Override public boolean isViewFromObject(View view, Object object) { return view.equals(object); } }
图片加载ImageLoader的更多相关文章
- Android中常见的图片加载框架
图片加载涉及到图片的缓存.图片的处理.图片的显示等.而随着市面上手机设备的硬件水平飞速发展,对图片的显示要求越来越高,稍微处理不好就会造成内存溢出等问题.很多软件厂家的通用做法就是借用第三方的框架进行 ...
- ImageLoader图片加载
http://blog.csdn.net/liu1164316159/article/details/38728259 转载请注明http://write.blog.csdn.net/po ...
- Android 三大图片加载框架的对比——ImageLoader,Picasso,Glide
一.ImageLaoder介绍 << Universal ImageLoader 是很早开源的图片缓存,在早期被很多应用使用 多线程下载图片,图片可以来源于网络,文件系统,项目文件夹ass ...
- 主流图片加载框架 ImageLoader、Glide、Picasso、Fresco 对比
图片缓存库主页: Glidehttps://github.com/bumptech/glide fresco - An Android library for managing images and ...
- 【光速使用开源框架系列】图片加载框架ImageLoader
[关于本系列] 最近看了不少开源框架,网上的资料也非常多,但是我认为了解一个框架最好的方法就是实际使用.本系列博文就是带领大家快速的上手一些常用的开源框架,体会到其作用. 由于作者水平有限,本系列只会 ...
- 图片加载框架之ImageLoader
Android开发中,多少会接触到异步加载图片,或者加载大量图片的问题,而加载图片我们常常会遇到许多的问题,比如说图片的错乱,OOM等问题,对于这些问题解决起来会比较吃力,比较著名的就是Univers ...
- 14. Android框架和工具之 ImageLoader(图片加载)
1. 这个图片加载框架网友很多都已经使用过,而且分析也很到位,这里我就不写了,直接引用别人,尊重别人的劳动成果. 2. 参考如下: (1)Android 开源框架Universal-Image-Loa ...
- Android图片加载神器之Fresco-加载图片基础[详细图解Fresco的使用](秒杀imageloader)
Fresco简单的使用—SimpleDraweeView 百学须先立志—学前须知: 在我们平时加载图片(不管是下载还是加载本地图片…..)的时候,我们经常会遇到这样一个需求,那就是当图片正在加载时应该 ...
- 强大的图片加载框架Fresco的使用
前面在卓新科技有限公司实习的时候,在自己的爱吖头条APP中,在图片异步加载的时候和ListView的滑动中,总会出现卡顿,这是因为图片的缓存做的不是足够到位,在项目监理的帮助下,有使用Xutils框架 ...
随机推荐
- STL学习笔记(非变动性算法)
辅助函数 本节跟以后几节将对所有STL算法逐一详细讨论.为了简化这些例子,我们使用了一些辅助函数,分别用于对容器进行输出跟插入操作. #ifndef ALGOSTUFF_HPP #define ALG ...
- Shell脚本之:函数
Shell 也支持函数.Shell函数必须先定义后使用. 函数的定义与调用 Shell 函数的定义格式如下: function_name () { list of commands [ return ...
- win7不休眠方式设置
方式1:命令行下以管理员方式执行:powercfg -h off 方式2:右键个性化-->屏幕保护程序-->更改电源设置--->更改计算机睡眠时间--->是计算机进入睡眠状态选 ...
- java统计中英文字数 Java问题通用解决代码
http://yangchao20020.blog.163.com/blog/static/483822472011111635424751/ 这个不适用于新浪微博字数的统计,结果有差别,若需要可 ...
- BNU 34990 Justice String (hash+二分求LCP)
思路:枚举第一个字符串的位置,然后枚举最长公共前缀的长度,时间即会下降-- #pragma comment(linker, "/STACK:1024000000,1024000000&quo ...
- golang之路:mac下安装go
1.下载dkg包 2.安装 3.vim .bash_profile export GOROOT=/usr/local/goexport GOPATH=$HOME/GoglandProjects/Pro ...
- PHP之十六个魔术方法详细介绍
PHP中把以两个下划线__开头的方法称为魔术方法(Magic methods),这些方法在PHP中充当了举足轻重的作用.这里进行详细介绍,感兴趣的小伙伴们可以参考一下. PHP中把以两个下划线__开头 ...
- eureka集群高可用配置,亲测成功配置(转)
转自大神的文章:https://blog.csdn.net/tianyaleixiaowu/article/details/78184793 网上讲这个东西的很多,抄来抄去的,大部分类似,多数没讲明白 ...
- mysql 集合函数与where条件
这里要查询的是去过的国家数(country)的次数ct大于2的人的名字 select name ,count(country) ct from sz03 where ct >2 group by ...
- 对LCD接口的认识
LCD接口类型: 1.首先我们以传递的信号类型来区分主要有两大类:- 模拟信号: - VGA: Video Graphics Array- 数字信号 - TTL: Transistor Transis ...