H5视频录制+拍照.html 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>视频录制+拍照</title>
  7. </head>
  8. <body>
  9. <video id="gum" autoplay muted style="display: block;margin: 0 auto;"></video>
  10. <div style="text-align: center;">
  11. <button id="record" disabled>开始录制</button>
  12. <button id="upload" disabled>播放</button>
  13. <button id="cap">拍照</button>
  14. </div>
  15. <div style="display: flex;justify-content: center;">
  16. <video id="playvideo" autoplay></video>
  17. <canvas id='showcap' width="480" height="480"></canvas>
  18. </div>
  19. </body>
  20. <script>
  21. var mediaSource = new MediaSource();
  22. mediaSource.addEventListener('sourceopen', handleSourceOpen, false);
  23. var mediaRecorder;
  24. var recordedBlobs;
  25. var sourceBuffer;
  26. var gumVideo = document.querySelector('video#gum');
  27. var recordButton = document.querySelector('button#record');
  28. var uploadButton = document.querySelector('button#upload');
  29. var capButton = document.querySelector('button#cap');
  30. var canvas = document.querySelector('canvas#showcap');
  31. let context = canvas.getContext('2d');
  32. recordButton.onclick = toggleRecording;
  33. uploadButton.onclick = upload;
  34. capButton.onclick = capphoto
  35. // window.isSecureContext could be used for Chrome
  36. var isSecureOrigin = location.protocol === 'https:' || location.hostname === 'localhost';
  37. // if (!isSecureOrigin) {
  38. // alert('getUserMedia() must be run from a secure origin: HTTPS or localhost.' + '\n\nChanging protocol to HTTPS');
  39. // location.protocol = 'HTTPS';
  40. // }
  41. var constraints = {
  42. audio: true,
  43. video: {
  44. width: 480,//视频宽度
  45. height: 480,//视频高度
  46. frameRate: 60,//每秒60帧
  47. }
  48. };
  49. // navigator.mediaDevices.getUserMedia(constraints).
  50. // then(handleSuccess).catch(handleError);
  51. if (navigator.mediaDevices.getUserMedia) {
  52. //最新的标准API
  53. navigator.mediaDevices.getUserMedia(constraints).then(handleSuccess).catch(handleError);
  54. } else if (navigator.webkitGetUserMedia) {
  55. //webkit核心浏览器
  56. navigator.webkitGetUserMedia(constraints, handleSuccess, handleError)
  57. } else if (navigator.mozGetUserMedia) {
  58. //firfox浏览器
  59. navigator.mozGetUserMedia(constraints, handleSuccess, handleError);
  60. } else if (navigator.getUserMedia) {
  61. //旧版API
  62. navigator.getUserMedia(constraints, handleSuccess, handleError);
  63. }
  64. function handleSourceOpen(event) {
  65. console.log('MediaSource opened');
  66. sourceBuffer = mediaSource.addSourceBuffer('video/webm; codecs="vp8"');
  67. console.log('Source buffer: ', sourceBuffer);
  68. }
  69. function handleSuccess(stream) {
  70. recordButton.disabled = false;
  71. console.log('getUserMedia() got stream: ', stream);
  72. window.stream = stream;
  73. gumVideo.srcObject = stream;
  74. }
  75. function handleError(error) {
  76. console.log('navigator.getUserMedia error: ', error);
  77. }
  78. function handleDataAvailable(event) {
  79. if (event.data && event.data.size > 0) {
  80. recordedBlobs.push(event.data);
  81. }
  82. }
  83. function handleStop(event) {
  84. console.log('Recorder stopped: ', event);
  85. }
  86. function toggleRecording() {
  87. if (recordButton.textContent === '开始录制') {
  88. startRecording();
  89. } else {
  90. stopRecording();
  91. recordButton.textContent = '开始录制';
  92. uploadButton.disabled = false;
  93. }
  94. }
  95. function startRecording() {
  96. recordedBlobs = [];
  97. var options = { mimeType: 'video/webm;codecs=h264' };
  98. try {
  99. mediaRecorder = new MediaRecorder(window.stream, options);
  100. } catch (e) {
  101. console.error('Exception while creating MediaRecorder: ' + e);
  102. alert('Exception while creating MediaRecorder: '
  103. + e + '. mimeType: ' + options.mimeType);
  104. return;
  105. }
  106. console.log('Created MediaRecorder', mediaRecorder, 'with options', options);
  107. recordButton.textContent = '结束录制';
  108. uploadButton.disabled = true;
  109. mediaRecorder.onstop = handleStop;
  110. mediaRecorder.ondataavailable = handleDataAvailable;
  111. mediaRecorder.start(10); // collect 10ms of data
  112. console.log('MediaRecorder started', mediaRecorder);
  113. }
  114. function stopRecording() {
  115. mediaRecorder.stop();
  116. console.log('Recorded Blobs: ', recordedBlobs);
  117. }
  118. function upload() {
  119. //保存在本地,通过post请求
  120. //还可以用append方法添加一些附加信息参数为(name,value),如下面的代码:
  121. var blob = new Blob(recordedBlobs, { type: 'video/mp4' });
  122. console.log(blob);
  123. let src = window.URL.createObjectURL(blob);
  124. document.getElementById('playvideo').src = src
  125. }
  126. function capphoto() {
  127. context.drawImage(gumVideo, 0, 0, 480, 480);
  128. let dd = canvas.toDataURL('image/jpg');
  129. console.log(776, dd)
  130. }
  131. </script>
  132. </html>