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, // 背景音乐音量