Android组件化开发(三)--图片加载组件封装

简介: 今天我们来封装一个`图片加载库`:`lib_image_loader`
🔥 Hi,我是小余。

本文已收录到 GitHub · Androider-Planet 中。这里有 Android 进阶成长知识体系,关注公众号 [小余的自习室] ,在成功的路上不迷路!

前言

前面一篇文章我们做了一个组件化网络请求库:lib_network的封装

相关文章:
Android组件化开发(二)--网络请求组件封装

今天我们来封装一个图片加载库lib_image_loader

其实封装思想都是一样的:
主要还是根据三步走:

  • 1.需求分析
  • 2.技术选型
  • 3.根据1和2进行类库封装

1.需求分析

  • 1.首先他是一个图片加载库

那就要考虑到我们需要加载哪些种类的图片?pngjpggifwebp?balabala。。

  • 2.具体到我们项目中:

常见图片加载场景

   - 1.对ImageView设置src?
   - 2.对View或者ViewGroup设置背景色。?
   - 3.对目标对象设置图片,设置到一个Target中,设置通知栏的图片信息?
   - 4.设置通知栏的图片信息
   - 5.显示圆角图片
  • 3.多张图片可以并发加载
  • 4.图片自适应我们的控件
  • 5.api使用简单,侵入性低

2.技术选型

有了第一步的需求分析:我们再来选择对应的技术

如何选择合适的类库进行封装?

一般图片加载库,有 GlideFrescoPicasso,而 GlidePicasso一种升级版本,可以只看 Glide就可以,
为了选择合适的类库,本人去 Glide和Fresco官网查看了下他们的优缺点:

Fresco最大的优点是在5.0以下机型,将Bitmap的字节数组放在一个特殊的位置,
而不占用中的资源,这样就可以避免OOM的发生,但是目前5.0以下的设备占比已经很少了,所以这个优点可以忽略不计。

其他方面也基本能满足我们的需求,都支持gifwebp格式的图片数据,

但是Glide相比较Fresco来说,api使用简单,对业务代码没有侵入性,而Fresco需要使用他的特定控件才能使用,且需要在application中做初始化操作,有一定的侵入性

基于以上几点,笔者考虑使用Glide来封装我们的类库。

如果有想自己开发一套更加原生的图片加载库的同学,可以参考这篇文章:

面试官:让你设计一套图片加载框架,你会怎么设计?

但是不推荐大家去重复造轮子,没必要,但是你必须了解其内部原理。

封装

有了前两个步骤,我们就可以开始我们的类库封装了。
我们要封装哪些东西呢?还是根据我们的需求来

  • 1.对ImageView设置src
  • 2.对View或者ViewGroup设置背景色
  • 3.对目标对象设置图片,设置到一个Target中或者说是直接回调一个Bitmap给上层
  • 4.设置通知栏的图片信息
  • 5.显示圆角图片
基于以上需求笔者做了以下封装

1.对ImageView设置src

/**创建一个设置ImageView src的接口
     * @param imageView
     * @param url
     */
    public void displayImageForIView(ImageView imageView, String url, CustomRequestListener listener){
        Glide.with(imageView.getContext())
                .load(url)
                .apply(initCommonOptions())
                .into(imageView);
    }

2.对View或者ViewGroup设置背景色

/**创建一个设置View背景的接口
     * @param view
     * @param url
     * @param listener
     */
    public void displayImageForView(final View view, String url,CustomRequestListener listener){
        Glide.with(view.getContext())
                .asBitmap()
                .load(url)
                .listener(listener)
                .apply(initCommonOptions())
                .into(initCustomViewTarget(view));
    }

3.对目标对象设置图片,设置到一个Target中或者说是直接回调一个Bitmap给上层,用户希望自己处理Bitmap显示

/**回调一个Bitmap给上层
     */
    public void displayImageForCallBack(Context context, String url, BitmapRequestListener listener){
        Glide.with(context)
                .asBitmap()
                .load(url)
                .into(new JustReadyTarget(listener));

    }

4.设置通知栏的图片信息,一般用在音乐播放器等场景

/**创建一个给通知栏RemoteViews设置src的接口
     * @param context
     * @param remoteViews
     * @param id
     * @param notification
     * @param notificationId
     * @param url
     */
    public void displayImageForNotification(Context context, RemoteViews remoteViews, int id,
                                            Notification notification,int notificationId,String url){
        Glide.with(context)
                .asBitmap()
                .load(url)
                .apply(initCommonOptions())
                .into(new NotificationTarget(context,id,remoteViews,notification,notificationId));

    }

5.显示圆角图片

