【HarmonyOS Next开发】用户文件访问

简介: 文件所有者为登录到该终端设备的用户,包括用户私有的图片、视频、音频、文档等。应用对用户文件的创建、访问、删除等行为,需要提前获取用户授权,或由用户操作完成。

概述

文件所有者为登录到该终端设备的用户,包括用户私有的图片、视频、音频、文档等。

应用对用户文件的创建、访问、删除等行为,需要提前获取用户授权,或由用户操作完成。

用户文件访问框架

是一套提供给开发者访问和管理用户文件的基础框架。

image.png

文件路径Uri

分为文档类Uri和媒体文件Uri两类,需要是normal等级的应用(默认的应用是这个)调用这两个类,要不然会报没有权限的错误,官方配图如下:

image.png

  • 文档类:由picker拉起文件管理器选择或保存返回,以及通过fileAccess模块获取Uri。
  • 媒体文件:由picker通过拉起图库选择图片或者视频返回,通过photoAccessHelper模块获取图片或者视频文件的uri,以及通过userFileManager模块获取图片、视频或者音频文件的uri。

文档类uri获取

  • 通过DocumentViewPicker接口来选择和保存各种格式文档,返回选择或保存的文件的uri。
import { common } from '@kit.AbilityKit';
import { picker } from '@kit.CoreFileKit';
import { BusinessError } from '@kit.BasicServicesKit';

@Entry
@Component
struct Index {
  build() {
    Column(){
      Button("点击文件选择器")
        .width("80%")
        .onClick((event: ClickEvent) => {
          let context = getContext(this) as common.Context;
          let docPicker = new picker.DocumentViewPicker(context);
          let opt = new picker.DocumentSelectOptions();
          docPicker.select(opt,(err:BusinessError,selectResult:Array<string>)=>{
            if (err) {
              console.error('错误: ' + JSON.stringify(err));
              return;
            }
            console.info('选择文件的uri: ' + JSON.stringify(selectResult));
          })
        })
    }
    .justifyContent(FlexAlign.Center)
    .height('100%')
    .width('100%')
  }
}

  • 通过AudioViewPicker接口来选择和保存音频类文件,返回选择或保存的文件的uri。
  • 通过PhotoViewPicker.save方法保存文件,返回保存的文件Uri。

媒体类uri获取

  • 通过PhotoViewPicker.select接口来选择图片/视频和保存图片/视频,返回选择的媒体文件文件的uri。
  • 通过photoAccessHelper模块中的getAccess或createAccess接口获取媒体文件对应的uri。需要申请相册管理模块读权限'ohos.permission.READ_IMAGEVIDEO'。

用户选择图片并返回Uri案例

cke\_9171.pngcke\_11158.png

import { common } from '@kit.AbilityKit';
import { fileIo, picker } from '@kit.CoreFileKit';
import { BusinessError } from '@kit.BasicServicesKit';
import { photoAccessHelper } from '@kit.MediaLibraryKit';


@Entry
@Component
struct Index {
  @State _uris: Array<string> = [];

  /**
   * 选择图片
   */
  PickerImage(): void {
    //文档选择实例
    const photoSelectOptions = new photoAccessHelper.PhotoSelectOptions();
    //选择文档的最大数目
    photoSelectOptions.maxSelectNumber = 2;
    //过滤选择媒体文件类型为图片
    photoSelectOptions.MIMEType = photoAccessHelper.PhotoViewMIMETypes.IMAGE_TYPE;
    const photoViewPicker = new photoAccessHelper.PhotoViewPicker();
    photoViewPicker.select(photoSelectOptions).then((selectResult: photoAccessHelper.PhotoSelectResult) => {
      this._uris = selectResult.photoUris;
      console.info('选择的文件路径:' + this._uris);
    })
      .catch((err: BusinessError) => {
        console.error(`Invoke photoViewPicker.select failed, code is ${err.code}, message is ${err.message}`)
      })
  }

