鸿蒙:使用Image组件展示相册图片或rawfile图片

1、前言

实现展示相册图片的方法,通过获取到图片的uri,将uri交给Image组件展示即可。如果是展示本地的rawfile图片,那么只需要获取图片的文件名及后缀,然后将这个字符串交给Image,通过$rawfile()方式展示即可。

2、参考文档

https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/photoaccesshelper-photoviewpickerhttps://developer.huawei.com/consumer/cn/doc/harmonyos-guides/photoaccesshelper-photoviewpicker

3、核心思路

  1. 通过媒体文件资源管理器拉起系统相册,然后获取到选择的图片uri,将uri数组每一项字符串交给Image组件渲染
  2. 项目rawfile目录下的图片加载则更为简单,将内部图片的文件名+后缀,放到同一个字符串数组中,我们直接循环渲染即可,每一项交给Image,通过$rawfile()展示。

4、运行效果

5、完整代码

Index.ets

复制代码
import { photoAccessHelper } from '@kit.MediaLibraryKit';

async function selectImage(): Promise<Array<string>> {
  const photoSelectOptions = new photoAccessHelper.PhotoSelectOptions();
  photoSelectOptions.MIMEType = photoAccessHelper.PhotoViewMIMETypes.IMAGE_TYPE; // 过滤选择媒体文件类型为IMAGE。
  photoSelectOptions.maxSelectNumber = 5; // 选择媒体文件的最大数目。
  const photoViewPicker = new photoAccessHelper.PhotoViewPicker();
  const photoSelectResult = await photoViewPicker.select(photoSelectOptions)
  return photoSelectResult.photoUris
}

function selectImages(): Array<string> {
  const arr: Array<string> = ["1.jpg", "2.jpg", "3.jpg"]

  return arr
}

@Entry
@ComponentV2
export struct Index {
  @Local imageUri: string[] = []

  build() {
    List() {
      ListItem() {
        Column({ space: 20 }) {

          ForEach(this.imageUri, (uri: string) => {
            Image(uri)
              .width(200)
            Text(uri)
            Image($rawfile(uri))
              .width(200)
          })

          Button("从相册选择图片并展示")
            .onClick(async () => {
              this.imageUri = await selectImage()
            })

          Button("展示项目本地的rawfile图片")
            .onClick(() => {
              this.imageUri = selectImages()
            })

        }
        .width("100%")
        .justifyContent(FlexAlign.Center)

      }
    }
    .width("100%")
    .height("100%")
  }
}

有帮助的话,可以点赞或收藏

相关推荐
盐焗西兰花2 小时前
鸿蒙学习实战之路-ArkTS循环渲染_ForEach使用指南
学习·华为·harmonyos
俩毛豆5 小时前
【鸿蒙生态共建】意图框架的使用-通过小艺调起京东发起搜索《精通HarmonyOS NEXT :鸿蒙App开发入门与项目化实战》读者福利
华为·harmonyos·小艺
Devil枫8 小时前
HarmonyOS 应用草稿箱功能设计方案(安全可靠+轻量化存储)
华为·harmonyos
C雨后彩虹12 小时前
二维伞的雨滴效应
java·数据结构·算法·华为·面试
数智顾问12 小时前
(111页PPT)华为业务变革框架及战略级项目管理(附下载方式)
大数据·运维·华为
芒鸽14 小时前
windows上使用Lycium 交叉编译移植鸿蒙三方库指南
windows·华为·harmonyos
FrameNotWork16 小时前
HarmonyOS 广告 SDK 封装实战:从原生 Ads Kit 到可复用广告组件
华为·harmonyos
木斯佳16 小时前
[鸿蒙2025领航者闯关] 把养老院装进口袋:如何利用鸿蒙6新特性探索智慧医养场景
华为·harmonyos
wangxiaowu19861 天前
HarmonyOS NEXT和通用JSBridge
华为·harmonyos
cz追天之路1 天前
华为机考 ------ 识别有效的IP地址和掩码并进行分类统计
javascript·华为·typescript·node.js·ecmascript·less·css3