自学HarmonyOS Next记录:实现相册访问功能

简介: 最近我决定开发一个鸿蒙App,旨在提供更好的照片管理体验。通过使用PhotoAccessHelper API,我实现了访问、显示和管理设备相册中的照片。过程中遇到了权限不足的问题,通过在config.json中添加权限声明并编写权限检查代码得以解决。此外,我还实现了分页加载和展示照片详细信息等功能,提升了用户体验。这次开发不仅让我掌握了API的使用,也深刻体会到鸿蒙系统对用户隐私和数据安全的重视。总结这次开发,我不仅学到了技术知识,还明白了开发者保护用户数据安全的责任。未来将继续探索更多功能,欢迎关注和收藏!

最近我决定开始一个新项目——自己动手开发一个鸿蒙App。这个App的功能想法其实很简单,就是一个能够访问设备相册的应用,方便用户查看、选择和管理照片。在日常使用手机的过程中,相册功能的使用频率很高,我想为鸿蒙设备上的用户提供一个更好的照片管理体验。于是,咱们就开始搞起来。



在翻阅了鸿蒙的Next开发文档后,我找到了一个非常适合我需求的API:PhotoAccessHelper。这个API可以用来访问设备中的照片,并提供相应的管理功能。我打算从最简单的功能做起,比如获取相册中的照片列表,然后一步一步拓展到更复杂的功能。


初步接触相册访问


一开始,我得先搞清楚怎么获取设备中的照片。PhotoAccessHelper 的文档描述得非常详细,使用它可以轻松地获取设备中的图片资源。所以,我先写了一个最简单的功能,尝试从设备中获取一些照片,并将它们显示在页面上。

下面是我用到的核心代码:


import PhotoAccessHelper from '@ohos.photo.PhotoAccessHelper';
let photoHelper = new PhotoAccessHelper();
function fetchPhotos() {
    photoHelper.getPhotos({
        limit: 10
    }).then((photos) => {
        console.log('获取到的照片:', photos);
        // 将照片展示在页面中
        photos.forEach(photo => {
            displayPhoto(photo.uri);
        });
    }).catch((err) => {
        console.error('获取照片失败', err);
    });
}
function displayPhoto(photoUri) {
    let imgElement = document.createElement('img');
    imgElement.src = photoUri;
    document.getElementById('photoContainer').appendChild(imgElement);
}


通过这段代码,我可以从设备相册中获取照片,并且在页面上展示出来。这一部分的实现其实比我想象得要简单许多,鸿蒙的API设计得相对直观,入门门槛不高。

然而,事情并没有我一开始想的那么简单。在运行这段代码的时候,我遇到了一个问题:权限不足。


权限的坑


在鸿蒙系统中,访问用户的照片需要申请相应的权限。这是为了保护用户隐私,避免不必要的应用获取到用户的敏感数据。所以,我不得不去研究权限申请的流程。


通过查阅官方文档,我了解到需要在config.json中添加相应的权限声明,例如:


"reqPermissions": [
    {
        "name": "ohos.permission.READ_MEDIA"
    }
]


这个权限声明非常重要,如果没有配置好,App根本无法访问用户的照片资源。添加权限声明后,我还需要在代码中进行权限检查,确保用户已经授权。

为此,我写了一个简单的权限检查函数:


import { Permissions } from '@ohos.permissions';
function checkPermission() {
    Permissions.checkPermission('ohos.permission.READ_MEDIA').then((result) => {
        if (result.granted) {
            fetchPhotos();
        } else {
            console.warn('缺少相册读取权限,正在请求权限...');
            requestPermission();
        }
    }).catch((err) => {
        console.error('权限检查失败', err);
    });
}
function requestPermission() {
    Permissions.requestPermission('ohos.permission.READ_MEDIA').then((result) => {
        if (result.granted) {
            fetchPhotos();
        } else {
            console.error('用户拒绝了相册读取权限');
        }
    }).catch((err) => {
        console.error('请求权限失败', err);
    });
}


通过这段代码,我成功地实现了权限检查和请求,这样用户在初次运行应用时会被提示授予相应权限。当用户同意后,应用便可以顺利地访问相册中的照片。


进一步探索:管理照片


接下来,我不满足于只是简单地获取和显示照片。我想进一步实现一些管理照片的功能,比如删除照片或者查看照片的详细信息。PhotoAccessHelper 也提供了一些这样的API,例如可以使用deletePhoto()来删除特定的照片。

以下是删除照片的代码实现:


function deletePhoto(photoUri) {
    photoHelper.deletePhoto(photoUri).then(() => {
        console.log('照片删除成功');
        // 删除成功后刷新页面
        document.getElementById('photoContainer').innerHTML = '';
        fetchPhotos();
    }).catch((err) => {
        console.error('删除照片失败', err);
    });
}


