HarmonyOS Next开发学习手册——添加组件(显示图片 (Image))

开发者经常需要在应用中显示一些图片,例如:按钮中的icon、网络图片、本地图片等。在应用中显示图片需要使用Image组件实现,Image支持多种图片格式,包括png、jpg、bmp、svg和gif。

Image通过调用接口来创建,接口调用形式如下:

Image(src: PixelMap | ResourceStr | DrawableDescriptor)

该接口通过图片数据源获取图片,支持本地图片和网络图片的渲染展示。其中,src是图片的数据源,加载方式请参考 加载图片资源 。

加载图片资源

Image支持加载存档图、多媒体像素图两种类型。

存档图类型数据源

存档图类型的数据源可以分为本地资源、网络资源、Resource资源、媒体库资源和base64。

  • 本地资源

    创建文件夹,将本地图片放入ets文件夹下的任意位置。

    Image组件引入本地图片路径,即可显示图片(根目录为ets文件夹)。

Image('images/view.jpg')
.width(200)
  • 网络资源

引入网络图片需申请权限ohos.permission.INTERNET,具体申请方式请参考 声明权限 。此时,Image组件的src参数为网络图片的链接。

Image组件首次加载网络图片时,需要请求网络资源,非首次加载时,默认从缓存中直接读取图片,更多图片缓存设置请参考 setImageCacheCount 、 setImageRawDataCacheSize 、 setImageFileCacheSize 。

Image('https://www.example.com/example.JPG') // 实际使用时请替换为真实地址
  • Resource资源

使用资源格式可以跨包/跨模块引入图片,resources文件夹下的图片都可以通过$r资源接口读 取到并转换到Resource格式。

图1 resources

调用方式:

Image($r('app.media.icon'))

还可以将图片放在rawfile文件夹下。

图2 rawfile

调用方式:

Image($rawfile('example1.png'))
  • 媒体库file://data/storage

支持file://路径前缀的字符串,用于访问通过 媒体库 提供的图片路径。

  1. 调用接口获取图库的照片url。
import picker from '@ohos.file.picker';
import { BusinessError } from '@ohos.base';

@Entry
@Component
struct Index {
  @State imgDatas: string[] = [];
  // 获取照片url集
  getAllImg() {
    try {
      let PhotoSelectOptions:picker.PhotoSelectOptions = new picker.PhotoSelectOptions();
      PhotoSelectOptions.MIMEType = picker.PhotoViewMIMETypes.IMAGE_TYPE;
      PhotoSelectOptions.maxSelectNumber = 5;
      let photoPicker:picker.PhotoViewPicker = new picker.PhotoViewPicker();
      photoPicker.select(PhotoSelectOptions).then((PhotoSelectResult:picker.PhotoSelectResult) => {
        this.imgDatas = PhotoSelectResult.photoUris;
        console.info('PhotoViewPicker.select successfully, PhotoSelectResult uri: ' + JSON.stringify(PhotoSelectResult));
      }).catch((err:Error) => {
        let message = (err as BusinessError).message;
        let code = (err as BusinessError).code;
        console.error(`PhotoViewPicker.select failed with. Code: ${code}, message: ${message}`);
      });
    } catch (err) {
      let message = (err as BusinessError).message;
      let code = (err as BusinessError).code;
      console.error(`PhotoViewPicker failed with. Code: ${code}, message: ${message}`);    }
  }

  // aboutToAppear中调用上述函数,获取图库的所有图片url,存在imgDatas中
  async aboutToAppear() {
    this.getAllImg();
  }
  // 使用imgDatas的url加载图片。
  build() {
    Column() {
      Grid() {
        ForEach(this.imgDatas, (item:string) => {
          GridItem() {
            Image(item)
              .width(200)
          }
        }, (item:string):string => JSON.stringify(item))
      }
    }.width('100%').height('100%')
  }
}
  1. 从媒体库获取的url格式通常如下。
Image('file://media/Photos/5')
.width(200)
  • base64

路径格式为data:image/[png|jpeg|bmp|webp];base64,[base64 data],其中[base64 data]为Base64字符串数据。

Base64格式字符串可用于存储图片的像素数据,在网页上使用较为广泛。

多媒体像素图

PixelMap是图片解码后的像素图,具体用法请参考 图片开发指导 。以下示例将加载的网络图片返回的数据解码成PixelMap格式,再显示在Image组件上,

  1. 创建PixelMap状态变量。
@State image: PixelMap | undefined = undefined;
  1. 引用多媒体。

请求网络图片,解码编码PixelMap。

  1. 引用网络权限与媒体库权限。
