# frozen_string_literal: true # Copyright (c) 2017-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. require 'json' module TencentCloud module Tts module V20190823 class Client < TencentCloud::Common::AbstractClient def initialize(credential, region, profile = nil) api_version = '2019-08-23' api_endpoint = 'tts.tencentcloudapi.com' sdk_version = 'TTS_' + File.read(File.expand_path('../VERSION', __dir__)).strip super(credential, region, api_version, api_endpoint, sdk_version, profile) end # 本接口服务对10万字符以内的文本进行语音合成,异步返回音频结果。满足一次性合成较长文本的客户需求,如阅读播报、新闻媒体等场景。 #
  • 支持音频格式:mp3,wav,pcm
  • #
  • 支持音频采样率:16000 Hz, 8000 Hz
  • #
  • 支持中文普通话、英文、中英文混读、粤语合成
  • #
  • 支持语速、音量设置
  • #
  • 支持回调或轮询的方式获取结果,结果获取请参考 长文本语音合成结果查询。
  • #
  • 提交长文本语音合成请求后,合成结果在3小时内完成,音频文件在服务端可保存24小时
  • #

    # 长文本合成支持 SSML,语法详见 [SSML 标记语言](https://cloud.tencent.com/document/product/1073/49575),使用时需满足如下使用规范: #
  • 使用 SSML 标签,需置于 speak 闭合标签内部;
  • #
  • 合成文本可包含多组 speak 闭合标签,且无数量限制;
  • #
  • 每个 speak 闭合标签内部,字符数不超过 150 字(标签字符本身不计算在内);
  • #
  • 每个 speak 闭合标签内部,使用 break 标签数目最大为 10 个。如需要使用更多,可拆解到多个 speak 标签中;
  • #

    # @param request: Request instance for CreateTtsTask. # @type request: :class:`Tencentcloud::tts::V20190823::CreateTtsTaskRequest` # @rtype: :class:`Tencentcloud::tts::V20190823::CreateTtsTaskResponse` def CreateTtsTask(request) body = send_request('CreateTtsTask', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = CreateTtsTaskResponse.new model.deserialize(response['Response']) model else code = response['Response']['Error']['Code'] message = response['Response']['Error']['Message'] reqid = response['Response']['RequestId'] raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid) end rescue TencentCloud::Common::TencentCloudSDKException => e raise e rescue StandardError => e raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect) end # 在调用长文本语音合成请求接口后,有回调和轮询两种方式获取识别结果。 #
  • 当采用回调方式时,合成完毕后会将结果通过 POST 请求的形式通知到用户在请求时填写的回调 URL,具体请参见 长文本语音合成结果查询 。
  • #
  • 当采用轮询方式时,需要主动提交任务ID来轮询识别结果,共有任务成功、等待、执行中和失败四种结果,具体信息请参见下文说明。
  • # @param request: Request instance for DescribeTtsTaskStatus. # @type request: :class:`Tencentcloud::tts::V20190823::DescribeTtsTaskStatusRequest` # @rtype: :class:`Tencentcloud::tts::V20190823::DescribeTtsTaskStatusResponse` def DescribeTtsTaskStatus(request) body = send_request('DescribeTtsTaskStatus', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = DescribeTtsTaskStatusResponse.new model.deserialize(response['Response']) model else code = response['Response']['Error']['Code'] message = response['Response']['Error']['Message'] reqid = response['Response']['RequestId'] raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid) end rescue TencentCloud::Common::TencentCloudSDKException => e raise e rescue StandardError => e raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect) end # 腾讯云语音合成技术(TTS)可以将任意文本转化为语音,实现让机器和应用张口说话。 # 腾讯TTS技术可以应用到很多场景,比如,移动APP语音播报新闻;智能设备语音提醒;依靠网上现有节目或少量录音,快速合成明星语音,降低邀约成本;支持车载导航语音合成的个性化语音播报。 # 基础合成支持 SSML,语法详见 [SSML 标记语言](https://cloud.tencent.com/document/product/1073/49575)。 # 默认接口请求频率限制: # 精品音色和标准音色:20次/秒 # 大模型音色:10次/秒 # 一句话复刻音色:5次/秒 # @param request: Request instance for TextToVoice. # @type request: :class:`Tencentcloud::tts::V20190823::TextToVoiceRequest` # @rtype: :class:`Tencentcloud::tts::V20190823::TextToVoiceResponse` def TextToVoice(request) body = send_request('TextToVoice', request.serialize) response = JSON.parse(body) if response['Response'].key?('Error') == false model = TextToVoiceResponse.new model.deserialize(response['Response']) model else code = response['Response']['Error']['Code'] message = response['Response']['Error']['Message'] reqid = response['Response']['RequestId'] raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid) end rescue TencentCloud::Common::TencentCloudSDKException => e raise e rescue StandardError => e raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect) end end end end end