From 3be26d15b00458923826dcf5513c3ed860f356cf Mon Sep 17 00:00:00 2001 From: Lingxi <2863878907@qq.com> Date: Mon, 16 Dec 2024 21:58:59 +0800 Subject: [PATCH] feat: slide text speed and autoplay speed --- .../src/Core/controller/gamePlay/autoPlay.ts | 5 ++-- packages/webgal/src/Core/gameScripts/say.ts | 4 +-- .../src/UI/Menu/Options/Display/Display.tsx | 25 ++++++----------- .../src/UI/Menu/Options/System/System.tsx | 26 ++++++----------- packages/webgal/src/hooks/useTextOptions.ts | 28 +++++++------------ .../webgal/src/store/userDataInterface.ts | 4 +-- packages/webgal/src/store/userDataReducer.ts | 4 +-- 7 files changed, 36 insertions(+), 60 deletions(-) diff --git a/packages/webgal/src/Core/controller/gamePlay/autoPlay.ts b/packages/webgal/src/Core/controller/gamePlay/autoPlay.ts index 0abe68278..1f183d9b5 100644 --- a/packages/webgal/src/Core/controller/gamePlay/autoPlay.ts +++ b/packages/webgal/src/Core/controller/gamePlay/autoPlay.ts @@ -58,8 +58,9 @@ export const autoNextSentence = () => { * 自动播放的执行函数 */ const autoPlay = () => { - const delay = webgalStore.getState().userData.optionData.autoSpeed; - const autoPlayDelay = 750 - 250 * delay; + const data = webgalStore.getState().userData.optionData.autoSpeed; + // 范围为 [250, 1750] + const autoPlayDelay = 250 + (100 - data) * 15; let isBlockingAuto = false; WebGAL.gameplay.performController.performList.forEach((e) => { if (e.blockingAuto()) diff --git a/packages/webgal/src/Core/gameScripts/say.ts b/packages/webgal/src/Core/gameScripts/say.ts index 27c016ff5..656d13e59 100644 --- a/packages/webgal/src/Core/gameScripts/say.ts +++ b/packages/webgal/src/Core/gameScripts/say.ts @@ -3,7 +3,7 @@ import { IPerform } from '@/Core/Modules/perform/performInterface'; import { playVocal } from './vocal'; import { webgalStore } from '@/store/store'; import { setStage } from '@/store/stageReducer'; -import { useTextDelay } from '@/hooks/useTextOptions'; +import { useTextAnimationDuration, useTextDelay } from '@/hooks/useTextOptions'; import { getRandomPerformName, PerformController } from '@/Core/Modules/perform/performController'; import { getSentenceArgByKey } from '@/Core/util/getSentenceArg'; import { textSize, voiceOption } from '@/store/userDataInterface'; @@ -148,7 +148,7 @@ export const say = (sentence: ISentence): IPerform => { } const performInitName: string = getRandomPerformName(); - let endDelay = 750 - userDataState.optionData.textSpeed * 250; + let endDelay = useTextAnimationDuration(userDataState.optionData.textSpeed) / 2; // 如果有 notend 参数,那么就不需要等待 if (isNotend) { endDelay = 0; diff --git a/packages/webgal/src/UI/Menu/Options/Display/Display.tsx b/packages/webgal/src/UI/Menu/Options/Display/Display.tsx index b7bc13045..5a72af784 100644 --- a/packages/webgal/src/UI/Menu/Options/Display/Display.tsx +++ b/packages/webgal/src/UI/Menu/Options/Display/Display.tsx @@ -34,23 +34,14 @@ export function Display() { /> - { - dispatch(setOptionData({ key: 'textSpeed', value: playSpeed.slow })); - setStorage(); - }, - () => { - dispatch(setOptionData({ key: 'textSpeed', value: playSpeed.normal })); - setStorage(); - }, - () => { - dispatch(setOptionData({ key: 'textSpeed', value: playSpeed.fast })); - setStorage(); - }, - ]} - currentChecked={userDataState.optionData.textSpeed} + { + const newValue = event.target.value; + dispatch(setOptionData({ key: 'textSpeed', value: Number(newValue) })); + setStorage(); + }} /> diff --git a/packages/webgal/src/UI/Menu/Options/System/System.tsx b/packages/webgal/src/UI/Menu/Options/System/System.tsx index 6d48e0011..fc9c33b46 100644 --- a/packages/webgal/src/UI/Menu/Options/System/System.tsx +++ b/packages/webgal/src/UI/Menu/Options/System/System.tsx @@ -18,6 +18,7 @@ import { WebGAL } from '@/Core/WebGAL'; import useSoundEffect from '@/hooks/useSoundEffect'; import savesReducer, { ISavesData, saveActions } from '@/store/savesReducer'; import { dumpFastSaveToStorage, dumpSavesToStorage } from '@/Core/controller/storage/savesController'; +import { OptionSlider } from '@/UI/Menu/Options/OptionSlider'; interface IExportGameData { userData: IUserData; @@ -104,23 +105,14 @@ export function System() { {!showAbout && ( <> - { - dispatch(setOptionData({ key: 'autoSpeed', value: playSpeed.slow })); - setStorage(); - }, - () => { - dispatch(setOptionData({ key: 'autoSpeed', value: playSpeed.normal })); - setStorage(); - }, - () => { - dispatch(setOptionData({ key: 'autoSpeed', value: playSpeed.fast })); - setStorage(); - }, - ]} - currentChecked={userDataState.optionData.autoSpeed} + { + const newValue = event.target.value; + dispatch(setOptionData({ key: 'autoSpeed', value: Number(newValue) })); + setStorage(); + }} /> diff --git a/packages/webgal/src/hooks/useTextOptions.ts b/packages/webgal/src/hooks/useTextOptions.ts index b388d0564..948bf9988 100644 --- a/packages/webgal/src/hooks/useTextOptions.ts +++ b/packages/webgal/src/hooks/useTextOptions.ts @@ -1,23 +1,15 @@ import { playSpeed } from '@/store/userDataInterface'; -export function useTextDelay(type: playSpeed) { - switch (type) { - case playSpeed.slow: - return 80; - case playSpeed.normal: - return 35; - case playSpeed.fast: - return 3; - } +// 范围为 [startRange, step * 100 + startRange] +export function useTextDelay(data: number) { + const startRange = 3; + const step = 1.5; + return startRange + (100 - data) * step; } -export function useTextAnimationDuration(type: playSpeed) { - switch (type) { - case playSpeed.slow: - return 800; - case playSpeed.normal: - return 350; - case playSpeed.fast: - return 200; - } +// 范围为 [startRange, step * 100 + startRange] +export function useTextAnimationDuration(data: number) { + const startRange = 200; + const step = 15; + return startRange + (100 - data) * step; } diff --git a/packages/webgal/src/store/userDataInterface.ts b/packages/webgal/src/store/userDataInterface.ts index 626544ded..e627b1f37 100644 --- a/packages/webgal/src/store/userDataInterface.ts +++ b/packages/webgal/src/store/userDataInterface.ts @@ -39,8 +39,8 @@ export enum fullScreenOption { */ export interface IOptionData { volumeMain: number; // 主音量 - textSpeed: playSpeed; // 文字速度 - autoSpeed: playSpeed; // 自动播放速度 + textSpeed: number; // 文字速度 + autoSpeed: number; // 自动播放速度 textSize: textSize; vocalVolume: number; // 语音音量 bgmVolume: number; // 背景音乐音量 diff --git a/packages/webgal/src/store/userDataReducer.ts b/packages/webgal/src/store/userDataReducer.ts index a70827073..bd80b9146 100644 --- a/packages/webgal/src/store/userDataReducer.ts +++ b/packages/webgal/src/store/userDataReducer.ts @@ -24,8 +24,8 @@ import { ISetGameVar } from './stageInterface'; const initialOptionSet: IOptionData = { slPage: 1, volumeMain: 100, // 主音量 - textSpeed: playSpeed.normal, // 文字速度 - autoSpeed: playSpeed.normal, // 自动播放速度 + textSpeed: 50, // 文字速度 + autoSpeed: 50, // 自动播放速度 textSize: textSize.medium, vocalVolume: 100, // 语音音量 bgmVolume: 25, // 背景音乐音量