首先通过nodejs搭建web服务器,搭建好后将服务启动。然后在public目录下新建一个recordVideo目录,在recordVideo目录下创建一个index.html文件,代码内容如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>webrtc录制音视频</title>
<script type="text/javascript" src="js/jquery.min.js"></script>
</head>
<body>
<video autoplay playsinline id="player"></video>
<video playsinline id="recordPlayer"></video>
<!-- 在开始录制之前播放和下载按钮时禁用的 -->
<button id="recordBtn">开始录制</button>
<button id="playBtn" disabled="">播放</button>
<button id="downloadBtn" disabled="">下载</button>
<script type="text/javascript" src="js/client.js"></script>
</body>
</html>
然后在recordVideo目录下新建一个js目录,在js目录下创建一个client.js文件,代码内容如下:
'use strict'
var player = $("#player")[0];
var recordPlayer = $("#recordPlayer")[0];
var recordBtn = $("#recordBtn");
var playBtn = $("#playBtn");
var downloadBtn = $("#downloadBtn");
var buffer; // 用于存储录制数据(数组)
var mediaStream;
var mediaRecoder;
start();
// 录制按钮点击事件
recordBtn.click(function(){
// 录制按钮的title在'开始录制'和'停止录制'之间进行切换
if (recordBtn.text()==='开始录制') {
startRecord();
recordBtn.text('停止录制');
playBtn.attr('disabled',false);
downloadBtn.attr('disabled',false);
}else if (recordBtn.text()==='停止录制') {
stopRecord();
recordBtn.text('开始录制');
// playBtn.attr('disabled',true);
// downloadBtn.attr('disabled',true);
}
});
// 播放按钮点击事件
playBtn.click(function(){
var blob = new Blob(buffer,{type:'video/webm'});
// 根据缓存数据生成url给recordPlayer进行播放
recordPlayer.src = window.URL.createObjectURL(blob);
recordPlayer.srcObject = null;
recordPlayer.controls = true; // 显示播放控件
});
// 下载按钮点击事件
downloadBtn.click(function(){
var blob = new Blob(buffer,{type:'video/webm'});
// 根据缓存数据生成url
var url = window.URL.createObjectURL(blob);
// 创建一个a标签,通过a标签指向url来下载
var a = document.createElement('a');
a.href = url;
a.style.display = 'none'; // 不显示a标签
a.download = 'test.webm'; // 下载的文件名
a.click(); // 调用a标签的点击事件进行下载
});
// 开始录制
function startRecord(){
var options = {mimeType:'video/webm;codecs=vp8'};
if(!MediaRecorder.isTypeSupported(options.mimeType)){
console.log('不支持'+options.mimeType);
return;
}
try{
buffer = [];
mediaRecoder = new MediaRecorder(mediaStream,options);
}catch(e){
console.log('创建MediaRecorder失败!');
return;
}
mediaRecoder.ondataavailable = handleDataAvailable;
// 开始录制,设置录制时间片为10ms(每10s触发一次ondataavilable事件)
mediaRecoder.start(10);
}
// 停止录制(停止录制时也会触发ondataavilable事件)
function stopRecord (){
mediaRecoder.stop();
}
// 触发ondataavilable事件的回调函数
function handleDataAvailable(e){
if (e && e.data && e.data.size>0) {
buffer.push(e.data);
}
}
function start(){
if (!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) {
console.log('不支采集音视频数据!');
}else{
// 采集音频数据
var constrants = {
video:true,
audio:true
};
navigator.mediaDevices.getUserMedia(constrants).then(gotMediaStream).catch(handleError);
}
}
// 采集音频数据成功时调用的方法
function gotMediaStream(stream){
mediaStream = stream;
player.srcObject = stream;
}
// 采集音频数据失败时调用的方法
function handleError(err){
console.log(err.name+':'+err.message);
}
然后打开浏览器在地址栏输入https://192.168.20.242:8081/recordVideo/index.html
,点击'开始录制'按钮进行录制,点击'播放'按钮可以播放刚刚录制的内容,点击'下载'按钮可以下载刚刚录制的内容,这里下载的是webm格式的视频,可以用浏览器打开进行播放。
网友评论