流式数据请求优化。

This commit is contained in:
francis_fh
2026-01-24 18:29:47 +08:00
parent 7a7aa33128
commit a3bc821bc3
2 changed files with 43 additions and 22 deletions

View File

@@ -376,8 +376,7 @@ class TTSPlayer {
// 微信小程序环境,使用背景音频管理器 // 微信小程序环境,使用背景音频管理器
const isBackgroundAudioAvailable = this.initAudioManager() const isBackgroundAudioAvailable = this.initAudioManager()
// 重置音频状态 // 重置音频状态,但不立即设置为正在播放,等待实际播放时再设置
this.isSpeaking.value = true
this.isPaused.value = false this.isPaused.value = false
this.isComplete.value = false this.isComplete.value = false
@@ -391,7 +390,7 @@ class TTSPlayer {
// 直接设置src并播放 // 直接设置src并播放
this.backgroundAudioManager.src = url this.backgroundAudioManager.src = url
console.log('🎵 微信小程序背景音频开始播放'); console.log('🎵 微信小程序背景音频开始加载');
} else { } else {
// 降级方案使用InnerAudioContext // 降级方案使用InnerAudioContext
console.log('🔄 微信小程序背景音频不可用降级使用InnerAudioContext'); console.log('🔄 微信小程序背景音频不可用降级使用InnerAudioContext');
@@ -403,7 +402,7 @@ class TTSPlayer {
} }
this.innerAudioContext = uni.createInnerAudioContext() this.innerAudioContext = uni.createInnerAudioContext()
this.innerAudioContext.autoplay = false this.innerAudioContext.autoplay = true // 设置自动播放,等音频加载完成后自动开始
this.innerAudioContext.obeyMuteSwitch = false this.innerAudioContext.obeyMuteSwitch = false
this.innerAudioContext.volume = 1.0 this.innerAudioContext.volume = 1.0
@@ -438,13 +437,11 @@ class TTSPlayer {
this.innerAudioContext.onCanplay(() => { this.innerAudioContext.onCanplay(() => {
console.log('🎵 微信小程序InnerAudioContext可以播放了') console.log('🎵 微信小程序InnerAudioContext可以播放了')
if (this.isSpeaking.value && !this.isPaused.value) { // 不需要手动调用play因为已经设置了autoplay
this.innerAudioContext.play()
}
}) })
this.innerAudioContext.src = url this.innerAudioContext.src = url
console.log('🎵 微信小程序InnerAudioContext开始播放'); console.log('🎵 微信小程序InnerAudioContext开始加载');
} }
// #endif // #endif

View File

@@ -480,10 +480,15 @@ const sendMessage = (text) => {
// 开始朗读当前消息 // 开始朗读当前消息
speechIndex.value = index; speechIndex.value = index;
readMarkdown(message.displayText, index); readMarkdown(message.displayText, index, { immediate: false });
// 一旦开始朗读就设置speechIndex避免重复调用
speechIndex.value = index;
} else { } else {
console.log('⏳ Waiting for more content before TTS, current length:', message.displayText.length); console.log('⏳ Waiting for more content before TTS, current length:', message.displayText.length);
} }
} else {
// 已经开始朗读这条消息,不再重复调用
console.log('⏭️ Already speaking this message, skipping duplicate TTS call');
} }
} }
}, },
@@ -508,7 +513,7 @@ const sendMessage = (text) => {
// 开始朗读完整的内容 // 开始朗读完整的内容
speechIndex.value = lastMessageIndex; speechIndex.value = lastMessageIndex;
readMarkdown(lastMessage.displayText, lastMessageIndex); readMarkdown(lastMessage.displayText, lastMessageIndex, { immediate: true });
} }
} }
}, },
@@ -781,7 +786,10 @@ function confirmFeeBack(value) {
// 防抖定时器 // 防抖定时器
let ttsDebounceTimer = null; let ttsDebounceTimer = null;
function readMarkdown(value, index) { // 保存上一次调用的文本内容避免重复调用TTS
let lastSpeechText = '';
function readMarkdown(value, index, options = {}) {
console.log('🎤 readMarkdown called'); console.log('🎤 readMarkdown called');
console.log('📝 Text to speak:', value ? value.substring(0, 100) + '...' : 'No text'); console.log('📝 Text to speak:', value ? value.substring(0, 100) + '...' : 'No text');
console.log('🔢 Index:', index); console.log('🔢 Index:', index);
@@ -798,17 +806,33 @@ function readMarkdown(value, index) {
console.log('🛑 Always stopping current speech before starting new one'); console.log('🛑 Always stopping current speech before starting new one');
speechIndex.value = index; speechIndex.value = index;
// 使用防抖避免频繁调用TTS // 立即调用speak不使用防抖延迟
ttsDebounceTimer = setTimeout(() => { const speakNow = () => {
// 检查文本内容是否发生变化避免重复调用TTS
if (value !== lastSpeechText) {
console.log('🎵 Starting new speech'); console.log('🎵 Starting new speech');
console.log('🎵 Calling speak function with text length:', value ? value.length : 0); console.log('🎵 Calling speak function with text length:', value ? value.length : 0);
try { try {
speak(value); speak(value);
console.log('✅ Speak function called successfully'); console.log('✅ Speak function called successfully');
// 更新上一次调用的文本内容
lastSpeechText = value;
} catch (error) { } catch (error) {
console.error('❌ Error calling speak function:', error); console.error('❌ Error calling speak function:', error);
} }
}, 300); // 300ms防抖延迟 } else {
console.log('🔄 Same text as last speech, skipping duplicate TTS call');
}
};
// 改进防抖逻辑,确保在短时间内只调用一次
if (options.immediate) {
// 如果是onComplete回调立即播放
speakNow();
} else {
// 对于流式数据,总是使用防抖,避免频繁调用
ttsDebounceTimer = setTimeout(speakNow, 500); // 延长防抖时间到500ms
}
} }
function stopMarkdown(value, index) { function stopMarkdown(value, index) {
console.log('⏸️ stopMarkdown called for index:', index); console.log('⏸️ stopMarkdown called for index:', index);