Android开源框架之Fresco

简介

Fresco是Facebook最新推出的一款用于Android应用中展示图片的强大图片库,可以从网络、本地存储和本地资源中加载图片。相对于ImageLoader,拥有更快的图片下载速度以及可以加载和显示gif图等诸多优势,是个很好的图片框架。

特点

  • 内存管理:在5.0以下系统,Fresco将图片放到一个特别的内存区域。当然,在图片不显示的时候,占用的内存会自动被释放。这会使得APP更加流畅,减少因图片内存占用而引发的OOM。 内存分配采用:系统匿名共享内存。
  • 共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式。两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以。
  • 渐进式呈现图片:渐进式图片格式先呈现大致的图片轮廓,然后随着图片下载的继续, 呈现逐渐清晰的图片,这对于移动设备,尤其是慢网络有极大的利好,可带来更好的用户体验。支持加载Gif图,支持WebP格式。
  • 图像的呈现:
    1.自定义居中焦点(对人脸等图片显示非常有帮助)。
    2.圆角图,当然圆圈也行。
    3.下载失败之后,点击重新下载。
    4.自定义占位图,自定义overlay,或者进度条。
    5.指定用户按压时的overlay。
  • 图像的加载:
    1.为同一个图片指定不同的远程路径,或者使用已经存在本地缓存中的图片。
    2.先显示一个低解析度的图片,等高清图下载完之后再显示高清图。
    3.加载完成回调通知。
    4.对于本地图,如有EXIF缩略图,在大图加载完成之前,可先显示缩略图。
    5.缩放或者旋转图片。
    6.处理已下载的图片。

下载地址

  • https://github.com/facebook/fresco
  • 官方使用网址:http://fresco-cn.org/docs/index.html(里面有一些案例,可以参考)

支持的URI

  • 远程图片 http://,https://
  • 本地文件 file://
  • Content provider content://
  • asset目录下的资源 asset://
  • res目录下的资源 res://
  • Uri中指定图片数据 data:mime/type;base64

常用API

在这里插入图片描述
在这里插入图片描述

使用步骤

  • 添加依赖
dependencies {
    
    
  // 在 API < 14 上的机器支持 WebP 时时,需要添加
  compile 'com.facebook.fresco:animated-base-support:0.14.1'
  // 支持 GIF 动图时,需要添加
  compile 'com.facebook.fresco:animated-gif:0.14.1'
  // 支持 WebP (静态图+动图)时,需要添加
  compile 'com.facebook.fresco:animated-webp:0.14.1'
  compile 'com.facebook.fresco:webpsupport:0.14.1'
  // 仅支持 WebP 静态图时,需要添加
  compile 'com.facebook.fresco:webpsupport:0.14.1'
  //这个必须要添加
  compile 'com.facebook.fresco:fresco:0.14.1'
}
  • 在application中初始化Fresco
Fresco.initialize(this);
  • 配置网络权限
<uses-permission android:name="android.permission.INTERNET"/>
  • 在xml布局文件中,加入命名空间
<!-- 其他元素-->
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:fresco="http://schemas.android.com/apk/res-auto"

    android:layout_height="match_parent"
    android:layout_width="match_parent">
  • 在xml文件中引入SimpleDraweeView
<com.facebook.drawee.view.SimpleDraweeView
    android:id="@+id/my_image_view"
    android:layout_width="130dp"
    android:layout_height="130dp"

    fresco:placeholderImage="@drawable/my_drawable"
  />
  • 在java文件中开始加载图片
//举例如下:
Uri uri = Uri.parse("https://raw.githubusercontent.com/facebook/fresco/gh-pages/static/logo.png");
SimpleDraweeView draweeView = (SimpleDraweeView) findViewById(R.id.my_image_view);
draweeView.setImageURI(uri);

在这里插入图片描述
Demo地址:https://github.com/hzulwy/private-project/blob/master/src.rar

猜你喜欢

转载自blog.csdn.net/qq_36828822/article/details/104087877