mirror of
https://github.com/kou029w/chirimen-hands-on.git
synced 2025-01-18 16:08:13 +00:00
50 lines
1.3 KiB
HTML
50 lines
1.3 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="ja">
|
|
<head>
|
|
<meta charset="UTF-8" />
|
|
<title>Webカメラ</title>
|
|
</head>
|
|
<body>
|
|
<h1>Webカメラ</h1>
|
|
<div id="player"></div>
|
|
<div id="devices"></div>
|
|
<script type="module">
|
|
const deviceId = location.hash.slice(1);
|
|
const playerElement = document.getElementById("player");
|
|
const videoElement = document.createElement("video");
|
|
const srcObject = await navigator.mediaDevices.getUserMedia({
|
|
video: {
|
|
deviceId,
|
|
},
|
|
});
|
|
|
|
Object.assign(videoElement, {
|
|
controls: "controls",
|
|
autoplay: true,
|
|
muted: true,
|
|
srcObject,
|
|
});
|
|
|
|
playerElement.append(videoElement);
|
|
|
|
const devicesElement = document.getElementById("devices");
|
|
const devices = (await navigator.mediaDevices.enumerateDevices()).filter(
|
|
({ kind }) => kind === "videoinput",
|
|
);
|
|
|
|
for (const { deviceId, label } of devices) {
|
|
const a = document.createElement("a");
|
|
|
|
Object.assign(a, {
|
|
href: `#${deviceId}`,
|
|
textContent: `${label} #${deviceId}`,
|
|
style: `display: block`,
|
|
});
|
|
|
|
devicesElement.appendChild(a);
|
|
}
|
|
|
|
window.onhashchange = () => location.reload();
|
|
</script>
|
|
</body>
|
|
</html>
|