美文网首页
Fresco源码分析思路整理

Fresco源码分析思路整理

作者: TeekTon | 来源:发表于2016-09-01 15:05 被阅读649次

1、关于Fresco

Fresco是FaceBook开源的一个图片加载组建,关于它的好处和如何使用这里就不再叙述了,相信大家都已经体验过了。如何不知道或者没用过,那你就out啦,赶紧去Fresco文档看看吧。


2、为什么写这篇文章

最近比较闲,于是打算看看一些开源项目的源码,因为项目中有用到Fresco,于是决定拿出源码看看。但是打开源码就懵逼了,太tm复杂了,怎么办看不懂。看不懂怎么办呢?咱也不是遇到困难就随便放弃的,网上资源那么多,先看看有没有其他人分析过,先借鉴一下。于是找到了一位大神的Fresco源码分析系列文章,写得很好分析也很详细。于是跟着作者的思路一起来看源码,但是在看的过程中发现老是会迷失在代码中,虽然最终也是慢慢一点一点的把整个流程给分析完了。这个时候我就在想怎么才能提高阅读源码的效率呢?给出一些我的看法,我觉得看源码一定要画图,UML图和流程图,借助这些图形我们可以很容易的看清楚整体情况,在阅读源码的时候才不容易迷失。所以本文也只是梳理一下Fresco源码分析的流程,关于具体的细节大家可以结合上文提到的文章。


3、关于DraweeView、DraweeHierarchy、DraweeController的关系

先给出一个UML图,下面我们将根据这个图来分析三者的关系。注意:图中只是给出了部分重要发方法和变量,并未全部罗列。


Fresco部分类的UML图

DraweeView、DraweeHierarchy、DraweeController是按照MVC的模式来进行设计,其中DraweeView是View负责绘制图片,DraweeHierarchy是Model提供绘制的drawable,而DraweeController是Controller负责图片的下载和处理等逻辑,我们使用Fresco只需要直接使用SimpleDraweeView即可,关于其细节都被隐藏了,这就是这个组建的强大之处。通过UML图我们可以清楚的知道DraweeView通过DraweeHolder持有了一个DraweeHierarchy和一个DraweeController。好的关于它们三者的关系暂时分析到这里,一些详细的分析大家可以去看上面提到的文章。


4、Fresco从网络获取图片到显示的流程分析

这里写图片描述

相关文章

  • Fresco源码分析思路整理

    1、关于Fresco Fresco是FaceBook开源的一个图片加载组建,关于它的好处和如何使用这里就不再叙述了...

  • Fresco源码分析-Fresco初始化

    本文为分析Fresco源码第一篇,基于fresco 1.8.1。 Fresco官网对于Fresco设计的基本概述 ...

  • Fresco图片显示原理浅析

    (第一篇)Fresco架构设计赏析 (第二篇)Fresco缓存架构分析 本文是Fresco源码分析系列第三篇文章,...

  • Fresco架构设计赏析

    本文是Fresco源码分析系列的开篇,主要分析Fresco的整体架构、各个组成模块的功能以及图片加载流程,希望通过...

  • 2019Android面试Fresco架构详解

    本文是Fresco源码分析系列的开篇,主要分析Fresco的整体架构、各个组成模块的功能以及图片加载流程,希望通过...

  • Fresco源码分析之Controller

    如果你是第一次看我的Fresco的源码分析系列文章,这里强烈推荐你先阅读我的前面两篇文章Fresco源码分析之Dr...

  • Fresco缓存设计分析

    (第一篇)Fresco架构设计赏析 本文是Fresco源码分析系列第二篇文章,主要来看一下Fresco中有关图片缓...

  • Fresco源码分析-BitmapMemoryCacheProd

    前面几节大致了解了Fresco中的Producer,并分析了NetworkFetchProducer。接下来就大致...

  • Fresco源码分析(二)

    先看Imagepipeline: Image pipeline 负责完成加载图像,变成Android设备可呈现的形...

  • Fresco源码分析(一)

    Fresco学习中文地址:Fresco中文学习 Fresco Javadoc地址:Javadoc Fresco初始...

网友评论

      本文标题:Fresco源码分析思路整理

      本文链接:https://www.haomeiwen.com/subject/upocettx.html