x-screenshot-s
开发文档
- 可以对窗口进行静默截图
- 可以对某一个view节点进行截图
应用场景
- 对产品端,给用户反馈保存时,可以对当前反馈的页面进行截图反馈,比如界面异常上传等
- 对局部节点截图保存可以进行对局部的分享保存,比如页面的排版海报
- 对整个页面分享保存
兼容性
| Harmony | IOS | Android | WEB | 小程序 |
|---|---|---|---|---|
| 支持 | 支持 | 支持 | x | x |
注意事项
使用前一定要打基座才可用,一定要在页面上先引用,再去打基座。 如果你mac开发。ios可以不用打基座,能直接使用(但前提是你要配置好原生开发环境,否则一样要打包) 如果你是开始安卓,不管是mac,win电脑都要打包基座才能使用。
API说明
getRootShotImage
ts
type XScreenshotResult = { path: string }
type XScreenshotRootOpts = {
/** 保存格式,默认 png,可选 jpg */
format?: 'png' | 'jpg'
success?: (res: XScreenshotResult) => void
fail?: (res: XScreenshotFail) => void
complete?: (res: XScreenshotResult | null) => void
}
function getRootShotImage(opts: XScreenshotRootOpts): void参数说明:
- opts.format:图片格式,
png(默认;节点截图仅绘制目标 View,临时清除目标节点自身 background 以保留透明底;子节点 background 仍按其自身渲染)或jpg(无透明通道,节点会合成父级/页面背景,更适合需要保留容器自身背景的场景) - opts.success:成功回调,
res.path为截图保存后的本地文件路径 - opts.fail:失败回调,返回标准
IUniError错误对象 - opts.complete:无论成功失败都会执行
getElementShotImage
ts
type XScreenshotElementOpts = {
ele?: UniElement | null
/** 保存格式,默认 png,可选 jpg */
format?: 'png' | 'jpg'
success?: (res: XScreenshotResult) => void
fail?: (res: XScreenshotFail) => void
complete?: (res: XScreenshotResult | null) => void
}
function getElementShotImage(opts: XScreenshotElementOpts): void参数说明:
- opts.ele:要截图的目标元素;为空时
fail错误码1003 - opts.success / opts.fail / opts.complete:同窗口截图
示例代码
vue
<template>
<x-sheet id="screentIds">
<x-button class="mb-16" :block="true" @click="getScreenimg">保存屏幕图片</x-button>
<x-button :block="true" @click="getSEleimg">保存节点截图</x-button>
</x-sheet>
</template>
<script setup lang="ts">
import {getRootShotImage, getElementShotImage} from "@/uni_modules/x-screenshot-s"
const getScreenimg = () => {
getRootShotImage({
format: 'png',
success: (res) => {
uni.previewImage({
current: res.path,
urls: [res.path] as string[]
})
},
fail: (err) => {
console.error(err)
}
})
}
const getSEleimg = () => {
let ele = uni.getElementById("screentIds") as UniElement|null
getElementShotImage({
ele: ele,
success: (res) => {
uni.previewImage({
current: res.path,
urls: [res.path] as string[]
})
},
fail: (err) => {
console.error(err)
}
})
}
</script>常见问题
截图黑屏或无内容
- 确保已正确打包基座
- 检查目标View是否已完成渲染
- Android端确保View的宽高不为0
- 节点内含
<video>、TextureView 等视频层时,请升级至 1.0.3+;Android 7.0+ 使用 PixelCopy 合成画面,低版本回退 TextureView 叠加绘制
截图文件路径无效
- 检查应用是否有存储权限
- 确保缓存目录可写入
性能注意事项
- 大尺寸View截图可能占用较多内存
- 建议在截图后及时释放不需要的图片资源
更新日志
1.0.5(2026-05-21)
- 修复 Android 节点 PNG 透明背景被合成白底:png 仅绘制目标 View,不再使用 PixelCopy/根节点裁剪(jpg 仍保留屏幕合成以呈现父级背景)。
- 进一步:PNG 节点截图绘制时临时清除目标节点自身 background(uni 容器常自带白底),绘制完即时恢复;子节点 background 不受影响。
1.0.4(2026-05-21)
- 修复 PNG 截图白底:iOS 设置
opaque=false(jpg 仍为不透明);节点/窗口均使用drawHierarchy(in:bounds),避免window坐标截取导致黑图。 - Android Canvas 回退路径从根 View 裁剪绘制,保留父级背景色。
1.0.3(2026-05-21)
- 新增
format参数,支持png、jpg保存格式,默认 png。 - 修复节点内含视频/TextureView 等组件时截图黑屏(Android):优先
PixelCopy窗口拷贝,失败时回退 Canvas 并叠加 TextureView 画面;iOS 保持drawHierarchy(afterScreenUpdates:true)以保障常规页面截图正常。 - 新增错误码
1007:format参数非法。
1.0.2(2026-05-21)
- 破坏性变更:API 改为 uni 标准 opts 回调风格
- 已使用的项目升级前请阅读 readme 示例,不可直接替换旧版回调写法。
1.0.1(2025-07-27)
- 兼容鸿蒙
1.0.0(2024-12-18)
- 对屏幕截图保存(不需要权限),对指定截图进行保存,安卓,ios支持,web不支持.
