简介
本文档提供关于数据万象图像增强的 API 概览以及 SDK 示例代码。
注意:
COS Node.js SDK 版本需要大于等于 v2.11.2。
待处理的图片,原图大小不超过 5MB。
API | 说明 |
腾讯云数据万象通过 AIEnhanceImage 接口对图像进行增强处理。 |
上传时处理
下面示例展示了如何在上传图片时自动实现图像增强。
图片上传完成后,COS 会存储原始图片和已处理过的图片。后续用户可以通过普通的下载请求获取处理结果。
示例代码
function handleFileInUploading() {// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/8629const filePath = 'temp-file-to-upload'; // 本地文件路径cos.putObject({// 需要替换成您自己的存储桶信息Bucket: 'examplebucket-1250000000', // 存储桶,必须字段Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijingKey: 'folder/document.jpg', // 对象文件名,例如:folder/document.jpgBody: fs.createReadStream(filePath), // 上传文件对象,必填ContentLength: fs.statSync(filePath).size, // 上传文件对象大小,当上传Body为文件流且需要正确展示上传进度时必填Headers: {// 通过 AIEnhanceImage 接口使用图像增强功能:指定图片锐化强度值 5,去噪强度值 3'Pic-Operations': JSON.stringify({is_pic_info: 1,rules: [{ fileid: 'test.jpg', rule: 'ci-process=AIEnhanceImage' }]}),},},function (err, data) {if (err) {// 处理请求失败console.log(err);} else {// 处理请求成功console.log(data);}});}handleFileInUploading();
参数说明
参数名称 | 描述 | 类型 | 是否必选 |
Bucket | 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 | String | 是 |
Region | String | 是 | |
Key | 对象文件名,例如:folder/document.jpg | String | 是 |
Body | 文件内容 | Buffer/String | 是 |
ContentLength | 上传文件内容长度,需要展示进度时必填 | Number | 否 |
Pic-Operations | 只需填写 fileid,代表处理后的图片路径,如'test.jpg'。rule 固定为ci-process=AIEnhanceImage | JsonString | 是 |
回调函数说明
function(err, data) { ... }
对云上数据进行图像增强
下面示例展示了如何在对已存储在 COS 的图片进行图像增强操作,并将结果存入到 COS。
示例代码
function handleFileInBucket() {// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/11459cos.request({// 需要替换成您自己的存储桶信息Bucket: 'examplebucket-1250000000', // 存储桶,必须字段Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijingKey: '1/jpg', // 对象文件名,例如:folder/document.jpg。Method: 'POST', // 固定值Action: 'image_process', // 固定值Headers: {// 通过 AIEnhanceImage 接口使用图像增强功能:指定图片锐化强度值 5,去噪强度值 3'Pic-Operations': JSON.stringify({rules: [{ fileid: 'test.jpg', rule: 'ci-process=AIEnhanceImage' }]}),},},function (err, data) {if (err) {// 处理请求失败console.log(err);} else {// 处理请求成功console.log(data);}});}handleFileInBucket();
参数说明
参数名称 | 描述 | 类型 | 是否必选 |
Bucket | 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 | String | 是 |
Region | String | 是 | |
Key | 对象文件名,例如:folder/document.jpg | String | 是 |
Method | 固定值:POST | String | 是 |
Action | 固定值:image_process | String | 是 |
Pic-Operations | 只需填写 fileid,代表处理后的图片路径,如'test.jpg'。rule固定为 ci-process=AIEnhanceImage | JsonString | 是 |
回调函数说明
function(err, data) { ... }
下载时使用图像增强
下面示例展示了如何在下载图片时实现图像增强。
示例代码
function getObject() {// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/11459cos.request({// 需要替换成您自己的存储桶信息Bucket: 'examplebucket-1250000000', // 存储桶,必须字段Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijingMethod: 'GET', // 固定值Key: '1/jpg', // 对象文件名,例如:folder/document.jpg。Query: {'ci-process': 'AIEnhanceImage', // 固定值denoise: 5 /*非必需,去噪强度值,取值范围为 0 - 5 之间的整数,值为 0 时不进行去噪操作,默认值为3*/,sharpen: 5 /* 非必需,锐化强度值,取值范围为 0 - 5 之间的整数,值为 0 时不进行锐化操作,默认值为3*/,detect-url:'http%25253A%25252F%25252Fwww.example.com%25252Fabc.jpg' /* 非必须,可以通过填写 detect-url 处理任意公网可访问的图片链接。不填写 detect-url 时,后台会默认处理 Key ,填写了 detect-url 时,后台会处理 detect-url 链接,detect-url 需要进行 UrlEncode */},},function (err, data) {if (err) {// 处理请求失败console.log(err);} else {// 处理请求成功console.log(data);const localPath = 'xxx'; // 填写要写入的本地文件路径fs.writeFileSync(localPath, data.Body); // 将图片内容保存本地路径}});}getObject();
参数说明
cos.request 方法参数说明:
参数名称 | 描述 | 类型 | 是否必选 |
Bucket | 存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式 | String | 是 |
Region | String | 是 | |
Method | 固定值:GET | String | 是 |
Key | 对象文件名,例如:folder/document.jpg | String | 是 |
Query | 其他请求参数 | Container | 是 |
Query 参数说明:
参数名称 | 描述 | 类型 | 是否必选 |
ci-process | 数据万象处理能力,图像增强固定为 AIEnhanceImage。 | String | 是 |
denoise | 去噪强度值,取值范围为 0 - 5 之间的整数,值为 0 时不进行去噪操作,默认值为 3。 | Integer | 否 |
sharpen | 锐化强度值,取值范围为 0 - 5 之间的整数,值为 0 时不进行锐化操作,默认值为 3。 | Integer | 否 |
detect-url | 处理任意公网可访问的图片链接。不填写 detect-url 时,后台会默认处理 Key ,填写了 detect-url 时,后台会处理 detect-url 链接。 detect-url 示例: http://www.example.com/abc.jpg ,需要进行 UrlEncode,处理后为 http%25253A%25252F%25252Fwww.example.com%25252Fabc.jpg 。 | String | 否 |
回调函数说明
function(err, data) { ... }