dongyukun
7 天以前 e295922209fb87c6dcd68ea1560fd16c3e6d808c
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;