2
スナップショットを撮るためにウェブカメラを使用しようとしています。私は写真を撮るときに切り取った領域になる四角形を重ねた。私が写真を撮ると、キャプチャされた画像が拡大されます。画像を矩形内の領域と同じにするにはどうしたらいいですか? https://jsfiddle.net/fzrLvbwf/9/HTML5ビデオウェブカメラの一致解像度
var timer = null;
var timeto = 3; // time in seconds to capture
var video = document.getElementById('videoElement');
function handleVideo(stream) {
video.src = window.URL.createObjectURL(stream);
}
function videoError(e) {
}
function init() {
setUpCamera();
// draw crop area box
var c = document.getElementById("rectElement");
var ctx = c.getContext("2d");
c.width = 480;
c.height = 360;
ctx.lineWidth = "4";
ctx.strokeStyle = "red";
ctx.rect(120, 50, 240, 260);
ctx.stroke();
document.getElementById('btnPhoto').onclick = function() {
var video = document.getElementById("videoElement");
var canvas = document.getElementById('snapshot-canvas');
var ctx = canvas.getContext('2d');
var printImg = document.getElementById('print-img');
canvas.width = 240;
canvas.height = 260;
// transform the canvas so the image matches the video horitontal flipped image
ctx.translate(canvas.width, 0);
ctx.scale(-1, 1);
var x = (video.videoWidth - canvas.width)/2;
var y = (video.videoHeight - canvas.height)/2;
//ctx.drawImage(video, x, y, canvas.width, canvas.height, 0, 0, canvas.width, canvas.height);
ctx.drawImage(video, 120, 50, 240, 260, 0, 0, 240, 260);
var dataUrl = canvas.toDataURL('image/jpeg');
printImg.src = dataUrl;
}
}
function doPhoto() {
}
function setUpCamera() {
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia || navigator.oGetUserMedia;
if (navigator.getUserMedia) {
navigator.getUserMedia({
video: true
}, handleVideo, videoError);
}
}
init();
あなたはガムのラリー古い実装を使用している、あなたは公式の[アダプタを使用する必要があります.js](https://github.com/webrtc/adapter)polyfill。 – Kaiido