有奖捉虫:办公协同&微信生态&物联网文档专题 HOT

简介

本文档提供关于数据万象图像增强的 API 概览以及 SDK 示例代码。
注意:
COS Javascript SDK 版本需要大于等于 v1.3.2。
待处理的图片,原图大小不超过 5MB。
API
说明
腾讯云数据万象通过 AIEnhanceImage 接口对图像进行增强处理。

上传时处理

下面示例展示了如何在上传图片时自动实现图像增强。 图片上传完成后,COS 会存储原始图片和已处理过的图片。后续用户可以通过普通的下载请求获取处理结果。

示例代码

<!-- html 页面 DOM 元素 -->

<!-- 选择要上传的文件 -->
<input id="fileSelector" type="file" />
<!-- 点击按钮上传 -->
<input id="submitBtn" type="submit" />
function handleFileInUploading(file) {
// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/11459
cos.putObject(
{
// 需要替换成您自己的存储桶信息
Bucket: 'examplebucket-1250000000', // 存储桶,必须字段
Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijing
Key: file.name, // 对象文件名,例如:folder/document.jpg,可以设置为本地文件的名称file.name
Body: file, // 选择要上传的文件
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);
}
}
);
}

document.getElementById('submitBtn').onclick = function (e) {
var file = document.getElementById('fileSelector').files[0];
if (!file) {
document.getElementById('msg').innerText = '未选择上传文件';
return;
}
handleFileInUploading(file);
};

参数说明

参数名称
描述
类型
是否必选
Bucket
存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式
String
Region
存储桶所在地域,枚举值请参见 地域和访问域名
String
Key
对象文件名,例如:folder/document.jpg
String
Body
文件内容,一般传入选择的文件file对象
File/Blob
Pic-Operations
只需填写 fileid,代表处理后的图片路径,如'test.jpg'。rule固定为ci-process=AIEnhanceImage
JsonString

回调函数说明

function(err, data) { ... }
参数名称
参数描述
类型
err
请求发生错误时返回的对象,包括网络错误和业务错误。如果请求成功则为空,更多详情请参见 错误码
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
data
请求成功时返回的对象,如果请求发生错误,则为空
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
- Response
响应结果 详情请参见 图像增强
Object

对云上数据进行图像增强

下面示例展示了如何在对已存储在 COS 的图片进行图像增强操作,并将结果存入到 COS。

示例代码

<!-- html 页面 DOM 元素 -->

<!-- 点击按钮请求对云上数据进行图像增强 -->
<input id="submitBtn" type="submit" />
function handleFileInBucket() {
// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/11459
cos.request(
{
// 需要替换成您自己的存储桶信息
Bucket: 'examplebucket-1250000000', // 存储桶,必须字段
Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijing
Key: '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);
}
}
);
}

document.getElementById('submitBtn').onclick = function (e) {
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) { ... }
参数名称
参数描述
类型
err
请求发生错误时返回的对象,包括网络错误和业务错误。如果请求成功则为空,更多详情请参见 错误码
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
data
请求成功时返回的对象,如果请求发生错误,则为空
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
- Response
响应结果 详情请参见 图像增强
Object

下载时使用图像增强

下面示例展示了如何在下载图片时实现图像增强。

示例代码

<!-- html 页面 DOM 元素 -->

<!-- 点击按钮下载文件并在下载时使用图像增强 -->
<input id="submitBtn" type="submit" />
function getObject() {
// sdk引入以及初始化请参考:https://cloud.tencent.com/document/product/436/11459
cos.request(
{
// 需要替换成您自己的存储桶信息
Bucket: 'examplebucket-1250000000', // 存储桶,必须字段
Region: 'COS_REGION', // 存储桶所在地域,必须字段 如 ap-beijing
Method: '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 */
},
RawBody: true, // 固定为true,不解析请求体Body
DataType: 'blob', // 设置为blob,返回Body为图片blob
},
function (err, data) {
if (err) {
// 处理请求失败
console.log(err);
} else {
// 处理请求成功
console.log(data);
}
}
);
}

参数说明

cos.request 方法参数说明:
参数名称
描述
类型
是否必选
Bucket
存储桶的名称,命名格式为 BucketName-APPID,此处填写的存储桶名称必须为此格式
String
Region
存储桶所在地域,枚举值请参见 地域和访问域名
String
Method
固定值:GET
String
Key
对象文件名,例如:folder/document.jpg
String
Query
其他请求参数
Container
RawBody
固定为true,不解析请求体Body
Boolean
DataType
设置为blob,返回Body为图片blob
String
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) { ... }
参数名称
参数描述
类型
err
请求发生错误时返回的对象,包括网络错误和业务错误。如果请求成功则为空,更多详情请参见 错误码
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
data
请求成功时返回的对象,如果请求发生错误,则为空
Object
- statusCode
请求返回的 HTTP 状态码,例如200、403、404等
Number
- headers
请求返回的头部信息
Object
- Response
响应结果 详情请参见 图像增强
Object

相关链接