图片加载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框架 ...
随机推荐
- js中数组的合并和对象的合并
1 数组合并 1.1 concat 方法 var a = [1,2,3], b = [4,5,6]; var c = a.concat(b); console.log(c);// 1,2,3,4,5, ...
- 64位windows2003 未在本地计算机上注册 microsoft.jet.oledb.4.0 提供程序
64位windows2003系统 使用 mdb数据库时候出现如下错误. 可能用office的一些比较旧的程序时候会这样. 未在本地计算机上注册 microsoft.jet.oledb.4.0 提供程序 ...
- zabbix web monitoring 监控网页
配置 Web 场景 配置 web 场景: 转到: 配置 (Configuration)–>主机 (或者 模板 ) 点击主机 (host)/ 模板 (template) 行中的 Web 点击右上角 ...
- d3系列2--api攻坚战02
<html> <head> <style type="text/css"> .area{ fill:steelblue; } </styl ...
- The TTY demystified
http://www.linusakesson.net/programming/tty/index.php The TTY demystified Real teletypes in the 1940 ...
- Hadoop 中的 ArrayWritable
虽然ArrayWritable不是接口,但貌似必须要子类去extends ArrayWritable,不能直接用ArrayWriable 否则会报下面的错误?(不是很确定) java.lang.Exc ...
- hdu - 5033 - Building(单调栈)
题意:N 幢楼排成一列(1<=N<=10^5),各楼有横坐标 xi(1<=xi<=10^7) 以及高度 hi(1<=hi<=10^7),在各楼之间的Q个位置(1&l ...
- MIC中函数和变量的声明
c++/c使用 __declspec(target(mic))函数或变量声明 或 __attribute__((target(mic)))函数或变量声明 举例如下: __attribute__((ta ...
- Oracle中NVL、NVL2、NULLIF 三个函数的区别?
首先说明:NULL指的是空值,或者非法值. 1.NVL (expr1, expr2)expr1为NULL,返回expr2:不为NULL,返回expr1.注意两者的类型要一致 2.NVL2 (expr1 ...
- CSS改变字体下划线颜色
下图是网页中一个非常普通的列表. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvQXVndXMzMzQ0/font/5a6L5L2T/fontsize/40 ...