From e295922209fb87c6dcd68ea1560fd16c3e6d808c Mon Sep 17 00:00:00 2001 From: dongyukun <1208714201@qq.com> Date: 星期五, 27 六月 2025 09:36:51 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/feature/ai' --- src/views/ai/image/index/components/dall3/index.vue | 65 +++++++++++++++++++++++++++----- 1 files changed, 54 insertions(+), 11 deletions(-) diff --git a/src/views/ai/image/index/components/dall3/index.vue b/src/views/ai/image/index/components/dall3/index.vue index 5c891ab..efa41ed 100644 --- a/src/views/ai/image/index/components/dall3/index.vue +++ b/src/views/ai/image/index/components/dall3/index.vue @@ -2,11 +2,11 @@ <template> <div class="prompt"> <el-text tag="b">画面描述</el-text> - <el-text tag="p">建议使用“形容词+动词+风格”的格式,使用“,”隔开</el-text> + <el-text tag="p">建议使用"形容词 + 动词 + 风格"的格式,使用","隔开</el-text> <el-input v-model="prompt" maxlength="1024" - rows="5" + :rows="5" class="w-100% mt-15px" input-style="border-radius: 7px;" placeholder="例如:童话里的小屋应该是什么样子?" @@ -82,7 +82,14 @@ </el-space> </div> <div class="btns"> - <el-button type="primary" size="large" round :loading="drawIn" @click="handleGenerateImage"> + <el-button + type="primary" + size="large" + round + :loading="drawIn" + :disabled="prompt.length === 0" + @click="handleGenerateImage" + > {{ drawIn ? '生成中' : '生成内容' }} </el-button> </div> @@ -95,10 +102,21 @@ ImageHotWords, Dall3SizeList, ImageModelVO, - AiPlatformEnum + AiPlatformEnum, + ImageSizeVO } from '@/views/ai/utils/constants' +import { ModelVO } from '@/api/ai/model/model' const message = useMessage() // 消息弹窗 + +// 接收父组件传入的模型列表 +const props = defineProps({ + models: { + type: Array<ModelVO>, + default: () => [] as ModelVO[] + } +}) +const emits = defineEmits(['onDrawStart', 'onDrawComplete']) // 定义 emits // 定义属性 const prompt = ref<string>('') // 提示词 @@ -107,8 +125,6 @@ const selectModel = ref<string>('dall-e-3') // 模型 const selectSize = ref<string>('1024x1024') // 选中 size const style = ref<string>('vivid') // style 样式 - -const emits = defineEmits(['onDrawStart', 'onDrawComplete']) // 定义 emits /** 选择热词 */ const handleHotWordClick = async (hotWord: string) => { @@ -126,6 +142,27 @@ /** 选择 model 模型 */ const handleModelClick = async (model: ImageModelVO) => { selectModel.value = model.key + // 可以在这里添加模型特定的处理逻辑 + // 例如,如果未来需要根据不同模型设置不同参数 + if (model.key === 'dall-e-3') { + // DALL-E-3 模型特定的处理 + style.value = 'vivid' // 默认设置vivid风格 + } else if (model.key === 'dall-e-2') { + // DALL-E-2 模型特定的处理 + style.value = 'natural' // 如果有其他DALL-E-2适合的默认风格 + } + + // 更新其他相关参数 + // 例如可以默认选择最适合当前模型的尺寸 + const recommendedSize = Dall3SizeList.find( + (size) => + (model.key === 'dall-e-3' && size.key === '1024x1024') || + (model.key === 'dall-e-2' && size.key === '512x512') + ) + + if (recommendedSize) { + selectSize.value = recommendedSize.key + } } /** 选择 style 样式 */ @@ -140,6 +177,15 @@ /** 图片生产 */ const handleGenerateImage = async () => { + // 从 models 中查找匹配的模型 + const matchedModel = props.models.find( + (item) => item.model === selectModel.value && item.platform === AiPlatformEnum.OPENAI + ) + if (!matchedModel) { + message.error('该模型不可用,请选择其它模型') + return + } + // 二次确认 await message.confirm(`确认生成内容?`) try { @@ -151,7 +197,8 @@ const form = { platform: AiPlatformEnum.OPENAI, prompt: prompt.value, // 提示词 - model: selectModel.value, // 模型 + modelId: matchedModel.id, // 使用匹配到的模型 + style: style.value, // 图像生成的风格 width: imageSize.width, // size 不能为空 height: imageSize.height, // size 不能为空 options: { @@ -183,10 +230,6 @@ defineExpose({ settingValues }) </script> <style scoped lang="scss"> -// 提示词 -.prompt { -} - // 热词 .hot-words { display: flex; -- Gitblit v1.9.3