通过这一段代码,我实现了一个简单的照片删除功能。当用户在照片上点击删除按钮时,可以调用deletePhoto()来移除该照片,并刷新页面显示最新的照片列表。


面临的挑战与解决方案


在开发过程中,我还遇到了一些意料之外的挑战。比如,有时候用户的照片数量非常多,这就导致了照片获取的过程可能会比较缓慢,页面加载时间较长。为了改善用户体验,我引入了分页加载的方式,每次只加载一部分照片,并通过滚动加载的方式不断获取更多内容。

以下是分页加载的实现思路:


let offset = 0;
const limit = 10;
function loadMorePhotos() {
    photoHelper.getPhotos({
        limit: limit,
        offset: offset
    }).then((photos) => {
        console.log('加载更多照片:', photos);
        // 将照片展示在页面中
        photos.forEach(photo => {
            displayPhoto(photo.uri);
        });
        offset += photos.length;
    }).catch((err) => {
        console.error('加载照片失败', err);
    });
}
window.onscroll = function() {
    if ((window.innerHeight + window.scrollY) >= document.body.offsetHeight) {
        loadMorePhotos();
    }
};


通过分页加载的方式,我有效地减少了初次加载时的等待时间,提高了用户的体验。滚动加载的方式让用户可以在需要时继续加载更多的照片,而不至于因为一次性加载所有照片而导致页面卡顿。


照片详细信息的展示


除了删除照片,我还想给用户提供更多的照片信息,比如照片的拍摄时间、大小、分辨率等。PhotoAccessHelper 提供了一些相关的方法,可以获取到这些信息。

以下是展示照片详细信息的代码:


function showPhotoDetails(photoUri) {
    photoHelper.getPhotoDetails(photoUri).then((details) => {
        console.log('照片详细信息:', details);
        // 在页面中展示详细信息
        let detailsElement = document.createElement('div');
        detailsElement.innerHTML = `
            <p>拍摄时间:${details.dateTaken}</p>
            <p>文件大小:${details.size} bytes</p>
            <p>分辨率:${details.width} x ${details.height}</p>
        `;
        document.getElementById('photoDetailsContainer').appendChild(detailsElement);
    }).catch((err) => {
        console.error('获取照片详细信息失败', err);
    });
}


通过这一部分的开发,用户可以点击某张照片来查看它的详细信息,这让整个应用的功能更加丰富,也提高了用户的互动性。


结语:开发中的收获


经过这次的开发,我不仅掌握了PhotoAccessHelper的使用,还进一步体会到了鸿蒙系统在保护用户隐私和数据安全方面的设计。在开发的过程中,权限管理确实让我感到了一些挑战,但也让我更加明白,作为开发者,我们有责任保护用户的数据安全,而这些必要的权限检查和声明,正是实现这一目标的重要手段。



总之又完成了一项挑战,未来还会继续研究相关技术,喜欢的朋友可以关注+收藏哦~!

