Android图片加载库:最全面的Picasso讲解

hadescen 8年前
   <p style="text-align:center"><img src="https://simg.open-open.com/show/374f635f21e2f63ee1efd57bf0db81f2.png"></p>    <h2><strong>前言</strong></h2>    <ul>     <li> <p>上文已经对当今 <strong>Android主流的图片加载库</strong> 进行了全面介绍 & 对比</p> <p>如果你还没阅读,我建议你先移步这里阅读</p> </li>     <li> <p>今天我们来学习其中一个Android主流的图片加载库的使用 - Picasso</p> </li>    </ul>    <h2><strong>目录</strong></h2>    <p style="text-align:center"><img src="https://simg.open-open.com/show/d3a309d68b7f2f47ad0ecd4964391dc8.png"></p>    <p style="text-align:center">目录</p>    <h2><strong>1. 简介</strong></h2>    <ul>     <li> <p>介绍:Picasso,可译为“毕加索”,是Android中一个图片加载开源库</p> <p>大概是因为其使用使用方法简单、优雅所以这样取名</p> </li>     <li> <p>主要作用:实现图片加载</p> </li>    </ul>    <h2><strong>2. 功能特点</strong></h2>    <h3><strong>2.1 功能列表</strong></h3>    <p style="text-align:center"><img src="https://simg.open-open.com/show/be8f6fab4074b4cdec48455d0ea637c1.png"></p>    <p style="text-align:center">功能列表</p>    <ul>     <li> <p>从上面可以看出,Picasso不仅实现了图片异步加载的功能,还解决了Android中加载图片时需要解决的一些常见问题</p> </li>     <li> <p>接下来,我会对Picasso的每个功能点进行详细的介绍</p> </li>    </ul>    <h3><strong>2.2 功能介绍</strong></h3>    <p>2.2.1 图片的异步加载(最基础功能)</p>    <pre>  <code class="language-java">ImageView targetImageView = (ImageView) findViewById(R.id.ImageView);          String Url = "http://218.192.170.132/1.jpg";    //Picasso使用了流式接口的调用方式  //Picasso类是核心实现类。  //实现图片加载功能至少需要三个参数:          Picasso  //with(Context context)  //Context对于很多Android API的调用都是必须的,这里就不多说了                  .with(context)    //load(String imageUrl):被加载图像的Url地址。  //大多情况下,一个字符串代表一个网络图片的URL。                  .load(Url)    //into(ImageView targetImageView):图片最终要展示的地方。                  .into(targetImageView);</code></pre>    <p>2.2.2 图片转换</p>    <p>使用最少的内存完成复杂的图片转换,转换图片以适合所显示的ImageView,来减少内存消耗</p>    <pre>  <code class="language-java">Picasso.with(context)    .load(url)  //裁剪图片尺寸    .resize(50, 50)  //设置图片圆角    .centerCrop()    .into(imageView)</code></pre>    <p>2.2.3 加载过重 & 错误处理</p>    <p>Picasso支持加载过程中和加载错误时显示对应图片</p>    <pre>  <code class="language-java">Picasso.with(context)      .load(url)  //加载过程中的图片显示      .placeholder(R.drawable.user_placeholder)  //加载失败中的图片显示  //如果重试3次(下载源代码可以根据需要修改)还是无法成功加载图片,则用错误占位符图片显示。      .error(R.drawable.user_placeholder_error)      .into(imageView);</code></pre>    <p>2.2.4 在Adapter中的回收不在视野的ImageView和取消已经回收的ImageView下载进程</p>    <pre>  <code class="language-java">@Override   public void getView(int position, View convertView, ViewGroup parent) {    SquaredImageView view = (SquaredImageView) convertView;    if (view == null) {      view = new SquaredImageView(context);    }    String url = getItem(position);      Picasso.with(context).load(url).into(view);  }</code></pre>    <p>2.2.5 从不同资源源加载</p>    <p>支持多种数据源 网络、本地、资源、Assets 等</p>    <pre>  <code class="language-java">//加载资源文件  Picasso.with(context).load(R.drawable.landing_screen).into(imageView1);  //加载本地文件  Picasso.with(context).load(new File("/images/oprah_bees.gif")).into(imageView2);</code></pre>    <p>2.2.6 自动添加磁盘和内存二级缓存功能</p>    <p>2.2.7 支持优先级处理</p>    <p>每次任务调度前会选择优先级高的任务,比如 App 页面中 Banner 的优先级高于 Icon 时就很适用。</p>    <p>2.2.8 支持飞行模式、并发线程数根据网络类型而变</p>    <p>手机切换到飞行模式或网络类型变换时会自动调整线程池最大并发数,比如 wifi 最大并发为 4, 4g 为 3,3g 为 2</p>    <p>2.2.9 “无”本地缓存</p>    <p>无”本地缓存,不是说没有本地缓存,而是 Picasso 自己没有实现,交给了 Square 的另外一个网络库 okhttp 去实现,这样的好处是可以通过请求 Response Header 中的 Cache-Control 及 Expired 控制图片的过期时间。</p>    <h2><strong>3. Demo实例</strong></h2>    <p>没有Demo的代码讲解不是好文章,让我们来一步步学会使用Picasso。</p>    <p>步骤1:在gradle添加依赖</p>    <pre>  <code class="language-java">compile 'com.squareup.picasso:picasso:2.5.2'</code></pre>    <p>步骤2:添加网络权限</p>    <pre>  <code class="language-java"><uses-permission android:name="android.permission.INTERNET"/></code></pre>    <p>步骤1和步骤2是Picasso使用的前提,千万别忘了!!!!</p>    <p>步骤3:在MainActivity中</p>    <pre>  <code class="language-java">ImageView targetImageView = (ImageView) findViewById(R.id.ImageView);          String Url = "http://218.192.170.132/1.jpg";            Picasso                  .with(this)                  .load(Url)                  .into(targetImageView);</code></pre>    <p>还有具体其他功能需要配置的自己按照我上面写的进行配置就好了~</p>    <p>这里再贴上Picasso的Github地址: <a href="/misc/goto?guid=4958972548258164558" rel="nofollow,noindex">请点击这里</a></p>    <h2><strong>4. 特点</strong></h2>    <h3><strong>4.1 优点</strong></h3>    <ul>     <li> <p>使用简单、方便(一行代码的事情)</p> </li>     <li> <p>由于同样是出品自Square的,Square 公司的其他开源库如 Retrofit 或者 OkHttp和Picasso搭配使用兼容性会更好些,占用体积也会少些</p> <p>所以,如果项目已经使用了 Square 公司的其他开源库(如 Retrofit 或者 OkHttp),在满足需求的前提下建议使用Picasso</p> </li>    </ul>    <h3><strong>4.2 缺点</strong></h3>    <ul>     <li> <p>功能较为简单-图片加载;</p> </li>     <li> <p>性能(加载速度等等)较其他图片加载库(Glide、Fresco)较差</p> </li>     <li> <p>自身无实现“本地缓存”</p> </li>    </ul>    <p> </p>    <p> </p>    <p>来自:http://www.jianshu.com/p/51dc758b52f9</p>    <p> </p>