当前位置: 首页 > article >正文

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

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

<!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>


http://www.kler.cn/a/473484.html

相关文章:

  • 常见的开源网络操作系统
  • 计算机网络之---数据传输与比特流
  • 开放词汇检测新晋SOTA:地瓜机器人开源DOSOD实时检测算法
  • 腾讯云AI代码助手编程挑战赛——贪吃蛇小游戏
  • 如何让用户在网页中填写PDF表格?
  • 快速上手:采用Let‘sEncrypt免费SSL证书配置网站Https (示例环境:Centos7.9+Nginx+Let‘sEncrypt)
  • CVPR 2024 3D Point Cloud(点云处理)方向总汇
  • ChatGPT网络配置问题方案
  • Golang的网络安全漏洞检测
  • 花生好坏缺陷识别数据集,7262张图片,支持yolo,coco json,pasical voc xml格式的标注,识别准确率在95.7%
  • Vscode 安装、配置及插件
  • Go语言的 的设计模式(Design Patterns)核心知识
  • 内网穿透-natapp
  • 前端 图片上鼠标画矩形框,标注文字,任意删除
  • 软考教材重点内容 信息安全工程师 第13章 网络安全漏洞防护技术原理与应用
  • 入侵检测技术原理与应用
  • vue elementui 大文件进度条下载
  • Sql 创建用户
  • 语义分割数据集介绍——Camvid和Cityscapes介绍
  • 数据结构与算法之二叉树: LeetCode 107. 二叉树的层序遍历 II (Ts版)
  • GRE技术的详细解释
  • MySQL中深度分页问题的优化
  • 大数据技术-Hadoop(四)Yarn的介绍与使用
  • 稀疏子空间聚类 SSC(Sparse Subspace Clustering)
  • halcon三维点云数据处理(七)find_shape_model_3d_recompute_score
  • vulnhub靶场【DC系列】之6