  /**
   * 读取图片信息
   */
  ReadImageFileIo(): void {
    this._uris.forEach(uri => {
      let file = fileIo.openSync(uri, fileIo.OpenMode.READ_ONLY);
      let buffer = new ArrayBuffer(4096);
      let readLen = fileIo.readSync(file.fd, buffer);
      console.info('readSync data to file succeed and buffer size is:' + readLen);
      fileIo.closeSync(file);
    });
  }

  build() {
    Column() {
      Button("点击文件选择器")
        .width("80%")
        .onClick((event: ClickEvent) => {
          let context = getContext(this) as common.Context;
          let docPicker = new picker.DocumentViewPicker(context);
          let opt = new picker.DocumentSelectOptions();
          docPicker.select(opt, (err: BusinessError, selectResult: Array<string>) => {
            if (err) {
              console.error('错误: ' + JSON.stringify(err));
              return;
            }
            console.info('选择文件的uri: ' + JSON.stringify(selectResult));
          })
        })
      Button("点击图片选择器")
        .width("80%")
        .margin({ top: 20 })
        .onClick(() => this.PickerImage())
      if (this._uris != undefined && this._uris.length > 0) {
        Image(this._uris[0])
          .width(50)
          .height(50)
          .margin({ top: 20 })
      }

    }
    .justifyContent(FlexAlign.Center)
    .height('100%')
    .width('100%')
  }
}

相关文章
|
18小时前
【HarmonyOS Next开发】:ListItemGroup使用
通过使用ListItemGroup和AlphabetIndexer两种类型组件,实现带标题分类和右侧导航栏的页面
79 61
|
18小时前
|
API
【HarmonyOS Next开发】Tabs使用封装
在写Tabs时,会使用很多个TabContent来实现不同页面的展示内容,但是如果TabContent数量很多时,会导致Tabs代码量大而且很臃肿,因此想着尝试去封装Tabs的使用,可以让界面整洁和对内容界面的解耦。 主要依托于wrapBuilder:封装全局@Builder的方法使用。需要注意从API 11 才开始支持使用
14 6
|
18小时前
|
API 容器
【HarmonyOS Next开发】Navigation使用
Navigation是路由容器组件,包括单栏(Stack)、分栏(Split)和自适应(Auto)三种显示模式。适用于模块内和跨模块的路由切换。 在页面跳转时,应该使用页面路由router,在页面内的页面跳转时,建议使用Navigation达到更好的转场动效场景。
17 8
|
1天前
|
人工智能 文字识别 算法
|
1天前
|
安全 Java 开发者
|
1天前
|
存储 开发者 容器
|
2天前
|
人工智能 自然语言处理 算法
开箱即用的个人主页页面开发实战—基于HarmonyOS 5.0 (Next)和ArkTS的实现【HarmonyOS 5.0(Next)】
本文介绍了基于HarmonyOS 5.0(Next)和ArkTS开发的开箱即用个人主页页面。HarmonyOS 5.0(Next)采用全新“和谐美学”设计理念,通过光元素模拟、多设备无缝流转及小艺助手升级,提升用户体验。文章详细解析了使用ArkTS构建个人主页页面的代码,展示了清晰的布局层次、简洁的事件处理、状态管理和组件化开发等最佳实践。这段代码不仅实现了美观的界面设计,还提供了高效的应用导航和数据传递功能,体现了对用户体验的高度关注。
36 12
开箱即用的个人主页页面开发实战—基于HarmonyOS 5.0 (Next)和ArkTS的实现【HarmonyOS 5.0(Next)】
|
21小时前
|
安全 数据安全/隐私保护
鸿蒙开发:一文了解软键盘相关
软键盘最主要的就是合理的进行避让,不能遮挡可输入组件,再有多个输入框的时候,需要动态的进行设置高度,这一点需要注意。
鸿蒙开发:一文了解软键盘相关
|
21小时前
鸿蒙开发:一个轻盈的上拉下拉刷新组件
在和可滑动组件使用的时候,记得一定要和nestedScroll属性配合使用,用于解决滑动冲突,除此之外,还需要传递滑动组件的scroller属性,用于手势操作。
鸿蒙开发:一个轻盈的上拉下拉刷新组件

热门文章

最新文章