/**给ImageVIew设置一个圆形的view
     * @param imageView
     * @param url
     */
    public void displayImageForCircleView(ImageView imageView,String url){
        Glide.with(imageView)
                .asBitmap()
                .load(url)
                .into(new BitmapImageViewTarget(imageView){
                    @Override
                    protected void setResource(Bitmap resource) {
                        RoundedBitmapDrawable drawable = RoundedBitmapDrawableFactory
                                .create(imageView.getResources(),resource);
                        drawable.setCircular(true);
                        imageView.setImageDrawable(drawable);
                    }
                });
    }

这里对常见的一些需求做了封装,完整代码可以看demo

GitHub - ByteYuhb/anna_music_app

总结

此篇文章主要是对组件化框架中功能组件:图片加载框架的封装,

对于大部分类库的封装都可以使用我们上面的思路,再结合maven私服的使用。可以很好的将我们代码作为一个组件共享给开发同事使用

组件化道路长远,到目前为止我们封装两个功能框架:网络请求库和图片加载库,后面会不定期对其他类库进行封装,最后整合成一个完整的组件化框架

组件化开发.png

相关文章
|
19天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
12 0
|
1月前
|
XML 缓存 Android开发
Android开发,使用kotlin学习多媒体功能(详细)
Android开发,使用kotlin学习多媒体功能(详细)
94 0
|
1月前
|
设计模式 人工智能 开发工具
安卓应用开发:构建未来移动体验
【2月更文挑战第17天】 随着智能手机的普及和移动互联网技术的不断进步,安卓应用开发已成为一个热门领域。本文将深入探讨安卓平台的应用开发流程、关键技术以及未来发展趋势。通过分析安卓系统的架构、开发工具和框架,本文旨在为开发者提供全面的技术指导,帮助他们构建高效、创新的移动应用,以满足不断变化的市场需求。
18 1
|
10天前
|
XML 开发工具 Android开发
构建高效的安卓应用:使用Jetpack Compose优化UI开发
【4月更文挑战第7天】 随着Android开发不断进化,开发者面临着提高应用性能与简化UI构建流程的双重挑战。本文将探讨如何使用Jetpack Compose这一现代UI工具包来优化安卓应用的开发流程,并提升用户界面的流畅性与一致性。通过介绍Jetpack Compose的核心概念、与传统方法的区别以及实际集成步骤,我们旨在提供一种高效且可靠的解决方案,以帮助开发者构建响应迅速且用户体验优良的安卓应用。
|
19天前
|
Android开发
Android开发小技巧:怎样在 textview 前面加上一个小图标。
Android开发小技巧:怎样在 textview 前面加上一个小图标。
10 0
|
19天前
|
Android开发
Android 开发 pickerview 自定义选择器
Android 开发 pickerview 自定义选择器
10 0
|
26天前
|
Java Android开发
Android开发系列全套课程
本系列课程面向有java基础,想进入企业从事android开发的计算机专业者。学习搭配实战案例,高效掌握岗位知识。
17 1
|
27天前
|
数据可视化 测试技术 Android开发
安卓应用开发:打造高效用户界面的五大技巧
【2月更文挑战第30天】在竞争激烈的应用市场中,一个流畅且直观的用户界面(UI)对于安卓应用的成功至关重要。本文将探讨五个关键的UI设计技巧,这些技巧旨在提升用户体验并优化性能。我们将深入分析布局优化、资源管理、动画效果、响应式设计和测试流程等方面,并提供实用的代码示例和最佳实践,帮助开发者构建既美观又高效的安卓应用。
|
28天前
|
监控 算法 Android开发
安卓应用开发中的内存优化策略
【2月更文挑战第30天】随着移动设备性能的不断提升,用户对应用程序的体验要求越来越高。在安卓应用开发中,内存管理是影响应用性能和用户体验的关键因素之一。本文将探讨针对安卓平台的内存优化技巧,包括避免内存泄漏、合理使用数据结构和算法、优化图片资源处理等策略,旨在帮助开发者提升应用性能和稳定性。
19 1
|
28天前
|
编解码 测试技术 Android开发
安卓应用开发:构建高效用户界面的实用指南
【2月更文挑战第29天】在移动应用开发的世界中,创建一个流畅、直观且响应迅速的用户界面(UI)对于吸引和保持用户至关重要。本篇文章旨在向安卓开发者展示如何通过优化布局设计、使用现代UI框架以及利用Android Studio提供的工具来构建高效的用户界面。我们将深入探讨如何减少内存消耗、提升渲染性能,并确保应用在不同设备和屏幕尺寸上的兼容性。跟随本文的指导,你将能够提高应用的整体用户体验,从而在竞争激烈的市场中脱颖而出。