news 2026/3/29 16:24:10

二十四、【鸿蒙 NEXT】对组件截图

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
二十四、【鸿蒙 NEXT】对组件截图

【前言】

我们部分场景可能会有这种诉求,将页面中的某个组件进行截图,并将截图展示出来。下面我们介绍下如何在鸿蒙next系统中实现组件截图功能。

1、注册监听组件绘制完成的事件

我们要截图,首先要等组件绘制完成后才进行,否则截出的图片可能是一片空白,实现如下,主要用到的系统接口是inspector.ComponentObserver,其中'img'是Row组件的id,这里主要监听Row组件的draw事件,表示已经绘制完成

private listener:inspector.ComponentObserver = this.getUIContext().getUIInspector().createComponentObserver('img') this.listener.on('draw', () => { // todo 截取组件图片 }) build(){ Row(){ Image($r('app.media.startIcon')).width(100).height(100) Image($r('app.media.startIcon')).width(100).height(100) }.id('img') }

2、实现组件截图

在绘制完成的事件里面实现组件截图,代码如下,这里'img'是id,originImg的值是一个PiexelMap对象,可以直接传给Image组件展示,或者做其他操作

this.originImg = await this.getUIContext().getComponentSnapshot().get('img')

如果需要对获取的截图进行一些裁剪操作,比如高度裁剪一半,代码实现如下,这里主要用到了offscreenCanvas对象,实现图像裁剪的效果,其中screenCanvasContext.getPixelMap(0,50, viewWidth,viewHeight),0表示x轴方向不裁剪,50表示y轴方向,从50vp开始裁剪图片。

this.originImg = await this.getUIContext().getComponentSnapshot().get('img') let viewInfo = this.getUIContext().getComponentUtils().getRectangleById('img') let viewWidth = this.getUIContext().px2vp(viewInfo.size.width) let viewHeight = this.getUIContext().px2vp(viewInfo.size.height) let screenCanvas = new OffscreenCanvas(viewWidth, viewHeight) let screenCanvasContext = screenCanvas.getContext('2d', new RenderingContextSettings(true)) screenCanvasContext.drawImage(this.originImg,0,0,viewWidth,viewHeight) this.cropImg = screenCanvasContext.getPixelMap(0,50, viewWidth,viewHeight)

实现图片截取的效果如下:

完整的代码实现如下,这里注意下,截取组件图片时,使用了setTimeout函数,这里如果不使用的话会出现截出空白图片的情况。另外,这里的Row组件中的Image图片也可以是网络图片,这里的截图方式,即使是网络图片也能实现截图。这里之所以要做px2vp操作,是因为OffscreenCanvas接收的是vp为单位的数值,而getComponentSnapshot获取的宽高是px为单位的数值

import { inspector } from '@kit.ArkUI'; @Entry @Component struct DrawPage { @State message: string = 'Hello World'; @State originImg:PixelMap|null = null @State cropImg:PixelMap|null = null private listener:inspector.ComponentObserver = this.getUIContext().getUIInspector().createComponentObserver('img') private onDrawComplete = () => { setTimeout(async () => { this.originImg = await this.getUIContext().getComponentSnapshot().get('img') let viewInfo = this.getUIContext().getComponentUtils().getRectangleById('img') let viewWidth = this.getUIContext().px2vp(viewInfo.size.width) let viewHeight = this.getUIContext().px2vp(viewInfo.size.height) let screenCanvas = new OffscreenCanvas(viewWidth, viewHeight) let screenCanvasContext = screenCanvas.getContext('2d', new RenderingContextSettings(true)) screenCanvasContext.drawImage(this.originImg,0,0,viewWidth,viewHeight) this.cropImg = screenCanvasContext.getPixelMap(0,50, viewWidth,viewHeight) },500) } aboutToAppear(): void { this.listener.on('draw', this.onDrawComplete) } build() { Column() { Text('原始组件:') Row(){ Image($r('app.media.startIcon')).width(100).height(100) Image($r('app.media.startIcon')).width(100).height(100) }.id('img') Column().height(20) Text('截取的完整图片:') Image(this.originImg).width(200).height(100) Column().height(20) Text('裁剪一半的图片:') Image(this.cropImg).width(200).height(100) } .height('100%') .width('100%') } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/20 7:00:16

谷歌翻译API对比Fun-ASR中文识别准确率

谷歌翻译API对比Fun-ASR中文识别准确率 在智能语音应用日益普及的今天,越来越多开发者尝试将语音内容自动转换为文字。然而一个常见的误区是:误以为像谷歌翻译这样的机器翻译服务也能“听懂”语音。尤其是在处理中文语音时,不少项目初期直接调…

作者头像 李华
网站建设 2026/3/26 4:55:46

JavaScript前端如何对接GLM-TTS后端API实现网页语音合成

JavaScript前端如何对接GLM-TTS后端API实现网页语音合成 在智能内容生成(AIGC)浪潮席卷各行各业的今天,语音合成已不再是实验室里的高冷技术,而是逐渐渗透进我们日常使用的每一个应用中——从有声书平台到虚拟主播直播&#xff0c…

作者头像 李华
网站建设 2026/3/24 14:53:32

网盘回收站恢复误删的Fun-ASR重要文件

网盘回收站恢复误删的Fun-ASR重要文件 在一次例行模型更新中,某企业AI运维团队不小心执行了 rm -rf models/ 命令,导致部署在本地服务器上的 Fun-ASR 语音识别系统瞬间“失声”——所有识别任务报错,历史记录无法加载。更糟的是,他…

作者头像 李华
网站建设 2026/3/26 8:21:48

MathType学生版价格贵?Fun-ASR教育免费用

Fun-ASR:用免费语音识别打破教育技术壁垒 在一所普通中学的英语课堂上,老师刚结束一段听力训练。几个学生举手提问:“老师,刚才那段话里‘global warming’后面说的是‘carbon emissions’还是‘carbon footprint’?”…

作者头像 李华
网站建设 2026/3/27 23:04:03

语音合成中的专业术语发音校正:医学、法律等领域适配

语音合成中的专业术语发音校正:医学、法律等领域适配 在三甲医院的智能导诊系统中,AI语音将“冠心病”读成“gun xīn bng”,而非正确的“guān xīn bng”——这看似微小的偏差,可能让患者误解为“灌注性心脏病”,进而…

作者头像 李华
网站建设 2026/3/28 4:06:35

Markdown流程图mermaid语法语音输入尝试

Fun-ASR 语音识别系统深度解析:从本地化部署到智能交互的实践之路 在远程办公、在线教育和智能会议日益普及的今天,如何高效地将语音内容转化为可编辑、可检索的文字,已成为许多企业和个人面临的现实挑战。传统的语音识别工具要么依赖云端服务…

作者头像 李华