捕获高分辨率视频/图像html5



我使用geUserMedia()从webcam Intro捕获图像。

我得到的最佳分辨率是640 X 480,但我有高清网络摄像头用1280 X 720录制视频拍照2592 X 1944

如何拍摄高分辨率照片?

下面是一个代码示例。它不关心画布的大小:

<video autoplay id="vid" style="display:none;"></video>
<canvas id="canvas" width="1280" height="720" style="border:1px solid #d3d3d3;"></canvas><br>
<button onclick="snapshot()">Take Picture</button>
<script type="text/javascript">
    var video = document.querySelector("#vid");
    var canvas = document.querySelector('#canvas');
    var ctx = canvas.getContext('2d');
    var localMediaStream = null;
    var onCameraFail = function (e) {
        console.log('Camera did not work.', e);
    };
    function snapshot() {
        if (localMediaStream) {
            ctx.drawImage(video, 0, 0);
        }
    }
    navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;
    window.URL = window.URL || window.webkitURL;
    navigator.getUserMedia({video:true}, function (stream) {
        video.src = window.URL.createObjectURL(stream);
        localMediaStream = stream;
    }, onCameraFail);
</script>

http://www.html5rocks.com/en/tutorials/getusermedia/intro/

=>设置媒体约束(分辨率,高度,宽度)

据我所知,无论你有什么相机,WebRTC目前都限制在640x480。

对于像我一样发现自己在这里的人,在http://webrtchacks.com/video-constraints-2/上有一个有用的更新。

查看原始问题,请注意,据我所知,使用WebRTC拍摄静态照片实际上是从视频提要中提取静态帧,因此您将始终受到设备视频分辨率的限制,即使它能够捕获更高分辨率的静态图像。

我使用以下约束来设置分辨率范围,但快照似乎与视频大小有关

var constraints = {
      audio: {deviceId: undefined},
      video: {
           deviceId: vid ? {exact: vid} : undefined
         , width: { min: 1280, max: 1560 }
         , height: { min: 720, max: 1440 }
      }
   };
navigator.mediaDevices.getUserMedia(constraints).then(gotStream).catch(handleError)

相关内容

  • 没有找到相关文章