文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

HarmonyOS三方件开发指南(14)-Glide组件功能介绍

2024-12-03 09:09

关注

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com

 引言

在实际应用开发中,会用到大量图片处理,如:网络图片、本地图片、应用资源、二进制流、Uri对象等,虽然官方提供了PixelMap进行图片处理,但是却远远满足不了实际应用中各种五花八门的应用场景,如占位图、Gif图、加载失败图、内存浪费、内存溢出、节约流量等,这时候就需要一款能够处理这些问题,而且简单易用且性能很高的图片处理器了,因此OhosGlide三方组件应运而生。

功能介绍

OhosGlide 是一款非常优秀的图片处理工具,支持多种格式图片加载,采用磁盘缓存、内存缓存方式实现预加载,指定缓存大小实现节省内存避免OOM,操作方便简单易用。

指南

接下来我们来看下OhosGlide 具体是怎么使用的,在哪些场景使用,以及他的开发指南

我们先来看下对于开发者来讲,如何使用这个三方件,也就是har包,需要注意哪些地方

新建工程,增加组件Har包依赖

在应用模块中添加HAR,只需要将glidelibrary.har复制到entry\libs目录下即可(由于build.gradle中已经依赖的libs目录下的*.har,因此不需要在做修改)。

修改配置文件,首先在entry下面的build.gradle添加library 的依赖

其次在content.json 中添加需要的权限(由于在开发过程中,需要用到网络,以及存储权限,所以需要在content.json中添加相应的权限申明)

在我们需要加载网络图片的地方,实现以下代码,具体如下:

OhosGlideUtils.with(this).load("https://www.528045.com/file/upload/202412/01/y4m42eftomy.png").def(ResourceTable.Media_A).into(image);

注释://with(this)当前page

//load(url) 需要显示的图片url

//def(resID) 默认展示图片,当中途发生异常,展示默认的图片

//into(image) 需要展示的component

在实际开发中,我们不仅需要加载网络图片,还需要加载本地图片,具体代码如下:

注释://load(inputStream) 需要显示的图片的流

作为一个程序员,最关注的不是如何使用三方件,而是三方件的灵魂,如果实现才是重中之重,那么作为图片处理工具,核心的就是我们的缓存了,这样不仅页面加载快,而且还能节省流量,体验感好,接下来我们就来看下OhosGlide的缓存是如何实现的

缓存主要分为两种,第一种:内存缓存,也就是我们经常说的MemoryCache,当首次加载图片时,将图片缓存至内存中,这样用户在有网的情况,再次访问时,先加载内存缓存图片,然后再去网络请求最新的图片。减少流量的浪费和增加用户体验感

第二种就是我们说的磁盘缓存:DiskCache,设计磁盘缓存的核心理念就是当前设备没有网络的情况,访问该页面,如果app有磁盘缓存,则显示缓存的图片。不至于用户什么也看不到,这样做的目的也是为了增加用户体验感。

先来介绍第一种:MemoryCache,核心代码如下,具体可以参考源码

  1. public static void savePixelMap(String key, PixelMap pixelMap) { 
  2.     if (!isCache(key)) { 
  3.         CACHE_LOADER.addBitmap(CacheUtils.hashKeyForCache(key), pixelMap); 
  4.     } 
  5. public static PixelMap getPixelMap(String key) { 
  6.     return CACHE_LOADER.getPixelMap(CacheUtils.hashKeyForCache(key)); 
  7.  

再来介绍第二种:DiskCache ,核心代码如下,具体可以参考源码:

  1. // Add缓存 
  2. byte[] bytes = response.body().bytes(); 
  3. diskLruCacheImpl.addDiskCache(bytes, url); 
  4. // Get缓存 
  5. pixelMap = diskLruCacheImpl.getDiskCache(url); 
  6. if (pixelMap != null) { 
  7.     abilitySlice.getUITaskDispatcher().asyncDispatch(() -> { 
  8.         image.setPixelMap(pixelMap); 
  9.     }); 

缓存架构图如下:

代码如下:

  1. public static void savePixelMap(String key, PixelMap pixelMap) { 
  2.     if (!isCache(key)) { 
  3.         CACHE_LOADER.addBitmap(CacheUtils.hashKeyForCache(key), pixelMap); 
  4.     } 
  5. public static PixelMap getPixelMap(String key) { 
  6.     return CACHE_LOADER.getPixelMap(CacheUtils.hashKeyForCache(key)); 
  7.  

最终模拟器展示一张网络图片效果图如下:

在实现的过程中,我们可以在任何地方去调用OhosGlide 去展示网络图片,比如ListContainer加载列表

最后附上项目源码:https://github.com/isoftstone-dev/Gilde_HarmonyOS.git

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com

 

来源:鸿蒙社区内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