首页 > 其他分享 >HarmonyOS Next 实战卡片开发 02

HarmonyOS Next 实战卡片开发 02

时间:2024-12-15 19:31:03浏览次数:8  
标签:02 卡片 Next HarmonyOS let import fileIo kit 图片

HarmonyOS Next 实战卡片开发 02

卡片开发中,还有一个难点是显示图片。其中分为显示本地图片和显示网络图片

显示本地图片

卡片可以显示本地图片,如存放在应用临时目录下的图片。路径比如

/data/app/el2/100/base/你的项目 boundleName/temp/123.png

以下操作是为了得到一张 该目录下的图片做的准备工作

  1. 截图,得到一张相册图片
  2. 使用PhotoViewPicker来选择要操作的图片
  3. 复制该图片到应用的临时目录下
  4. 传递给卡片组件

image-20241025215452668

截图,得到一张相册图片

使用 PhotoViewPicker 来选择要操作的图片

在首页中,选择要操作的图片,获得该文件的 uri 地址

entry/src/main/ets/pages/Index.ets

import { photoAccessHelper } from '@kit.MediaLibraryKit';
import { fileIo } from '@kit.CoreFileKit';
import { promptAction } from '@kit.ArkUI';

@Entry
@Component
struct Index {
  async aboutToAppear() {
    // 创建一个新的 PhotoSelectOptions 实例来配置图片选择器的行为
    let PhotoSelectOptions = new photoAccessHelper.PhotoSelectOptions();

    // 设置 MIME 类型为图像类型,这样用户只能选择图像文件
    PhotoSelectOptions.MIMEType = photoAccessHelper.PhotoViewMIMETypes.IMAGE_TYPE;

    // 设置用户可以选择的最大图片数量为 1 张
    PhotoSelectOptions.maxSelectNumber = 1;

    // 创建一个新的 PhotoViewPicker 实例,用于打开图片选择器
    let photoPicker = new photoAccessHelper.PhotoViewPicker();

    // 使用前面配置好的选项打开图片选择器,并等待用户完成选择
    // 注意这里的 select 方法是一个异步方法,所以需要使用 await 关键字等待其结果
    const PhotoSelectResult = await photoPicker.select(PhotoSelectOptions);

    // 获取用户选择的第一张图片的 URI(统一资源标识符)
    // 假设这里只关心用户选择的第一张图片
    // uri file://media/Photo/3/IMG_1729864738_002/screenshot_20241025_215718.jpg
    const uri = PhotoSelectResult.photoUris[0];
    promptAction.showToast({ message: `${uri}` })
  }

