Files

149 lines
6.7 KiB
C#
Raw Permalink Normal View History

/*
* Copyright (c) 2018 THL A29 Limited, a Tencent company. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
namespace TencentCloud.Facefusion.V20181201
{
using Newtonsoft.Json;
using System.Threading.Tasks;
using TencentCloud.Common;
using TencentCloud.Common.Profile;
using TencentCloud.Facefusion.V20181201.Models;
public class FacefusionClient : AbstractClient{
private const string endpoint = "facefusion.tencentcloudapi.com";
private const string version = "2018-12-01";
/// <summary>
/// Client constructor.
/// </summary>
/// <param name="credential">Credentials.</param>
/// <param name="region">Region name, such as "ap-guangzhou".</param>
public FacefusionClient(Credential credential, string region)
: this(credential, region, new ClientProfile())
{
}
/// <summary>
/// Client Constructor.
/// </summary>
/// <param name="credential">Credentials.</param>
/// <param name="region">Region name, such as "ap-guangzhou".</param>
/// <param name="profile">Client profiles.</param>
public FacefusionClient(Credential credential, string region, ClientProfile profile)
: base(endpoint, version, credential, region, profile)
{
}
/// <summary>
/// 本接口用于人脸融合用户上传人脸图片获取与模板融合后的人脸图片。未发布的活动请求频率限制为1次/秒已发布的活动请求频率限制50次/秒。如有需要提高活动的请求频率限制,请在控制台中申请。
/// >
/// - 公共参数中的签名方式必须指定为V3版本即配置SignatureMethod参数为TC3-HMAC-SHA256。
/// </summary>
/// <param name="req"><see cref="FaceFusionRequest"/></param>
/// <returns><see cref="FaceFusionResponse"/></returns>
public async Task<FaceFusionResponse> FaceFusion(FaceFusionRequest req)
{
JsonResponseModel<FaceFusionResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "FaceFusion");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<FaceFusionResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 本接口用于人脸融合用户上传人脸图片获取与模板融合后的人脸图片。未发布的活动请求频率限制为1次/秒已发布的活动请求频率限制50次/秒。如有需要提高活动的请求频率限制,请在控制台中申请。
/// >
/// - 公共参数中的签名方式必须指定为V3版本即配置SignatureMethod参数为TC3-HMAC-SHA256。
/// </summary>
/// <param name="req"><see cref="FaceFusionRequest"/></param>
/// <returns><see cref="FaceFusionResponse"/></returns>
public FaceFusionResponse FaceFusionSync(FaceFusionRequest req)
{
JsonResponseModel<FaceFusionResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "FaceFusion");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<FaceFusionResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 本接口用于单脸、多脸融合,用户上传人脸图片,获取与模板融合后的人脸图片。查看 <a href="https://cloud.tencent.com/document/product/670/38247" target="_blank">选脸融合接入指引</a>。
///
/// 未发布的活动请求频率限制为1次/秒已发布的活动请求频率限制50次/秒。如有需要提高活动的请求频率限制,请在控制台中申请。
/// >
/// - 公共参数中的签名方式必须指定为V3版本即配置SignatureMethod参数为TC3-HMAC-SHA256。
/// </summary>
/// <param name="req"><see cref="FuseFaceRequest"/></param>
/// <returns><see cref="FuseFaceResponse"/></returns>
public async Task<FuseFaceResponse> FuseFace(FuseFaceRequest req)
{
JsonResponseModel<FuseFaceResponse> rsp = null;
try
{
var strResp = await this.InternalRequest(req, "FuseFace");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<FuseFaceResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
/// <summary>
/// 本接口用于单脸、多脸融合,用户上传人脸图片,获取与模板融合后的人脸图片。查看 <a href="https://cloud.tencent.com/document/product/670/38247" target="_blank">选脸融合接入指引</a>。
///
/// 未发布的活动请求频率限制为1次/秒已发布的活动请求频率限制50次/秒。如有需要提高活动的请求频率限制,请在控制台中申请。
/// >
/// - 公共参数中的签名方式必须指定为V3版本即配置SignatureMethod参数为TC3-HMAC-SHA256。
/// </summary>
/// <param name="req"><see cref="FuseFaceRequest"/></param>
/// <returns><see cref="FuseFaceResponse"/></returns>
public FuseFaceResponse FuseFaceSync(FuseFaceRequest req)
{
JsonResponseModel<FuseFaceResponse> rsp = null;
try
{
var strResp = this.InternalRequestSync(req, "FuseFace");
rsp = JsonConvert.DeserializeObject<JsonResponseModel<FuseFaceResponse>>(strResp);
}
catch (JsonSerializationException e)
{
throw new TencentCloudSDKException(e.Message);
}
return rsp.Response;
}
}
}