news 2026/5/1 11:26:59

二十四、【鸿蒙 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/5/1 5:53:44

MathType公式库扩充计划引入语音录入方式

MathType公式库扩充计划引入语音录入方式 在数学教学、科研写作和数字出版的日常实践中,输入复杂的数学表达式始终是一项繁琐且技术门槛较高的任务。传统的键盘输入依赖LaTeX语法或图形化编辑器的点选操作,对教师、学生尤其是非专业用户而言,…

作者头像 李华
网站建设 2026/5/1 5:54:34

PyCharm社区版用户成功运行Fun-ASR后端

PyCharm社区版用户成功运行Fun-ASR后端 在如今AI模型动辄需要云服务器、专业IDE和复杂部署流程的背景下,一个看似“不可能”的任务正在悄然成为现实:使用免费的PyCharm社区版,在一台普通笔记本上完整运行通义实验室与钉钉联合推出的Fun-ASR语…

作者头像 李华
网站建设 2026/5/1 5:56:12

进度条可视化:实时显示长文本合成剩余时间

进度条可视化:实时显示长文本合成剩余时间 在有声读物平台的后台,一位编辑上传了一段三万字的小说章节,点击“语音合成”后,页面陷入长达数分钟的静默。没有进度提示、没有时间预估,只有浏览器标签上缓慢旋转的加载图标…

作者头像 李华
网站建设 2026/5/1 5:54:52

数字电路实验与工业传感器接口设计:系统学习

从实验室到工厂现场:数字电路与工业传感器接口的实战之路你有没有遇到过这样的情况?在实验室里调试得好好的传感器系统,一搬到工厂现场就“水土不服”——数据跳变、通信中断、偶尔死机。明明代码没改,硬件也没动,问题…

作者头像 李华
网站建设 2026/5/1 7:00:16

微pe驱动加载确保GPU正常工作支持GLM-TTS

微PE驱动加载确保GPU正常工作支持GLM-TTS 在边缘计算与现场部署日益普及的今天,如何让复杂的生成式AI模型在资源受限、无盘或快速启动的环境中稳定运行,已成为一个关键挑战。设想这样一个场景:你需要在一台没有硬盘的工控机上,仅通…

作者头像 李华
网站建设 2026/5/1 7:00:31

Discord社群运营:打造全球化GLM-TTS爱好者交流空间

Discord社群运营:打造全球化GLM-TTS爱好者交流空间 在AI语音技术飞速发展的今天,我们不再满足于“能说话”的机器声音。无论是为动画角色赋予灵魂,还是让有声书朗读充满情感起伏,亦或是构建个性化的虚拟助手,用户对语音…

作者头像 李华