wjs/yolo_safehat_det_flask_stream/templates/speech.html

71 lines
2.1 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Speech Recognition Demo</title>
<style>
body {
font-family: Arial, sans-serif;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 100vh;
}
button {
padding: 10px 20px;
font-size: 16px;
margin-top: 20px;
}
#output {
margin-top: 20px;
font-size: 18px;
color: #333;
}
</style>
</head>
<body>
<h1>Speech Recognition Demo</h1>
<button id="start-btn">Start Recognition</button>
<div id="output"></div>
<script>
document.addEventListener('DOMContentLoaded', () => {
const startBtn = document.getElementById('start-btn');
const output = document.getElementById('output');
if ('webkitSpeechRecognition' in window) {
const recognition = new webkitSpeechRecognition();
recognition.lang = 'zh-CN';
recognition.continuous = false;
recognition.interimResults = false;
recognition.onstart = () => {
output.textContent = 'Listening...';
};
recognition.onresult = (event) => {
const transcript = event.results[0][0].transcript;
output.textContent = `You said: ${transcript}`;
};
recognition.onerror = (event) => {
output.textContent = `Error occurred: ${event.error}`;
};
recognition.onend = () => {
output.textContent += ' (recognition ended)';
};
startBtn.addEventListener('click', () => {
recognition.start();
});
} else {
output.textContent = 'Speech recognition not supported in this browser.';
}
});
</script>
</body>
</html>