import http from '@oho
<think>我们正在讨论HarmonyOS NEXT显示JPG图片的问题。根据用户的问题,他想要在鸿蒙开发显示JPG图片数据。我们可以参考提供的引用资料,特别是引用[4]中的代码示例,该示例展示了如何从资源中获取JPG图片显示。 在HarmonyOS NEXT中,显示图片通常使用`<Image>`组件。同时,我们需要通过资源管理获取图片数据,然后创建ImageSource,进而生成PixelMap,最后将PixelMap设置给Image组件。 根据引用[4]的示例,我们可以分解为以下步骤: 1. 获取资源管理器(resourceManager)并读取图片文件(如test.jpg)的原始数据。 2. 将原始数据转换为ArrayBuffer,然后创建ImageSource。 3. 通过ImageSource创建PixelMap(位图数据)。 4. 将PixelMap设置给Image组件进行显示。 但是,需要注意的是,引用[4]中的代码仅展示了如何从资源文件中获取图片并创建PixelMap,并没有直接展示如何显示Image组件上。因此,我们需要结合ArkUIImage组件显示。 在ArkUI中,Image组件可以通过设置`src`属性来显示图片,而`src`属性可以接受资源路径、PixelMap等。 因此,我们可以这样实现: 步骤1:将图片文件(如test.jpg)放在resources/base/media目录下(如果没有media目录,可以创建)。 步骤2:在UI中使用Image组件,并设置其src属性为资源路径($r('app.media.test'))即可直接显示。 但是,如果用户希望从二进制数据(比如通过网络下载的JPG数据)显示,那么就需要使用引用[4]中的方法,将二进制数据转换为PixelMap,然后设置给Image组件。 因此,我们分两种情况: 情况一:图片是本地资源文件(放在resources目录下) 情况二:图片是二进制数据(比如从网络下载或内存中) 用户的问题中提到了“显示JPG图片数据”,这里的数据可能是二进制数据,所以我们重点放在情况二。 以下是如何在ArkUI(使用TypeScript)中显示二进制JPG图片数据的步骤: 1. 获取二进制数据(Uint8Array格式)。 2. 使用`image.createImageSource`创建ImageSource。 3. 通过ImageSource创建PixelMap。 4. 将PixelMap设置给Image组件的src属性。 示例代码(基于ArkTS): 假设我们有一个包含JPG图片二进制数据的Uint8Array(例如从网络下载或读取文件得到),我们可以这样显示: ```typescript import image from '@ohos.multimedia.image'; import resourceManager from '@ohos.resourceManager'; @Entry @Component struct ImageDisplayExample { // 用于存储PixelMap @State pixelMap: image.PixelMap | undefined = undefined; aboutToAppear() { // 假设我们有一个Uint8Array类型的jpg数据,这里用空数组代替,实际应从网络或文件读取 // 这里我们模拟一个从资源文件读取的过程,实际中可能从网络获取 const context = getContext(this); resourceManager.getResourceManager().then(resMgr => { resMgr.getRawFileContent('test.jpg').then(fileData => { console.log("Succeeded in getting RawFileContent"); // 获取ArrayBuffer const buffer = fileData.buffer.slice(0); // 创建ImageSource const imageSource = image.createImageSource(buffer); // 创建PixelMap imageSource.createPixelMap().then(pixelMap => { this.pixelMap = pixelMap; }).catch(err => { console.error("Failed to create PixelMap: " + JSON.stringify(err)); }); }).catch(err => { console.error("Failed to get RawFileContent: " + JSON.stringify(err)); }); }).catch(err => { console.error("Failed to get resourceManager: " + JSON.stringify(err)); }); } build() { Column() { // 使用Image组件显示 if (this.pixelMap) { Image(this.pixelMap) .width(200) .height(200) } else { Text('Loading...') } } .width('100%') .height('100%') } } ``` 注意:上述代码中,我们使用了`resourceManager`来读取resources/rawfile目录下的test.jpg文件(注意:getRawFileContent读取的是rawfile目录下的文件,所以需要将test.jpg放在resources/rawfile目录下)。如果我们的二进制数据来自其他途径(如网络),则不需要使用resourceManager,直接使用获取到的Uint8Array即可。 例如,如果我们从网络获取到二进制数据(ArrayBuffer),可以这样: ```typescript // 假设response是网络请求返回的ArrayBuffer const buffer = response; // response是ArrayBuffer类型 const imageSource = image.createImageSource(buffer); imageSource.createPixelMap().then(pixelMap => { this.pixelMap = pixelMap; }); ``` 另外,需要注意的是,HarmonyOS NEXTImage组件可以直接显示网络图片,通过设置src为网络URL,但这里用户要求显示JPG图片数据(二进制数据),所以我们需要转换为PixelMap。 总结: 在HarmonyOS NEXT显示JPG图片数据(二进制数据)的关键步骤是: 1. 将二进制数据(Uint8Array或ArrayBuffer)转换为ImageSource。 2. 通过ImageSource创建PixelMap。 3. 将PixelMap设置为Image组件的src。 这样,就可以在应用界面上显示JPG图片了。 参考文献: [^4] 提供了创建ImageSource和PixelMap的代码示例。 根据用户的问题,我们提供了上述解决方案。如果用户有其他疑问,可以进一步探讨。 相关问题: 1. 在HarmonyOS NEXT中如何显示网络图片(直接通过URL)? 2. 如何处理图片加载失败的情况? 3. 如何对图片进行缩放、裁剪等操作?</think>在 HarmonyOS NEXT显示 JPG 图片数据主要通过 `Image` 组件和图像处理 API 实现,以下是详细步骤和代码示例: ### 核心步骤 1. **获取图片数据** 从资源文件、网络或内存中获取 JPG 二进制数据(`Uint8Array` 格式) 2. **创建 ImageSource 对象** 使用 `@ohos.multimedia.image` 模块将二进制数据转换为图像源: ```typescript import image from '@ohos.multimedia.image'; // 假设 jpgData 是 Uint8Array 类型的 JPG 数据 const imageSource = image.createImageSource(jpgData.buffer); ``` 3. **生成 PixelMap 位图** 从 ImageSource 解码生成可显示的位图对象: ```typescript imageSource.createPixelMap().then((pixelMap: image.PixelMap) => { // 此处获取到可渲染的位图 }).catch((error: BusinessError) => { console.error("解码失败: " + error.message); }); ``` 4. **通过 Image 组件显示** 在 ArkUI 中将 PixelMap 绑定到 Image 组件: ```typescript @State pixelMap: image.PixelMap | null = null; build() { Column() { if (this.pixelMap) { Image(this.pixelMap) // 直接使用 PixelMap .width(200) .height(200) .objectFit(ImageFit.Contain) } else { Text('图片加载中...') } } } ``` ### 完整示例代码 ```typescript import image from '@ohos.multimedia.image'; import { BusinessError } from '@ohos.base'; @Entry @Component struct ImageDisplayExample { @State pixelMap: image.PixelMap | null = null; aboutToAppear() { // 1. 获取JPG数据(示例从资源读取) const context: Context = getContext(this); context.resourceManager.getRawFileContent('test.jpg') .then((fileData: Uint8Array) => { console.log("获取JPG数据成功"); // 2. 创建ImageSource const buffer = fileData.buffer.slice(0); const imageSource: image.ImageSource = image.createImageSource(buffer); // 3. 生成PixelMap imageSource.createPixelMap() .then((pixelMap: image.PixelMap) => { this.pixelMap = pixelMap; }) }).catch((error: BusinessError) => { console.error("处理失败: " + error.message); }); } build() { Column() { if (this.pixelMap) { // 4. 显示图片 Image(this.pixelMap) .width('90%') .height(300) .borderRadius(10) .overlay('JPG图片', { align: Alignment.Bottom, offset: { y: 10 } }) } else { ProgressBar() .width(100) .height(100) .color(Color.Blue) Text('解码图片中...').margin(10) } } .width('100%') .height('100%') .padding(20) } } ``` ### 关键注意事项 1. **资源放置** JPG 文件需放在项目的 `resources/rawfile` 目录下(如 `test.jpg`) 2. **权限声明** 如果加载网络图片,需在 `module.json5` 中添加网络权限: ```json "requestPermissions": [ { "name": "ohos.permission.INTERNET" } ] ``` 3. **内存管理** 使用后释放资源避免内存泄漏: ```typescript // 组件销毁时 aboutToDisappear() { if (this.pixelMap) { this.pixelMap.release(); } } ``` 4. **性能优化** 大图片建议先获取尺寸再按需解码: ```typescript imageSource.getImageInfo().then((info: image.ImageInfo) => { console.log(`图片尺寸: ${info.size.width}x${info.size.height}`); }); ``` ### 替代方案(直接显示资源文件) 如果只需显示本地资源文件,可直接使用资源路径: ```typescript Image($r('app.media.test_jpg')) // 放在resources/base/media目录 .width(200) .height(200) ``` > 提示:鸿蒙的 `Image` 组件原生支持 JPG/PNG/WEBP 等常见格式[^4],解码过程会自动处理色彩空间转换和 EXIF 方向信息。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值