全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android使用开源框架Fresco处理图片

关于Fresco的优点大家自行谷歌吧,它太强大太优秀了,我这一片小博文容纳不下啊羡慕,今天主要给大家简单介绍下Fresco的使用以及一些属性的介绍。

 Fresco是一个强大的图片加载组件。使用它之后,你不需要再去关心图片的加载和显示这些繁琐的事情!支持Android2.3及以后的版本。

官网详细介绍了Fresco一些特性,我第一次看确实是惊呆了。https://www.fresco-cn.org/

2016年Fresco的最新的源码分析:https://github.com/desmond1121/Fresco-Source-Analysis

简述与其他常用图片缓存框架的比较

(1)Volley提供了一个新的控件NetworkImageView来代替传统的ImageView如果你的工程项目,是一个比较小的项目,或者要求不是很高的项目,处理比较简单的可以使用这个库,这个库是Google 2013 I/O发布的一个开源库。使用这个库在图片的处理上,没有提供任何的图片处理的操作,用于细粒度的数据连接还是可以的。

(2)Universal-Image-Loader是比较早的一个图片缓存组件,也一直受到开发者的推崇,在很多老的应用中使用。

(3)Picasso与Glide,无疑Glide胜出

(4)而Fresco作为新秀,不管从内存管理(三级缓存),图片的渐进式呈现,Gif图和Webp格式图像的加载,都是非常突出。(也是我最喜欢用的)

涉及的常用基本属性介绍

(1)layout_width和layout_height不支持warp_Content但是可以通过setAspectRetio();来设置宽高比

(2)fadeDuration()淡出时间;

(3)actualImageScaleType 设置图片缩放,通常使用foucsCrop,该属性值会通过算法把人头像放在中间

(4)placeholderImage下载成功之前显示的图片placeholderImageScaleType

(5)failureImage加载失败时显示的图片faiturelmagescateType

(6)retrylmage加载失败,提示用户点击重新加载的图片retrylmagescateType

(7)progressBarImage提示用户正在加载,和进度无关progressBarlmagescateType

(8)progressBarAutoRotateInterval图片自动旋转的时间间隔

(9)backgroundImage背景

(10)overlayImage叠加图

(11)pressedStateOverlayImage按下时候的叠加图

(12)roundAsCircle是否涉及圆圈

(13)roundedCornerRadius圆角

(14)roundTopLeft、roundTopRight…..分别设置4个角不同半径,设置为true以后可以在代码中通过RoundingParams的setConnersRadii()方法设置角度。

(15)roundWithOverlayColor边框的叠加颜色

(16)roundingBorderWidth边框宽度

(17)roundingBorderColor边框颜色

下面我们简单演示使用Fresco加载网络图片的流程:
演示效果如下(你们猜对了,又是本人的玉照安静):

第一步:导依赖包

与之前的android-image-indicator-master项目相同,本次依然使用AndroidStudio2.2。仍然采用在build.gradle下中dependencies下直接添加如下代码:

compile 'com.facebook.fresco:fresco:0.12.0'

同时可以根据个人项目需求添加如下依赖:

dependencies {
  // 在 API < 14 上的机器支持 WebP 时,需要添加
  compile 'com.facebook.fresco:animated-base-support:0.12.0'
  // 支持 GIF 动图,需要添加
  compile 'com.facebook.fresco:animated-gif:0.12.0'
  // 支持 WebP (静态图+动图),需要添加
  compile 'com.facebook.fresco:animated-webp:0.12.0'
  compile 'com.facebook.fresco:webpsupport:0.12.0'
  // 仅支持 WebP 静态图,需要添加
  compile 'com.facebook.fresco:webpsupport:0.12.0'
}

第二步:添加网络权限

因为是加载网络图片所以必须在 AndroidManifest.xml配置文件中添加网络权限:

<uses-permission android:name="android.permission.INTERNET"/>

第三步:初始化Fresco类

在加载图片之前,你必须初始化Fresco类。你只需要调用Fresco.initialize一次即可完成初始化,下面分别介绍在MainActivity与Application中调用初始化方法

(1)在Application调用初始化(建议使用)

[MyApplication.java]
public class MyApplication extends Application {
  @Override
  public void onCreate() {
    super.onCreate();
    Fresco.initialize(this);
  }
}

做完上面的工作后,需要在 AndroidManifest.xml 中指定 Application 类。

(2)在MainActivity中调用初始化

需要注意的是要在setContentView之前初始化

