【代码优化】AI:绘图 index.vue 代码梳理 65%(Dall3.vue)

pull/476/MERGE
YunaiV 2024-07-09 20:41:22 +08:00
parent 75af4f07c0
commit 7706e46bfa
3 changed files with 75 additions and 80 deletions

View File

@ -3,12 +3,11 @@
<div class="prompt"> <div class="prompt">
<el-text tag="b">画面描述</el-text> <el-text tag="b">画面描述</el-text>
<el-text tag="p">建议使用形容词+动词+风格的格式使用隔开</el-text> <el-text tag="p">建议使用形容词+动词+风格的格式使用隔开</el-text>
<!-- TODO @fanstyle 看看能不能哟 unocss 替代 @芋艿 尝试了下没效果哪个地方有使用么我看看 -->
<el-input <el-input
v-model="prompt" v-model="prompt"
maxlength="1024" maxlength="1024"
rows="5" rows="5"
style="width: 100%; margin-top: 15px;" class="w-100% mt-15px"
input-style="border-radius: 7px;" input-style="border-radius: 7px;"
placeholder="例如:童话里的小屋应该是什么样子?" placeholder="例如:童话里的小屋应该是什么样子?"
show-word-limit show-word-limit
@ -20,10 +19,11 @@
<el-text tag="b">随机热词</el-text> <el-text tag="b">随机热词</el-text>
</div> </div>
<el-space wrap class="word-list"> <el-space wrap class="word-list">
<el-button round <el-button
round
class="btn" class="btn"
:type="(selectHotWord === hotWord ? 'primary' : 'default')" :type="selectHotWord === hotWord ? 'primary' : 'default'"
v-for="hotWord in hotWords" v-for="hotWord in ImageHotWords"
:key="hotWord" :key="hotWord"
@click="handleHotWordClick(hotWord)" @click="handleHotWordClick(hotWord)"
> >
@ -37,17 +37,12 @@
</div> </div>
<el-space wrap class="model-list"> <el-space wrap class="model-list">
<div <div
:class="selectModel === model.key ? 'modal-item selectModel' : 'modal-item'" :class="model === model.key ? 'modal-item selectModel' : 'modal-item'"
v-for="model in models" v-for="model in Dall3Models"
:key="model.key" :key="model.key"
> >
<el-image <el-image :src="model.image" fit="contain" @click="handleModelClick(model)" />
:src="model.image" <div class="model-font">{{ model.name }}</div>
fit="contain"
@click="handleModelClick(model)"
/>
<div class="model-font">{{model.name}}</div>
</div> </div>
</el-space> </el-space>
</div> </div>
@ -57,16 +52,16 @@
</div> </div>
<el-space wrap class="image-style-list"> <el-space wrap class="image-style-list">
<div <div
:class="selectImageStyle === imageStyle.key ? 'image-style-item selectImageStyle' : 'image-style-item'" :class="
selectImageStyle === imageStyle.key
? 'image-style-item selectImageStyle'
: 'image-style-item'
"
v-for="imageStyle in imageStyleList" v-for="imageStyle in imageStyleList"
:key="imageStyle.key" :key="imageStyle.key"
> >
<el-image <el-image :src="imageStyle.image" fit="contain" @click="handleStyleClick(imageStyle)" />
:src="imageStyle.image" <div class="style-font">{{ imageStyle.name }}</div>
fit="contain"
@click="handleStyleClick(imageStyle)"
/>
<div class="style-font">{{imageStyle.name}}</div>
</div> </div>
</el-space> </el-space>
</div> </div>
@ -75,11 +70,13 @@
<el-text tag="b">画面比例</el-text> <el-text tag="b">画面比例</el-text>
</div> </div>
<el-space wrap class="size-list"> <el-space wrap class="size-list">
<div class="size-item" <div
class="size-item"
v-for="imageSize in imageSizeList" v-for="imageSize in imageSizeList"
:key="imageSize.key" :key="imageSize.key"
@click="handleSizeClick(imageSize)"> @click="handleSizeClick(imageSize)"
<div :class="selectImageSize === imageSize.key ? 'size-wrapper selectImageSize' : 'size-wrapper'"> >
<div :class="size === imageSize.key ? 'size-wrapper selectImageSize' : 'size-wrapper'">
<div :style="imageSize.style"></div> <div :style="imageSize.style"></div>
</div> </div>
<div class="size-font">{{ imageSize.name }}</div> <div class="size-font">{{ imageSize.name }}</div>
@ -87,17 +84,16 @@
</el-space> </el-space>
</div> </div>
<div class="btns"> <div class="btns">
<el-button type="primary" <el-button type="primary" size="large" round :loading="drawIn" @click="handleGenerateImage">
size="large" {{ drawIn ? '生成中' : '生成内容' }}
round
:loading="drawIn"
@click="handleGenerateImage">
{{drawIn ? '生成中' : '生成内容'}}
</el-button> </el-button>
</div> </div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import {ImageApi, ImageDrawReqVO, ImageVO} from '@/api/ai/image'; import { ImageApi, ImageDrawReqVO, ImageVO } from '@/api/ai/image'
import { Dall3Models, ImageHotWords } from '@/views/ai/utils/constants'
const message = useMessage() //
// image // image
interface ImageModelVO { interface ImageModelVO {
@ -109,32 +105,18 @@ interface ImageModelVO {
// image // image
interface ImageSizeVO { interface ImageSizeVO {
key: string key: string
name: string, name: string
style: string, style: string
width: string, width: string
height: string, height: string
} }
// //
const prompt = ref<string>('') // const prompt = ref<string>('') //
const drawIn = ref<boolean>(false) // const drawIn = ref<boolean>(false) //
const selectHotWord = ref<string>('') // const selectHotWord = ref<string>('') //
const hotWords = ref<string[]>(['中国旗袍', '古装美女', '卡通头像', '机甲战士', '童话小屋', '中国长城']) // const model = ref<string>('dall-e-3') //
const selectModel = ref<string>('dall-e-3') // const size = ref<string>('1024x1024') // size
// message
const message = useMessage()
const models = ref<ImageModelVO[]>([
{
key: 'dall-e-3',
name: 'DALL·E 3',
image: `/src/assets/ai/dall2.jpg`,
},
{
key: 'dall-e-2',
name: 'DALL·E 2',
image: `/src/assets/ai/dall3.jpg`,
},
]) //
const selectImageStyle = ref<string>('vivid') // style const selectImageStyle = ref<string>('vivid') // style
@ -142,37 +124,36 @@ const imageStyleList = ref<ImageModelVO[]>([
{ {
key: 'vivid', key: 'vivid',
name: '清晰', name: '清晰',
image: `/src/assets/ai/qingxi.jpg`, image: `/src/assets/ai/qingxi.jpg`
}, },
{ {
key: 'natural', key: 'natural',
name: '自然', name: '自然',
image: `/src/assets/ai/ziran.jpg`, image: `/src/assets/ai/ziran.jpg`
}, }
]) // style ]) // style
const selectImageSize = ref<string>('1024x1024') // size
const imageSizeList = ref<ImageSizeVO[]>([ const imageSizeList = ref<ImageSizeVO[]>([
{ {
key: '1024x1024', key: '1024x1024',
name: '1:1', name: '1:1',
width: '1024', width: '1024',
height: '1024', height: '1024',
style: 'width: 30px; height: 30px;background-color: #dcdcdc;', style: 'width: 30px; height: 30px;background-color: #dcdcdc;'
}, },
{ {
key: '1024x1792', key: '1024x1792',
name: '3:5', name: '3:5',
width: '1024', width: '1024',
height: '1792', height: '1792',
style: 'width: 30px; height: 50px;background-color: #dcdcdc;', style: 'width: 30px; height: 50px;background-color: #dcdcdc;'
}, },
{ {
key: '1792x1024', key: '1792x1024',
name: '5:3', name: '5:3',
width: '1792', width: '1792',
height: '1024', height: '1024',
style: 'width: 50px; height: 30px;background-color: #dcdcdc;', style: 'width: 50px; height: 30px;background-color: #dcdcdc;'
} }
]) // size ]) // size
@ -196,7 +177,7 @@ const handleHotWordClick = async (hotWord: string) => {
/** 模型 - click */ /** 模型 - click */
const handleModelClick = async (model: ImageModelVO) => { const handleModelClick = async (model: ImageModelVO) => {
selectModel.value = model.key model.value = model.key
} }
/** 样式 - click */ /** 样式 - click */
@ -206,7 +187,7 @@ const handleStyleClick = async (imageStyle: ImageModelVO) => {
/** size - click */ /** size - click */
const handleSizeClick = async (imageSize: ImageSizeVO) => { const handleSizeClick = async (imageSize: ImageSizeVO) => {
selectImageSize.value = imageSize.key size.value = imageSize.key
} }
/** 图片生产 */ /** 图片生产 */
@ -217,23 +198,23 @@ const handleGenerateImage = async () => {
// //
drawIn.value = true drawIn.value = true
// //
emits('onDrawStart', selectModel.value) emits('onDrawStart', model.value)
const imageSize = imageSizeList.value.find(item => item.key === selectImageSize.value) as ImageSizeVO const imageSize = imageSizeList.value.find((item) => item.key === size.value) as ImageSizeVO
const form = { const form = {
platform: 'OpenAI', platform: 'OpenAI',
prompt: prompt.value, // prompt: prompt.value, //
model: selectModel.value, // model: model.value, //
width: imageSize.width, // size width: imageSize.width, // size
height: imageSize.height, // size height: imageSize.height, // size
options: { options: {
style: selectImageStyle.value, // style: selectImageStyle.value //
} }
} as ImageDrawReqVO } as ImageDrawReqVO
// //
await ImageApi.drawImage(form) await ImageApi.drawImage(form)
} finally { } finally {
// //
emits('onDrawComplete', selectModel.value) emits('onDrawComplete', model.value)
// //
drawIn.value = false drawIn.value = false
} }
@ -242,17 +223,18 @@ const handleGenerateImage = async () => {
/** 填充值 */ /** 填充值 */
const settingValues = async (imageDetail: ImageVO) => { const settingValues = async (imageDetail: ImageVO) => {
prompt.value = imageDetail.prompt prompt.value = imageDetail.prompt
selectModel.value = imageDetail.model model.value = imageDetail.model
// //
selectImageStyle.value = imageDetail.options?.style selectImageStyle.value = imageDetail.options?.style
// //
const imageSize = imageSizeList.value.find(item => item.key === `${imageDetail.width}x${imageDetail.height}`) as ImageSizeVO const imageSize = imageSizeList.value.find(
(item) => item.key === `${imageDetail.width}x${imageDetail.height}`
) as ImageSizeVO
await handleSizeClick(imageSize) await handleSizeClick(imageSize)
} }
/** 暴露组件方法 */ /** 暴露组件方法 */
defineExpose({ settingValues }) defineExpose({ settingValues })
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
// //
@ -309,7 +291,6 @@ defineExpose({ settingValues })
} }
} }
// style // style
.image-style { .image-style {
margin-top: 30px; margin-top: 30px;

View File

@ -30,17 +30,17 @@
import ImageList from './components/ImageList.vue' import ImageList from './components/ImageList.vue'
import { AiPlatformEnum } from '@/views/ai/utils/constants' import { AiPlatformEnum } from '@/views/ai/utils/constants'
import { ImageVO } from '@/api/ai/image' import { ImageVO } from '@/api/ai/image'
import Dall3 from './dall3/index.vue' import Dall3 from './components/dall3/index.vue'
import Midjourney from './midjourney/index.vue' import Midjourney from './midjourney/index.vue'
import StableDiffusion from './components/stableDiffusion/index.vue' import StableDiffusion from './components/stableDiffusion/index.vue'
const imageListRef = ref<any>() // image ref const imageListRef = ref<any>() // image ref
const dall3Ref = ref<any>() // openai ref const dall3Ref = ref<any>() // dall3(openai) ref
const midjourneyRef = ref<any>() // midjourney ref const midjourneyRef = ref<any>() // midjourney ref
const stableDiffusionRef = ref<any>() // stable diffusion ref const stableDiffusionRef = ref<any>() // stable diffusion ref
// //
const selectPlatform = ref('StableDiffusion') const selectPlatform = ref(AiPlatformEnum.OPENAI)
const platformOptions = [ const platformOptions = [
{ {
label: 'DALL3 绘画', label: 'DALL3 绘画',

View File

@ -63,6 +63,7 @@ export const ImageHotEnglishWords = [
export interface ImageModelVO { export interface ImageModelVO {
key: string key: string
name: string name: string
image?: string
} }
export const StableDiffusionSamplers = ref<ImageModelVO[]>([ export const StableDiffusionSamplers = ref<ImageModelVO[]>([
@ -210,3 +211,16 @@ export const StableDiffusionClipGuidancePresets = ref<ImageModelVO[]>([
name: 'SLOWEST' name: 'SLOWEST'
} }
]) ])
export const Dall3Models = ref<ImageModelVO[]>([
{
key: 'dall-e-3',
name: 'DALL·E 3',
image: `/src/assets/ai/dall2.jpg`
},
{
key: 'dall-e-2',
name: 'DALL·E 2',
image: `/src/assets/ai/dall3.jpg`
}
])