簡體   English   中英

HTML5視頻網絡攝像機匹配分辨率

[英]HTML5 video webcam match resolution

我正在嘗試使用網絡攝像頭拍攝快照。 我已經覆蓋了一個矩形,它將成為拍攝照片時的裁剪區域。 當我拍攝照片時,所拍攝的圖像被放大。如何使圖像與矩形內的區域相同? https://jsfiddle.net/fzrLvbwf/9/

    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();

我發現視頻是640 x 480,所以我需要找到比例

var rx = (video.videoWidth / videoContainer.clientWidth);
var ry = (video.videoHeight / videoContainer.clientHeight);

ctx.drawImage(video, 120 * rx, 50 * ry, 240 * rx, 260 * ry, 0, 0, 240, 260);

https://jsfiddle.net/fzrLvbwf/11/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM