tt.saveImageToPhotosAlbum收藏我的收藏
收藏
我的收藏基础库 1.0.0 开始支持本方法,这是一个异步方法。
保存图片到系统相册。
前提条件 | 无 |
业务背景 | 无 |
使用限制 | 无 |
注意事项 | 手动取消也会触发失败回调,回调参数为 saveImageToPhotosAlbum:fail cancel,可以通过判断详细错误信息区分取消和其他错误。 |
支持沙盒 | 否 |
相关教程 | 无 |
语法
tt.saveImageToPhotosAlbum(options)
参数说明
options 为 object 类型,属性如下:
属性名 | 类型 | 默认值 | 必填 | 说明 | 最低支持版本 |
---|---|---|---|---|---|
filePath | string | 否 | 图片文件路径,可以是临时文件路径,如调用 `tt.downloadFile` 或 `tt.compressImage` 等 API 返回的路径。也可以是永久文件路径,不支持网络路径 | 1.0.0 | |
success | function | 否 | 接口调用成功的回调函数 | 1.0.0 | |
fail | function | 否 | 接口调用失败的回调函数 | 1.0.0 | |
complete | function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) | 1.0.0 |
回调成功
object 类型,属性如下:
属性名 | 类型 | 说明 | 最低支持版本 |
---|---|---|---|
errMsg | string | "saveImageToPhotosAlbum:ok" | 1.0.0 |
回调失败
object 类型,属性如下:
属性名 | 类型 | 说明 | 最低支持版本 |
---|---|---|---|
errMsg | string | "saveImageToPhotosAlbum:fail" + 详细错误信息 | 1.0.0 |
错误码
errorCode | errMsg | errorType | 说明 | 最低支持版本 |
---|---|---|---|---|
112090 | saveImageToPhotosAlbum:fail auth deny | U | 拒绝授权 用户未授予小程序授权,请引导用户按需 授权,详情参考 用户授权 | 1.0.0 |
112089 | saveImageToPhotosAlbum:fail system auth deny | U | 用户拒绝授权系统权限 用户未授予系统权限,请引导用户按需授权 | 1.0.0 |
112002 | saveImageToPhotosAlbum:fail can't support this image format | D | 不支持的图片格式 检查格式 | 1.0.0 |
112099 | saveImageToPhotosAlbum:fail filePath is invalid | D | filePath为空 检查文件路径 | 1.0.0 |
112079 | saveImageToPhotosAlbum:fail api scope is not declared in the privacy agreement | D | 隐私能力不在申请的 scope 内 检查隐私协议 | 1.0.0 |
112001 | saveImageToPhotosAlbum:fail no such file or directory ${ttFilePath} | D | 路径错误 检查文件/文件夹路径 | 1.0.0 |
112080 | saveImageToPhotosAlbum:fail privacy permission is not authorized | U | 隐私协议未授权 用户未授权隐私协议,请引导用户按需授权 | 1.0.0 |
112093 | saveImageToPhotosAlbum:fail unknown error xxx | F | 小程序框架内部错误,有需要请创建工单咨询 | 1.0.0 |
112003 | saveImageToPhotosAlbum:fail permission denied, read xxx | D | 无读权限 检查文件/文件夹路径 | 1.0.0 |
扫码体验
请使用字节宿主APP扫码
代码示例
<!-- index.ttml --> <view class="card-area"> <image mode="widthFix" src="{{filePath}}" style="width: 300px"></image> <button type="primary" bindtap="saveImageToPhotosAlbum">保存</button> </view>
// index.js Page({ data: { filePath: "https://s3.pstatp.com/toutiao/static/img/logo.201f80d.png", }, saveImageToPhotosAlbum() { tt.downloadFile({ url: this.data.filePath, header: { "content-type": "application/json", }, success: (res) => { let filePath = res.tempFilePath; tt.saveImageToPhotosAlbum({ filePath, // 暂不支持网络图片/本地图片地址,需与tt.downloadFile一起使用 success: (res) => { tt.showToast({ title: "成功保存到本地相册" }); }, fail: (err) => { let errType = err.errMsg.includes( "saveImageToPhotosAlbum:fail cancel" ) ? "取消保存" : "保存失败"; tt.showModal({ title: errType, content: err.errMsg, showCancel: false, }); }, }); }, fail: (err) => { tt.showModal({ title: "下载出错", content: err.errMsg, showCancel: false, }); }, }); }, });
点击纠错