# 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. module TencentCloud module Aiart module V20221229 # ImageToImage请求参数结构体 class ImageToImageRequest < TencentCloud::Common::AbstractModel # @param InputImage: 输入图 Base64 数据。 # 算法将根据输入的图片,结合文本描述智能生成与之相关的图像。 # Base64 和 Url 必须提供一个,如果都提供以 Base64 为准。 # 图片限制:单边分辨率小于2000,转成 Base64 字符串后小于 5MB。 # @type InputImage: String # @param InputUrl: 输入图 Url。 # 算法将根据输入的图片,结合文本描述智能生成与之相关的图像。 # Base64 和 Url 必须提供一个,如果都提供以 Base64 为准。 # 图片限制:单边分辨率小于2000,转成 Base64 字符串后小于 5MB。 # @type InputUrl: String # @param Prompt: 文本描述。 # 用于在输入图的基础上引导生成图效果,增加生成结果中出现描述内容的可能。 # 推荐使用中文。最多支持256个 utf-8 字符。 # @type Prompt: String # @param NegativePrompt: 反向文本描述。 # 用于一定程度上从反面引导模型生成的走向,减少生成结果中出现描述内容的可能,但不能完全杜绝。 # 推荐使用中文。最多可传256个 utf-8 字符。 # @type NegativePrompt: String # @param Styles: 绘画风格。 # 请在 [智能图生图风格列表](https://cloud.tencent.com/document/product/1668/86250) 中选择期望的风格,传入风格编号。 # 推荐使用且只使用一种风格。不传默认使用201(日系动漫风格)。 # @type Styles: Array # @param ResultConfig: 生成图结果的配置,包括输出图片分辨率和尺寸等。 # 支持生成以下分辨率的图片:origin(与输入图分辨率一致)、768:768(1:1)、768:1024(3:4)、1024:768(4:3),不传默认使用origin。 # @type ResultConfig: :class:`Tencentcloud::Aiart.v20221229.models.ResultConfig` # @param LogoAdd: 为生成结果图添加标识的开关,默认为1。 # 1:添加标识。 # 0:不添加标识。 # 其他数值:默认按1处理。 # 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 # @type LogoAdd: Integer # @param LogoParam: 标识内容设置。 # 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 # @type LogoParam: :class:`Tencentcloud::Aiart.v20221229.models.LogoParam` # @param Strength: 生成自由度。 # Strength 值越小,生成图和原图越接近,取值范围0 - 1,不传使用模型内置的默认值。 # 推荐的取值范围为0.6 - 0.8。 # @type Strength: Float # @param RspImgType: 返回图像方式(base64 或 url) ,二选一,默认为 base64。url 有效期为1小时。 # @type RspImgType: String attr_accessor :InputImage, :InputUrl, :Prompt, :NegativePrompt, :Styles, :ResultConfig, :LogoAdd, :LogoParam, :Strength, :RspImgType def initialize(inputimage=nil, inputurl=nil, prompt=nil, negativeprompt=nil, styles=nil, resultconfig=nil, logoadd=nil, logoparam=nil, strength=nil, rspimgtype=nil) @InputImage = inputimage @InputUrl = inputurl @Prompt = prompt @NegativePrompt = negativeprompt @Styles = styles @ResultConfig = resultconfig @LogoAdd = logoadd @LogoParam = logoparam @Strength = strength @RspImgType = rspimgtype end def deserialize(params) @InputImage = params['InputImage'] @InputUrl = params['InputUrl'] @Prompt = params['Prompt'] @NegativePrompt = params['NegativePrompt'] @Styles = params['Styles'] unless params['ResultConfig'].nil? @ResultConfig = ResultConfig.new @ResultConfig.deserialize(params['ResultConfig']) end @LogoAdd = params['LogoAdd'] unless params['LogoParam'].nil? @LogoParam = LogoParam.new @LogoParam.deserialize(params['LogoParam']) end @Strength = params['Strength'] @RspImgType = params['RspImgType'] end end # ImageToImage返回参数结构体 class ImageToImageResponse < TencentCloud::Common::AbstractModel # @param ResultImage: 根据入参 RspImgType 填入不同,返回不同的内容。 # 如果传入 base64 则返回生成图 Base64 编码。 # 如果传入 url 则返回的生成图 URL , 有效期1小时,请及时保存。 # @type ResultImage: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :ResultImage, :RequestId def initialize(resultimage=nil, requestid=nil) @ResultImage = resultimage @RequestId = requestid end def deserialize(params) @ResultImage = params['ResultImage'] @RequestId = params['RequestId'] end end # logo参数 class LogoParam < TencentCloud::Common::AbstractModel # @param LogoUrl: 水印url # @type LogoUrl: String # @param LogoImage: 水印base64,url和base64二选一传入 # @type LogoImage: String # @param LogoRect: 水印图片位于融合结果图中的坐标,将按照坐标对标识图片进行位置和大小的拉伸匹配 # @type LogoRect: :class:`Tencentcloud::Aiart.v20221229.models.LogoRect` attr_accessor :LogoUrl, :LogoImage, :LogoRect def initialize(logourl=nil, logoimage=nil, logorect=nil) @LogoUrl = logourl @LogoImage = logoimage @LogoRect = logorect end def deserialize(params) @LogoUrl = params['LogoUrl'] @LogoImage = params['LogoImage'] unless params['LogoRect'].nil? @LogoRect = LogoRect.new @LogoRect.deserialize(params['LogoRect']) end end end # 输入框 class LogoRect < TencentCloud::Common::AbstractModel # @param X: 左上角X坐标 # @type X: Integer # @param Y: 左上角Y坐标 # @type Y: Integer # @param Width: 方框宽度 # @type Width: Integer # @param Height: 方框高度 # @type Height: Integer attr_accessor :X, :Y, :Width, :Height def initialize(x=nil, y=nil, width=nil, height=nil) @X = x @Y = y @Width = width @Height = height end def deserialize(params) @X = params['X'] @Y = params['Y'] @Width = params['Width'] @Height = params['Height'] end end # QueryTextToImageProJob请求参数结构体 class QueryTextToImageProJobRequest < TencentCloud::Common::AbstractModel # @param JobId: 任务 ID。 # @type JobId: String attr_accessor :JobId def initialize(jobid=nil) @JobId = jobid end def deserialize(params) @JobId = params['JobId'] end end # QueryTextToImageProJob返回参数结构体 class QueryTextToImageProJobResponse < TencentCloud::Common::AbstractModel # @param JobStatusCode: 当前任务状态码: # 1:排队中、3:处理中、5:处理失败、7:处理完成。 # @type JobStatusCode: String # @param JobStatusMsg: 当前任务状态:排队中、处理中、处理失败或者处理完成。 # @type JobStatusMsg: String # @param JobErrorCode: 任务处理失败错误码。 # @type JobErrorCode: String # @param JobErrorMsg: 任务处理失败错误信息。 # @type JobErrorMsg: String # @param ResultImage: 生成图 URL 列表,有效期1小时,请及时保存。 # @type ResultImage: Array # @param ResultDetails: 结果 detail 数组,Success 代表成功。 # @type ResultDetails: Array # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :JobStatusCode, :JobStatusMsg, :JobErrorCode, :JobErrorMsg, :ResultImage, :ResultDetails, :RequestId def initialize(jobstatuscode=nil, jobstatusmsg=nil, joberrorcode=nil, joberrormsg=nil, resultimage=nil, resultdetails=nil, requestid=nil) @JobStatusCode = jobstatuscode @JobStatusMsg = jobstatusmsg @JobErrorCode = joberrorcode @JobErrorMsg = joberrormsg @ResultImage = resultimage @ResultDetails = resultdetails @RequestId = requestid end def deserialize(params) @JobStatusCode = params['JobStatusCode'] @JobStatusMsg = params['JobStatusMsg'] @JobErrorCode = params['JobErrorCode'] @JobErrorMsg = params['JobErrorMsg'] @ResultImage = params['ResultImage'] @ResultDetails = params['ResultDetails'] @RequestId = params['RequestId'] end end # 返回结果配置 class ResultConfig < TencentCloud::Common::AbstractModel # @param Resolution: 生成图分辨率 # 智能文生图支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3)、1080:1920(9:16)、1920:1080(16:9),不传默认使用768:768 # 智能图生图支持生成以下分辨率的图片:origin(与输入图分辨率一致)、768:768(1:1)、768:1024(3:4)、1024:768(4:3),不传默认使用origin,如果指定生成的长宽比与输入图长宽比差异过大可能导致图片内容被裁剪 # @type Resolution: String attr_accessor :Resolution def initialize(resolution=nil) @Resolution = resolution end def deserialize(params) @Resolution = params['Resolution'] end end # SubmitTextToImageProJob请求参数结构体 class SubmitTextToImageProJobRequest < TencentCloud::Common::AbstractModel # @param Prompt: 文本描述。 # 算法将根据输入的文本智能生成与之相关的图像。 # 不能为空,推荐使用中文。最多可传100个 utf-8 字符。 # @type Prompt: String # @param Style: 绘画风格。 # 请在 [文生图(高级版)风格列表](https://cloud.tencent.com/document/product/1668/104567) 中选择期望的风格,传入风格编号。 # 不传默认不指定风格。 # @type Style: String # @param Resolution: 生成图分辨率。 # 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3),不传默认使用1024:1024。 # @type Resolution: String # @param LogoAdd: 为生成结果图添加显式水印标识的开关,默认为1。 # 1:添加。 # 0:不添加。 # 其他数值:默认按1处理。 # 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 # @type LogoAdd: Integer # @param Engine: 文生图引擎,默认使用engine1。 # 取值: # engine1 # engine2 # @type Engine: String attr_accessor :Prompt, :Style, :Resolution, :LogoAdd, :Engine def initialize(prompt=nil, style=nil, resolution=nil, logoadd=nil, engine=nil) @Prompt = prompt @Style = style @Resolution = resolution @LogoAdd = logoadd @Engine = engine end def deserialize(params) @Prompt = params['Prompt'] @Style = params['Style'] @Resolution = params['Resolution'] @LogoAdd = params['LogoAdd'] @Engine = params['Engine'] end end # SubmitTextToImageProJob返回参数结构体 class SubmitTextToImageProJobResponse < TencentCloud::Common::AbstractModel # @param JobId: 任务 ID。 # @type JobId: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :JobId, :RequestId def initialize(jobid=nil, requestid=nil) @JobId = jobid @RequestId = requestid end def deserialize(params) @JobId = params['JobId'] @RequestId = params['RequestId'] end end # TextToImage请求参数结构体 class TextToImageRequest < TencentCloud::Common::AbstractModel # @param Prompt: 文本描述。 # 算法将根据输入的文本智能生成与之相关的图像。建议详细描述画面主体、细节、场景等,文本描述越丰富,生成效果越精美。 # 不能为空,推荐使用中文。最多可传256个 utf-8 字符。 # @type Prompt: String # @param NegativePrompt: 反向文本描述。 # 用于一定程度上从反面引导模型生成的走向,减少生成结果中出现描述内容的可能,但不能完全杜绝。 # 推荐使用中文。最多可传256个 utf-8 字符。 # @type NegativePrompt: String # @param Styles: 绘画风格。 # 请在 [智能文生图风格列表](https://cloud.tencent.com/document/product/1668/86249) 中选择期望的风格,传入风格编号。 # 推荐使用且只使用一种风格。不传默认使用201(日系动漫风格)。 # @type Styles: Array # @param ResultConfig: 生成图结果的配置,包括输出图片分辨率和尺寸等。 # 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3)、1080:1920(9:16)、1920:1080(16:9),不传默认使用768:768。 # @type ResultConfig: :class:`Tencentcloud::Aiart.v20221229.models.ResultConfig` # @param LogoAdd: 为生成结果图添加标识的开关,默认为1。 # 1:添加标识。 # 0:不添加标识。 # 其他数值:默认按1处理。 # 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 # @type LogoAdd: Integer # @param LogoParam: 标识内容设置。 # 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 # @type LogoParam: :class:`Tencentcloud::Aiart.v20221229.models.LogoParam` # @param RspImgType: 返回图像方式(base64 或 url) ,二选一,默认为 base64。url 有效期为1小时。 # @type RspImgType: String attr_accessor :Prompt, :NegativePrompt, :Styles, :ResultConfig, :LogoAdd, :LogoParam, :RspImgType def initialize(prompt=nil, negativeprompt=nil, styles=nil, resultconfig=nil, logoadd=nil, logoparam=nil, rspimgtype=nil) @Prompt = prompt @NegativePrompt = negativeprompt @Styles = styles @ResultConfig = resultconfig @LogoAdd = logoadd @LogoParam = logoparam @RspImgType = rspimgtype end def deserialize(params) @Prompt = params['Prompt'] @NegativePrompt = params['NegativePrompt'] @Styles = params['Styles'] unless params['ResultConfig'].nil? @ResultConfig = ResultConfig.new @ResultConfig.deserialize(params['ResultConfig']) end @LogoAdd = params['LogoAdd'] unless params['LogoParam'].nil? @LogoParam = LogoParam.new @LogoParam.deserialize(params['LogoParam']) end @RspImgType = params['RspImgType'] end end # TextToImage返回参数结构体 class TextToImageResponse < TencentCloud::Common::AbstractModel # @param ResultImage: 根据入参 RspImgType 填入不同,返回不同的内容。 # 如果传入 base64 则返回生成图 Base64 编码。 # 如果传入 url 则返回的生成图 URL , 有效期1小时,请及时保存。 # @type ResultImage: String # @param RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 # @type RequestId: String attr_accessor :ResultImage, :RequestId def initialize(resultimage=nil, requestid=nil) @ResultImage = resultimage @RequestId = requestid end def deserialize(params) @ResultImage = params['ResultImage'] @RequestId = params['RequestId'] end end end end end