目录
相关文章
|
12天前
|
缓存 API 数据安全/隐私保护
自学记录:学习HarmonyOS Location Kit构建智能定位服务
作为一名对新技术充满好奇心的开发者,我选择了HarmonyOS Next 5.0.1(API 13)作为挑战对象,深入研究其强大的定位服务API——Location Kit。从权限管理、获取当前位置、逆地理编码到地理围栏,最终成功开发了一款智能定位应用。本文将结合代码和开发过程,详细讲解如何实现这些功能,并分享遇到的挫折与兴奋时刻。希望通过我的经验,能帮助其他开发者快速上手HarmonyOS开发,共同探索更多可能性。
99 5
|
14天前
|
安全 数据安全/隐私保护 Android开发
HarmonyOS 5.0 Next实战应用开发—‘我的家乡’【HarmonyOS Next华为公司完全自研的操作系统】
HarmonyOS NEXT是华为自研的鸿蒙操作系统的重要版本更新,标志着鸿蒙系统首次完全脱离Linux内核及安卓开放源代码项目(AOSP),仅支持鸿蒙内核和鸿蒙系统的应用。该版本引入了“和谐美学”设计理念,通过先进的物理渲染引擎还原真实世界的光影色彩,为用户带来沉浸式体验。应用图标设计融合国画理念,采用留白和实时模糊技术展现中式美学。 HarmonyOS NEXT强化了设备间的协同能力,支持无缝切换任务,如在手机、平板或电脑间继续阅读文章或编辑文件。系统注重数据安全和隐私保护,提供数据加密和隐私权限管理功能。此外,它利用分布式技术实现跨设备资源共
84 15
HarmonyOS 5.0 Next实战应用开发—‘我的家乡’【HarmonyOS Next华为公司完全自研的操作系统】
|
14天前
|
存储 JavaScript 开发工具
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
本次的.HarmonyOS Next ,ArkTS语言,HarmonyOS的元服务和DevEco Studio 开发工具,为开发者提供了构建现代化、轻量化、高性能应用的便捷方式。这些技术和工具将帮助开发者更好地适应未来的智能设备和服务提供方式。
39 8
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
|
13天前
|
存储 API
鸿蒙元服务项目实战:终结篇之备忘录搜索功能实现
开发元服务,有很多的限制性因素,比如包的大小限制,相关API限制,所以,我们在实际开发的时候,具体Api能否使用,还需要去官网查看一下,目前,针对当前这个小项目,总结了几个小问题,大家在开发的过程中可以作为参考。
鸿蒙元服务项目实战:终结篇之备忘录搜索功能实现
|
3天前
|
存储 JSON 区块链
【HarmonyOS NEXT开发——ArkTS语言】购物商城的实现【合集】
HarmonyOS应用开发使用@Component装饰器将Home结构体标记为一个组件,意味着它可以在界面构建中被当作一个独立的UI单元来使用,并且按照其内部定义的build方法来渲染具体的界面内容。txt:string定义了一个名为Data的接口,用于规范表示产品数据的结构。src:类型为,推测是用于引用资源(可能是图片资源等)的一种特定类型,用于指定产品对应的图片资源。txt:字符串类型,用于存放产品的文字描述,比如产品名称等相关信息。price:数值类型,用于表示产品的价格信息。
23 5
|
3天前
|
开发工具 开发者 容器
【HarmonyOS NEXT开发——ArkTS语言】欢迎界面(启动加载页)的实现【合集】
从ArkTS代码架构层面而言,@Entry指明入口、@Component助力复用、@Preview便于预览,只是初窥门径,为开发流程带来些许便利。尤其动画回调与Blank组件,细节粗糙,后续定当潜心钻研,力求精进。”,字体颜色为白色,字体大小等设置与之前类似,不过动画配置有所不同,时长为。,不过这里没有看到额外的动画效果添加到这个特定的图片元素上(与前面带动画的元素对比而言)。这是一个显示文本的视图,文本内容为“奇怪的知识”,设置了字体颜色为灰色(的结构体,它代表了整个界面组件的逻辑和视图结构。
16 1
|
15天前
|
人工智能 自然语言处理 API
自学记录HarmonyOS Next的HMS AI API 13:语音合成与语音识别
在完成图像处理项目后,我计划研究HarmonyOS Next API 13中的AI语音技术,包括HMS AI Text-to-Speech和Speech Recognizer。这些API提供了强大的语音合成与识别功能,支持多语言、自定义语速和音调。通过这些API,我将开发一个支持语音输入与输出的“语音助手”原型应用,实现从语音指令解析到语音响应的完整流程。此项目不仅提高了应用的交互性,也为开发者提供了广阔的创新空间。未来,语音技术将在无障碍应用和智慧城市等领域展现巨大潜力。如果你也对语音技术感兴趣,不妨一起探索这个充满无限可能的领域。 (238字符)
80 11
|
16天前
|
存储 API 计算机视觉
自学记录HarmonyOS Next Image API 13:图像处理与传输的开发实践
在完成数字版权管理(DRM)项目后,我决定挑战HarmonyOS Next的图像处理功能,学习Image API和SendableImage API。这两个API支持图像加载、编辑、存储及跨设备发送共享。我计划开发一个简单的图像编辑与发送工具,实现图像裁剪、缩放及跨设备共享功能。通过研究,我深刻体会到HarmonyOS的强大设计,未来这些功能可应用于照片编辑、媒体共享等场景。如果你对图像处理感兴趣,不妨一起探索更多高级特性,共同进步。
71 11
|
12天前
|
人工智能 数据可视化 API
自学记录鸿蒙API 13:Calendar Kit日历功能从学习到实践
本文介绍了使用HarmonyOS的Calendar Kit开发日程管理应用的过程。通过API 13版本,不仅实现了创建、查询、更新和删除日程等基础功能,还深入探索了权限请求、日历配置、事件添加及查询筛选等功能。实战项目中,开发了一个智能日程管理工具,具备可视化管理、模糊查询和智能提醒等特性。最终,作者总结了模块化开发的优势,并展望了未来加入语音助手和AI推荐功能的计划。
123 1
|
11天前
|
存储 人工智能 JavaScript
Harmony OS开发-ArkTS语言速成二
本文介绍了ArkTS基础语法,包括三种基本数据类型(string、number、boolean)和变量的使用。重点讲解了let、const和var的区别,涵盖作用域、变量提升、重新赋值及初始化等方面。期待与你共同进步!
72 47
Harmony OS开发-ArkTS语言速成二