Spaces:
Runtime error
Runtime error
File size: 1,740 Bytes
8200e4b | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | document.addEventListener('DOMContentLoaded', () => {
const video = document.getElementById('video');
const canvas = document.getElementById('canvas');
const captureButton = document.getElementById('capture');
const message = document.getElementById('message');
// Access the webcam
navigator.mediaDevices.getUserMedia({ video: true })
.then(stream => {
video.srcObject = stream;
})
.catch(err => {
message.textContent = 'Error accessing webcam: ' + err;
message.style.color = 'red';
});
// Capture image when button is clicked
captureButton.addEventListener('click', () => {
const context = canvas.getContext('2d');
canvas.width = video.videoWidth;
canvas.height = video.videoHeight;
context.drawImage(video, 0, 0, canvas.width, canvas.height);
// Convert to base64
const dataUrl = canvas.toDataURL('image/png');
// Send to server
fetch('/capture', {
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
},
body: 'image=' + encodeURIComponent(dataUrl)
})
.then(response => response.json())
.then(data => {
if (data.error) {
message.textContent = 'Error: ' + data.error;
message.style.color = 'red';
} else {
message.textContent = data.message + ' (' + data.filename + ')';
message.style.color = 'green';
}
})
.catch(err => {
message.textContent = 'Error: ' + err;
message.style.color = 'red';
});
});
}); |