13

我使用 geUserMedia() 从网络摄像头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>
4

4 回答 4

12

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

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

于 2013-11-18T21:48:01.067 回答
4

据我所知,WebRTC 目前仅限于 640x480,无论您拥有什么相机。希望这会很快改变。

于 2013-04-11T19:14:51.963 回答
0

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

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

于 2014-10-22T06:27:55.617 回答
0

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

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)
于 2021-07-06T03:30:37.113 回答