  build() {
    RelativeContainer() {

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

复制该图片到应用的临时目录下

目标是将刚才的图片复制到应用的临时目录下,为最后的卡片显示本地图片做准备

image-20241025220456712

在刚才的代码下,接着实现

// 获取应用的临时目录
let tempDir = getContext(this).getApplicationContext().tempDir;

// 生成一个新的文件名
const fileName = 123 + ".png";
// 通过缓存路径+文件名 拼接出完整的路径
const copyFilePath = tempDir + "/" + fileName;
// 将文件 拷贝到 临时目录
const file = fileIo.openSync(uri, fileIo.OpenMode.READ_ONLY);
fileIo.copyFileSync(file.fd, copyFilePath);

传递给卡片组件

在当前的环节中,有一个需要特别需要注意的地方,就是构造合适的数据。比如以下的数据

image-20241025221558917

然后在创建卡片的时候,在 Ability 中读取图片地址,拼接参数,传递给卡片

entry/src/main/ets/entryformability/EntryFormAbility.ets

import { Want } from "@kit.AbilityKit";
import { fileIo } from "@kit.CoreFileKit";
import { formBindingData, FormExtensionAbility } from "@kit.FormKit";

export default class EntryFormAbility extends FormExtensionAbility {
  // 在添加卡片时,打开一个本地图片并将图片内容传递给卡片页面显示
  onAddForm(want: Want): formBindingData.FormBindingData {
    // 假设在当前卡片应用的tmp目录下有一个本地图片 123.png
    let tempDir = this.context.getApplicationContext().tempDir;
    let imgMap: Record<string, number> = {};
    // 打开本地图片并获取其打开后的fd
    let file = fileIo.openSync(tempDir + "/" + "123.png");
    imgMap["imgBear"] = file.fd;

    class FormDataClass {
      // 卡片需要显示图片场景, 必须和下列字段formImages 中的key 'imgBear' 相同。
      imgName: string = "imgBear";
      // 卡片需要显示图片场景, 必填字段(formImages 不可缺省或改名), 'imgBear' 对应 fd
      formImages: Record<string, number> = imgMap;
    }

    let formData = new FormDataClass();
    console.log("formDataformData", JSON.stringify(formData));
    // 将fd封装在formData中并返回至卡片页面
    return formBindingData.createFormBindingData(formData);
  }
}

卡片需要 使用 'memory://+this.imgName' 来显示图片

let storageWidgetImageUpdate = new LocalStorage();

@Entry(storageWidgetImageUpdate)
@Component
struct WidgetImageUpdateCard {
  @LocalStorageProp('imgName') imgName: ResourceStr = "";

  build() {
    Column() {
    }
    .width('100%').height('100%')
    .backgroundImage('memory://' + this.imgName)
    .backgroundImageSize(ImageSize.Cover)
  }
}

完整效果

小结

  1. 截图,得到一张相册图片
  2. 使用PhotoViewPicker来选择要操作的图片
  3. 复制该图片到应用的临时目录下
  4. 传递给卡片组件

以上的前三步骤都是为了得到临时图片,实际开发中根据情况来获取即可

还有

  • Image 组件通过入参(memory://fileName)中的(memory://)标识来进行远端内存图片显示,其中 fileName 需要和 EntryFormAbility 传递对象('formImages': {key: fd})中的 key 相对应。
  • Image 组件通过传入的参数是否有变化来决定是否刷新图片,因此 EntryFormAbility 每次传递过来的 imgName 都需要不同,连续传递两个相同的 imgName 时,图片不会刷新。
  • 在卡片上展示的图片,大小需要控制在 2MB 以内。

显示网络图片

卡片中不支持直接显示网络图片如以下方式是不支持的

Image("https://cn-assets.gitee.com/assets/mini_app-e5eee5a21c552b69ae6bf2cf87406b59.jpg")

我们需要申请网络权限,然后将图片下载下来,最后再重复类似卡片显示本地图片的步骤即可

  1. 申请网络权限

    entry/src/main/module.json5

    image-20241025225743062

  2. 设置网络图片地址

  3. 使用 http 开始下载

  4. 写入文件

  5. 返回给卡片组件

entry/src/main/ets/entryformability/EntryFormAbility.ets

import { Want } from "@kit.AbilityKit";
import { fileIo } from "@kit.CoreFileKit";
import {
  formBindingData,
  FormExtensionAbility,
  formInfo,
  formProvider,
} from "@kit.FormKit";
import { http } from "@kit.NetworkKit";
import { BusinessError } from "@kit.BasicServicesKit";

export default class EntryFormAbility extends FormExtensionAbility {
  // 在添加卡片时,打开一个本地图片并将图片内容传递给卡片页面显示
  onAddForm(want: Want) {
    // 注意:FormExtensionAbility在触发生命周期回调时被拉起,仅能在后台存在5秒
    // 建议下载能快速下载完成的小文件,如在5秒内未下载完成,则此次网络图片无法刷新至卡片页面上
    const formId = want.parameters![formInfo.FormParam.IDENTITY_KEY] as string;
    let netFile =
      "https://env-00jxhf99mujs.normal.cloudstatic.cn/card/3.webp?expire_at=1729871552&er_sign=0eb3f6ac3730703039b1565b6d3e59ad"; // 需要在此处使用真实的网络图片下载链接

    let httpRequest = http.createHttp();
    // 下载图片
    httpRequest
      .request(netFile)
      .then(async (data) => {
        if (data?.responseCode == http.ResponseCode.OK) {
          // 拼接图片地址
          let tempDir = this.context.getApplicationContext().tempDir;
          let fileName = "file" + Date.now();
          let tmpFile = tempDir + "/" + fileName;
          let imgMap: Record<string, number> = {};

          class FormDataClass {
            // 卡片需要显示图片场景, 必须和下列字段formImages 中的key fileName 相同。
            imgName: string = fileName;
            // 卡片需要显示图片场景, 必填字段(formImages 不可缺省或改名), fileName 对应 fd
            formImages: Record<string, number> = imgMap;
          }

          // 打开文件
          let imgFile = fileIo.openSync(
            tmpFile,
            fileIo.OpenMode.READ_WRITE | fileIo.OpenMode.CREATE
          );
          imgMap[fileName] = imgFile.fd;
          // 写入文件
          await fileIo.write(imgFile.fd, data.result as ArrayBuffer);
          let formData = new FormDataClass();
          let formInfo = formBindingData.createFormBindingData(formData);
          // 下载完网络图片后,再传递给卡片
          formProvider.updateForm(formId, formInfo);
          fileIo.closeSync(imgFile);
          httpRequest.destroy();
          console.log("============");
        }
      })
      .catch((e: BusinessError) => {
        console.log("eeee", e.message);
      });

    class FormData {
      formId: string = "";
    }

    // 先返回基本数据
    return formBindingData.createFormBindingData(new FormData());
  }

  onFormEvent(formId: string, message: string): void {}
}

标签:02,卡片,Next,HarmonyOS,let,import,fileIo,kit,图片
From: https://www.cnblogs.com/aspXiaoBai/p/18608386

相关文章

  • 三文带你轻松上手鸿蒙的 AI 语音 02-声音文件转文本
    三文带你轻松上手鸿蒙的AI语音02-声音文件转文本接上一文前言本文主要实现使用鸿蒙的AI语音功能将声音文件识别并转换成文本实现流程利用AudioCapturer录制声音,生成录音文件利用AI语音功能,实现识别两个录音库介绍在HarmonyOSNEXT应用开中,实现录音的两个核心......
  • HarmonyOS Next 并发 taskpool 和 worker
    HarmonyOSNext并发taskpool和worker总览介绍并发,指的是同一时间内,多段代码同时执行。在ArkTs编程中,并发分为异步并发和多线程并发。异步并发异步并发并不是真正的并发,比如在单核设备中,同时执行多端代码其实是通过CPU快速调度来实现的。比如一个司机,它在同一时间只......
  • 2024-2025-1 20241423 《计算机基础与程序设计》第十二周学习总结
    作业信息这个作业属于哪个课程2024-2025-1-计算机基础与程序设计(https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP)这个作业要求在哪里2024-2025-1计算机基础与程序设计第十二周作业(https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP/homework/13276)......
  • 【最新】北大数字普惠金融指数数据集-省市县(2011-2023年)
    一、数据介绍数据名称:第六期北大数字普惠金融指数-省市县数据年份:2011-2023年数据范围:全国31个省、337个地级以上城市以及2800个县数据说明:编制方法请参阅《经济学(季刊)》中的《测度中国数字普惠金融发展:指数编制与空间特征》时间跨度:省级和城市级指数时间跨度为2011-202......
  • 2024-2025 ICPC, NERC, Southern and Volga Russian Regional Contest
    自己vp了一下这一场,赛时7题,比较简单,但是有几题也是卡了蛮久。都是思维题。C感觉结论比较显然但是实现上被卡住了。用map没过,重构的时候把多个数压缩成一个数处理ac了,对拍发现是因为循环逻辑导致错误了。。#include<bits/stdc++.h>usingnamespacestd;#defineLLlonglon......
  • 鸿蒙动画开发02——组件内转场动画
    我们接着鸿蒙动画开发01——布局更新动画,现在了解鸿蒙的组件内部的转场动画。1、概述组件的插入、删除过程即为组件本身的转场过程,组件的插入、删除动画称为组件内转场动画。通过组件内转场动画,可定义组件出现、消失的效果。2、关键接口组件内转场动画的接口为:transition(val......
  • 2024-2025-1 20241314 《计算机基础与程序设计》第十二周学习总结
    2024-2025-120241314《计算机基础与程序设计》第十二周学习总结作业信息这个作业属于哪个课程2024-2025-1-计算机基础与程序设计这个作业要求在哪里2024-2025-1计算机基础与程序设计第十二周作业这个作业的目标复习作业正文正文教材学习内容总结引......
  • Windows Server 2022 DHCP 服务器 是一种网络服务,属于 动态主机配置协议(DHCP, Dynamic
    WindowsServer2022DHCP服务器是一种网络服务,属于动态主机配置协议(DHCP,DynamicHostConfigurationProtocol)实现的一部分,用于自动为网络中的计算机和设备分配IP地址和其他网络配置信息,如子网掩码、默认网关和DNS服务器等。功能和作用:自动化IP地址分配:DHCP服......
  • Apache Struts 远程代码执行漏洞(CVE-2024-53677)
       0x01阅读须知        技术文章仅供参考,此文所提供的信息只为网络安全人员对自己所负责的网站、服务器等(包括但不限于)进行检测或维护参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作。利用此文所提供的信息而造成的直接或间接后果和损失,均......
  • THUPC2025游寄
    DAY-3原来是和\(xjy\)和\(cjz\)组队的,但是临时不方便,换队了。DAY-1成功和机房另外两个佬\(cyx\)和\(yzw\)组队。DAY1昨晚睡得有点晚,但是问题不大,\(11:00\)才开赛。开\(M\)题彩蛋。发现是中国剩余定理,由于我不会,只能手玩,过了之后发现已经花了\(2\)分钟,还行......