Android项目重构实践:从 Fresco 到 Glide 低成本重构方案

作者:ImWiki

Fresco 是一个***性很重的框架,如果使用 Fresco 我们的ImageView都要替换为 SimpleDraweeView,如果使用自定义ImageView,就非常麻烦。虽然 SimpleDraweeView 提供了非常丰富的功能,比如圆角,边框等,但有时候会出现非常奇怪的布局异常。在5.0版本以前 Fresco 可以有效降低 OOM,但是现在已经没有优势了,所以项目计划从 Fresco 替换为 Glide。

Fresco 缺点

  • 包太大。
  • 容易出现未知布局错误。
  • ***性太强,必须使用Fresco的View控件。

替换分析

由于项目中大量使用了SimpleDraweeView来实现布局,而且SimpleDraweeView提供了丰富的圆角、圆形、边框等。修改整个项目的布局代码也不现实,所以我们需要创一个包名、属性名称和SimpleDraweeView都一样的View,提供相同的功能,这样就可以大大降低替换成本。但是这个SimpleDraweeView不是全功能的,因为完全模仿成本太高,所以我们需要去掉 setImageRequest(ImageRequest request)和 getControllerBuilder() 这些调用方法,只提供通用的调用方法和属性。

自定义替换控件

我已经封装好了替换方案 ImageViewEx,可以直接引入工程。

api 'com.taoweiji:SimpleDraweeView:0.9.5'

自定义 RoundedCornerDrawable

我们实际上可以直接在ImageView.onDraw的方法中绘制图片,但是通过自定义 Drawable 可以让组件可控性更好,也可以复用。由于绘制比较复杂,这里就不一一介绍,请直接浏览我的Github代码。

自定义 ImageViewExBase

创建一个抽象的基础ImageView类,用于承载圆角、边框等功能。

自定义 ImageViewEx

继承ImageViewExBase,这个是用来替换SimpleDraweeView的,后续我们新写的代码还是尽量不要使用SimpleDraweeView,使用ImageViewEx代替。

自定义 SimpleDraweeView

这个类是关键,也是继承ImageViewExBase,功能和ImageViewEx是一样的,只是XML的属性是延续Fresco的,包名必须是 com.facebook.drawee.view,并且xml的属性也必须和Fresco是一致的。需要重写 setImageURI(Uri uri),使用回调方式让开发者实现图片显示。

《Android项目重构实践:从 Fresco 到 Glide 低成本重构方案》

设置 LoadHandler

class MyApplication : Application() {
 override fun onCreate() {
 super.onCreate()
 SimpleDraweeView.setLoadHandler { imageView, url ->
 // TODO 实现图片显示
 }
 }
}

说明

提供的 com.facebook.drawee.view.SimpleDraweeView 的属性是支持全部的 Fresco 属性,但是功能不是全部支持,替换之后需要深度的测试,避免有错误。

开源项目地址

https://github.com/taoweiji/ImageViewEx

Android学习PDF+架构视频+面试文档+源码笔记

感谢大家能耐着性子看完

在这里小编也分享一份自己收录整理的Android学习PDF+架构视频+面试文档+源码笔记,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习

如果你有需要的话,可以点赞+评论关注我,然后加我VX:15388039515 我发给你
(或关注微信公众号“Android开发之家”回复【资料】免费领取)
《Android项目重构实践:从 Fresco 到 Glide 低成本重构方案》

《Android项目重构实践:从 Fresco 到 Glide 低成本重构方案》

《Android项目重构实践:从 Fresco 到 Glide 低成本重构方案》

    原文作者:wx5da1bcf102738
    原文地址: https://blog.51cto.com/14573572/2453087
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