package com.mly.panhouye.frescodemo;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import com.facebook.drawee.backends.pipeline.Fresco;
public class MainActivity extends AppCompatActivity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Fresco.initialize(this);//需要在setContentView之前初始化
    setContentView(R.layout.activity_main);
  }
}

第四步:layout中的xml布局文件

在布局之前需要在xml文件中加入命名空间

xmlns:fresco="http://schemas.android.com/apk/res-auto"

具体布局文件如下,本次演示通过按钮点击出发图片加载,使用SimpleDraweeView(注意:layout_width/height不支持wrap_content):

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  xmlns:fresco="http://schemas.android.com/apk/res-auto"
  android:id="@+id/activity_main"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.mly.panhouye.frescodemo.MainActivity">
  <Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/my_image_view"
    android:layout_centerHorizontal="true"
    android:text="加载网络图片"
    android:onClick="loadInternetImage"
    android:layout_marginTop="12dp"
    android:id="@+id/button" />
  <com.facebook.drawee.view.SimpleDraweeView
    android:id="@+id/my_image_view"
    android:layout_width="400dp"
    android:layout_height="400dp"
    fresco:placeholderImage="@mipmap/ic_launcher"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true" />
</RelativeLayout>

第五步:java实现代码

package com.mly.panhouye.frescodemo;
import android.net.Uri;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.drawee.view.SimpleDraweeView;
public class MainActivity extends AppCompatActivity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Fresco.initialize(this);//需要在setContentView之前初始化
    setContentView(R.layout.activity_main);
  }
  //点击事件加载网络图片代码
  public void loadInternetImage(View view){
    Uri uri = Uri.parse("http://r.photo.store.qq.com/psb?/V12kkHqD1CWRD4/MeykWt0NXu0stiBFzf378D7ajKSDet6k1.Vaqmq2vps!/r/dKMAAAAAAAAA");
    SimpleDraweeView draweeView = (SimpleDraweeView) findViewById(R.id.my_image_view);
    draweeView.setImageURI(uri);
  }
}

剩下的,Fresco会替你完成,比如:显示占位图直到加载完成;下载图片;缓存图片;图片不再显示时,从内存中移除等等等等。

 本文仅仅介绍了Fresco最基本的使用方法,大家伙可以访问官网来尝试其他功能实现。

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


# Android  # FRESCO  # 开源框架  # Android Fresco图片加载优化的方案  # 详解Android之图片加载框架Fresco基本使用(二)  # 详解Android之图片加载框架Fresco基本使用(一)  # 详细分析Fresco源码之图片加载流程  # 加载  # 是一个  # 不支持  # 使用这个  # 官网  # 的是  # 都是  # 放在  # 又是  # 我这  # 要在  # 你不  # 很高  # 最喜欢  # 可以通过  # 给大家  # 详细介绍  # 再去  # 按下  # 较小 


相关文章:   浅谈Javascript中的Label语句  已有域名如何免费搭建网站?  网站制作软件有哪些,制图软件有哪些?  学校为何禁止电信移动建设网站?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  建站之星在线版空间:自助建站+智能模板一键生成方案  利用JavaScript实现拖拽改变元素大小  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  成都网站制作报价公司,成都工业用气开户费用?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  电商平台网站制作流程,电商网站如何制作?  b2c电商网站制作流程,b2c水平综合的电商平台?  建站之星如何开启自定义404页面避免用户流失?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  网站制作服务平台,有什么网站可以发布本地服务信息?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  网站制作报价单模板图片,小松挖机官方网站报价?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  建站主机选购指南:核心配置优化与品牌推荐方案  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  建站之星安装提示数据库无法连接如何解决?  如何在Golang中指定模块版本_使用go.mod控制版本号  建站之星备案流程有哪些注意事项?  如何通过西部建站助手安装IIS服务器?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  建站主机服务器选购指南:轻量应用与VPS配置解析  建站为何优先选择香港服务器?  建站之星图片链接生成指南:自助建站与智能设计教程  如何在腾讯云服务器快速搭建个人网站?  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何选择域名并搭建高效网站?  如何选择可靠的免备案建站服务器?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  如何彻底删除建站之星生成的Banner?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  公司门户网站制作流程,华为官网怎么做?  如何高效完成独享虚拟主机建站?  油猴 教程,油猴搜脚本为什么会网页无法显示?  如何通过商城免费建站系统源码自定义网站主题?  php json中文编码为null的解决办法  如何在万网自助建站中设置域名及备案?  如何选择建站程序?包含哪些必备功能与类型? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。