2024-06-27 17:50:48 +08:00
|
|
|
<template>
|
2024-07-16 17:36:46 +08:00
|
|
|
<ContentWrap class="w-300px h-full mb-[0!important]">
|
2024-06-27 17:50:48 +08:00
|
|
|
<el-radio-group v-model="generateMode" class="mb-15px">
|
2024-08-15 11:49:58 +08:00
|
|
|
<el-radio-button value="desc"> 描述模式 </el-radio-button>
|
|
|
|
<el-radio-button value="lyric"> 歌词模式 </el-radio-button>
|
2024-06-27 17:50:48 +08:00
|
|
|
</el-radio-group>
|
|
|
|
|
|
|
|
<!-- 描述模式/歌词模式 切换 -->
|
2024-08-15 11:49:58 +08:00
|
|
|
<component :is="generateMode === 'desc' ? desc : lyric" ref="modeRef" />
|
2024-06-27 17:50:48 +08:00
|
|
|
|
2024-08-15 11:49:58 +08:00
|
|
|
<el-button type="primary" round class="w-full" @click="generateMusic"> 创作音乐 </el-button>
|
2024-06-27 17:50:48 +08:00
|
|
|
</ContentWrap>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
|
|
|
import desc from './desc.vue'
|
|
|
|
import lyric from './lyric.vue'
|
|
|
|
|
|
|
|
defineOptions({ name: 'Index' })
|
|
|
|
|
|
|
|
const emits = defineEmits(['generate-music'])
|
|
|
|
|
|
|
|
const generateMode = ref('lyric')
|
|
|
|
|
2024-07-16 17:36:46 +08:00
|
|
|
const modeRef = ref<Nullable<{ formData: Recordable }>>(null)
|
2024-06-27 17:50:48 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
*@Description: 根据信息生成音乐
|
|
|
|
*@MethodAuthor: xiaohong
|
|
|
|
*@Date: 2024-06-27 16:40:16
|
2024-08-15 11:49:58 +08:00
|
|
|
*/
|
|
|
|
function generateMusic() {
|
|
|
|
emits('generate-music', { formData: unref(modeRef)?.formData })
|
2024-06-27 17:50:48 +08:00
|
|
|
}
|
|
|
|
</script>
|