feat: 添加国产浏览器兼容性提示和用户交互解锁机制

This commit is contained in:
2026-04-22 22:33:43 +08:00
parent d674c4d460
commit 37242cdf82
2 changed files with 29 additions and 1 deletions

Binary file not shown.

View File

@@ -453,6 +453,9 @@
<!-- TTS 设置 --> <!-- TTS 设置 -->
<div class="tts-section"> <div class="tts-section">
<h3>🔊 TTS语音合成设置</h3> <h3>🔊 TTS语音合成设置</h3>
<div class="browser-tip" id="browserTip" style="display: none; background: #fff3cd; padding: 8px 12px; border-radius: 6px; margin-bottom: 10px; font-size: 13px; color: #856404;">
⚠️ 当前浏览器可能限制音频播放,建议使用 Chrome/Firefox或点击页面任意位置解锁播放
</div>
<div class="tts-options" id="ttsOptions"> <div class="tts-options" id="ttsOptions">
<div class="tts-option" data-provider="none"> <div class="tts-option" data-provider="none">
<div class="name">❌ 无 TTS</div> <div class="name">❌ 无 TTS</div>
@@ -545,6 +548,16 @@
let currentVoice = 'zh-CN-XiaoxiaoNeural'; let currentVoice = 'zh-CN-XiaoxiaoNeural';
let autoPlay = true; // 自动播放开关 let autoPlay = true; // 自动播放开关
let volumeLevel = 1.5; // 音量倍率 let volumeLevel = 1.5; // 音量倍率
let userInteracted = false; // 用户是否已交互
// 用户点击页面解锁音频播放能力
document.addEventListener('click', () => {
userInteracted = true;
}, { once: true });
document.addEventListener('touchstart', () => {
userInteracted = true;
}, { once: true });
// 元素 // 元素
const statusDot = document.getElementById('statusDot'); const statusDot = document.getElementById('statusDot');
@@ -569,10 +582,25 @@
await checkStatus(); await checkStatus();
await loadTTSProviders(); await loadTTSProviders();
// 检测特殊浏览器(小米浏览器等)
checkBrowser();
// 定时检查状态 // 定时检查状态
setInterval(checkStatus, 10000); setInterval(checkStatus, 10000);
} }
// 检测浏览器兼容性
function checkBrowser() {
const ua = navigator.userAgent.toLowerCase();
const browserTip = document.getElementById('browserTip');
// 小米浏览器、华为浏览器等国产浏览器UA特征
if (ua.includes('miui') || ua.includes('xiaomi') || ua.includes('huawei') ||
ua.includes('micromessenger') || ua.includes('quark') || ua.includes('ucbrowser')) {
browserTip.style.display = 'block';
}
}
// 检查服务状态 // 检查服务状态
async function checkStatus() { async function checkStatus() {
try { try {
@@ -913,7 +941,7 @@
chatSection.scrollTop = chatSection.scrollHeight; chatSection.scrollTop = chatSection.scrollHeight;
// 自动播放在元素添加到DOM后 // 自动播放在元素添加到DOM后
if (role === 'assistant' && audioData && autoPlay && audioBtnId) { if (role === 'assistant' && audioData && autoPlay && audioBtnId && userInteracted) {
setTimeout(() => { setTimeout(() => {
const btn = document.getElementById(audioBtnId); const btn = document.getElementById(audioBtnId);
if (btn) { if (btn) {