如何使用JavaScript打开网络摄像头?


在本教程中,我们将学习如何使用JavaScript打开网络摄像头。可以使用WebRTC来实现。WebRTC是Web实时通信的缩写。使用此对象,我们可以访问和捕获用户设备中可用的网络摄像头和麦克风设备。

如何访问网络摄像头?

我们可以使用ECMAScript对象`navigator.mediaDevices.getUserMedia(constraints)`访问用户设备的网络摄像头和麦克风。

因此,`getUserMedia()`函数默认会请求用户权限以使用您的网络摄像头。此函数返回一个**Promise**,一旦您点击确定并授予权限,则Promise函数被触发,它将在您的系统中启用网络摄像头;否则,如果您不允许,它还有一个catch方法来关闭网络摄像头。

我们还可以向`getUserMedia()`函数传递参数,例如我们想要特定宽度或高度的图片。

打开网络摄像头的过程

我们可以按照以下步骤使用JavaScript打开网络摄像头。

  • **步骤1** - 添加HTML元素,例如用于显示网络摄像头流的视频和一个按钮。

  • **步骤2** - 检查网络摄像头是否可用并解析`getUserMedia`函数返回的Promise。

  • **步骤3** - 向`getUserMedia()`函数传递参数,例如audio和video为true,因为我们将使用它们。

  • **步骤4** - 在智能手机的情况下,我们必须使用`facingMode`选项,因为两个摄像头都可用,并且默认情况下,我们使用前置摄像头打开。

示例

下面是一个打开网络摄像头的简单程序。我们已经按照上述步骤完成了我们的任务。

<html> <head> <title>Open webcam using JavaScript. </title> </head> <body> <h1>Open WebCam Using JavaScript</h1> <br/> <button id="startBtn" onclick="openCam()">Open Webcam</button> <br/><br/> <video id="videoCam"></video> <script> function openCam(){ let All_mediaDevices=navigator.mediaDevices if (!All_mediaDevices || !All_mediaDevices.getUserMedia) { console.log("getUserMedia() not supported."); return; } All_mediaDevices.getUserMedia({ audio: true, video: true }) .then(function(vidStream) { var video = document.getElementById('videoCam'); if ("srcObject" in video) { video.srcObject = vidStream; } else { video.src = window.URL.createObjectURL(vidStream); } video.onloadedmetadata = function(e) { video.play(); }; }) .catch(function(e) { console.log(e.name + ": " + e.message); }); } </script> </body> </html>

使用CSS设计界面

首先,让我们使用HTML和CSS设计我们的网页界面。

我们添加了网络摄像头视频区域之类的组件,并使用CSS将其高度和宽度设置为400px,背景颜色为黑色。它将显示网络摄像头视频流。

添加一个名为**打开摄像头**的按钮并应用其CSS属性;此按钮将用于启动网络摄像头。

现在我们将添加并嵌入我们的功能代码到主程序中。

我们将调用函数,当单击**打开摄像头**按钮时,将执行上面讨论的所有指令。

示例

在下面的示例中,我们添加了一些CSS来设计更具交互性的界面。

<html> <head> <title>Open webcam using JavaScript.</title> <style> *{ background-color: #658EA9; } #videoCam { width: 630px; height: 300px; margin-left: 0px; border: 3px solid #ccc; background: black; } #startBtn { margin-left: 280px; width: 120px; height: 45px; cursor: pointer; font-weight: bold; } #startBtn:hover{ background-color: #647C90; color: red; } </style> </head> <body> <h1>Open WebCam Using JavaScript</h1> <br/> <video id="videoCam"></video> <br/><br/> <button id="startBtn" onclick="openCam()">Open Camera</button> <script> function openCam(){ let All_mediaDevices=navigator.mediaDevices if (!All_mediaDevices || !All_mediaDevices.getUserMedia) { console.log("getUserMedia() not supported."); return; } All_mediaDevices.getUserMedia({ audio: true, video: true }) .then(function(vidStream) { var video = document.getElementById('videoCam'); if ("srcObject" in video) { video.srcObject = vidStream; } else { video.src = window.URL.createObjectURL(vidStream); } video.onloadedmetadata = function(e) { video.play(); }; }) .catch(function(e) { console.log(e.name + ": " + e.message); }); } </script> </body> </html>

从输出屏幕中可以看出,当我们点击“打开摄像头”按钮时,它会请求访问网络摄像头,当我们允许访问时,它将在视频区域屏幕中启动网络摄像头视频流;如果我们不授予访问权限,则不会显示任何输出。

更新于:2022年8月23日

19K+ 次浏览

启动您的职业生涯

通过完成课程获得认证

开始
广告
© . All rights reserved.