【工具】HTML自动识别用户正在讲话 以及停止讲话

【工具】HTML自动识别用户正在讲话 以及停止讲话

javascript 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>语音识别</title>
</head>
<body>
    <h2>点击按钮开始语音识别</h2>
    <button id="startButton">开始识别</button>
    <p id="status">等待用户讲话...</p>
    <script>
        let recognition;
        let isRecognizing = false;

        // 检查浏览器是否支持 Web Speech API
        if (!('webkitSpeechRecognition' in window)) {
            alert("抱歉,您的浏览器不支持语音识别!");
        } else {
            recognition = new webkitSpeechRecognition();
            recognition.continuous = true;  // 设置为持续模式,识别一段时间后不会停止
            recognition.interimResults = true;  // 获取中间结果

            // 语音识别开始时
            recognition.onstart = function() {
                isRecognizing = true;
                document.getElementById('status').innerText = "正在识别中...";
            };

            // 语音识别结束时
            recognition.onend = function() {
                isRecognizing = false;
                document.getElementById('status').innerText = "停止识别,等待用户讲话...";
            };

            // 识别到语音时
            recognition.onresult = function(event) {
                let result = event.results[event.resultIndex];
                let transcript = result[0].transcript;  // 获取识别的文本
                console.log("识别结果:", transcript);
                
                // 如果有中间结果,可以实时更新
                if (event.results[0].isFinal) {
                    document.getElementById('status').innerText = "识别结果: " + transcript;
                }
            };

            // 点击按钮开始识别
            document.getElementById('startButton').addEventListener('click', function() {
                if (isRecognizing) {
                    recognition.stop();  // 停止识别
                    document.getElementById('status').innerText = "已停止识别。";
                } else {
                    recognition.start();  // 开始识别
                }
            });
        }
    </script>
</body>
</html>
相关推荐
秋雨梧桐叶落莳1 小时前
iOS——QQ音乐仿写项目总结
学习·macos·ui·ios·mvc·objective-c·xcode
爱就是恒久忍耐1 小时前
VSCode里clangd如何配置跳转
ide·vscode·编辑器
SmartManWind1 小时前
vscode中claude-code插件wsl中开启自动模式
ide·vscode·编辑器·claude code
MXsoft6181 小时前
**用自动化脚本给MAC误阻断留条后路:可审计、可回滚的准入控制方案**
运维·macos·自动化
iUNPo3 小时前
WWDC26 技术解读:Apple Intelligence、Siri AI 与苹果生态的下一步
macos·ios·wwdc
小米渣的逆袭3 小时前
macos上一个好用的PDF文字提取工具方案
macos·pdf
Watink Cpper3 小时前
VSCode通过ChatGPT5.5登陆codex:sign-in could not be complete 问题解决方案
ide·vscode·编辑器·codex·gpt5.5
::呵呵哒::3 小时前
在macOS/Linux上优雅管理多个JDK版本:环境变量与别名配置指南
java·linux·macos
相醉为友4 小时前
Trae IDE WSL2/SSH 环境网络故障排查笔记
ide·笔记·ssh
带娃的IT创业者4 小时前
深度解析:当 MLX 遇上视觉语言模型,Mac 本地推理的新范式
人工智能·macos·语言模型·视觉语言模型·apple silicon·mlx·mac本地推理