Как сделать снимок и сохранить с веб-камеры с помощью грааля?

Попытка сделать снимок с веб-камеры и хотел сохранить на диске

Использование Grails 2.3.7

код сценария

var video = document.querySelector("#videoElement");
var imageW;
                //check for getUserMedia support
                navigator.getUserMedia = navigator.getUserMedia
                        || navigator.webkitGetUserMedia
                        || navigator.mozGetUserMedia
                        || navigator.msGetUserMedia || navigator.oGetUserMedia;

                if (navigator.getUserMedia) {
                    // get webcam feed if available
                    navigator.getUserMedia({
                        video : true
                    }, handleVideo, videoError);
                }

                function handleVideo(stream) {

                    video.src = window.URL.createObjectURL(stream);
                }

                function videoError(e) {

                }
                var v, canvas, context, w, h;
                var imgtag = document.getElementById('imgtag'); 
                var sel = document.getElementById('"avatar"'); 

                document.addEventListener('DOMContentLoaded', function() {

                    v = document.getElementById('videoElement');
                    canvas = document.getElementById('canvas');
                    context = canvas.getContext('2d');
                    w = canvas.width;
                    h = canvas.height;

                }, false);

                function draw(v, c, w, h) {

                    if (v.paused || v.ended)
                        return false; // if no video, exit here

                    context.drawImage(v, 0, 0, w, h); // draw video feed to canvas

                    var uri = canvas.toDataURL("image/png"); // convert canvas to data URI


                      imageW = canvas.toDataURL("image/png");
        imageW = imageW.replace('data:image/png;base64,', '');


                    imgtag.src = uri;
                }

                document.getElementById('save').addEventListener('click',
                        function(e) {

                            draw(v, context, w, h); 

                        });


                var fr;

                sel.addEventListener('change', function(e) {
                    var f = sel.files[0]; 

                    fr = new FileReader();
                    fr.onload = receivedData; 

                    fr.readAsDataURL(f); 
                })

                function receivedData() {

                    imgtag.src = fr.result;
                }
                function webImageSubmit() {

                    alert(imageW);

                    var pars = "id=" + $('#id').val() + "&imageW=" + imageW;
                    $.ajax({
                        type : 'POST',
                        url : '/controller_name/saveWebCamImage',
                        data : pars,
                        error : function(request, status, error) {

                            document.getElementById('load').style.visibility = "hidden";
                        },
                        beforeSend : function() {
                            document.getElementById('load').style.visibility = "visible";
                        },
                        success : function(data) {
                            location.reload();
                        }
                    });
                }

Сторона контроллера:

def encodedData = javax.xml.bind.DatatypeConverter.parseBase64Binary(params.imageW.toString());
    def defaultPath = "/images/userImages";
        def webRootDir = servletContext.getRealPath("/");
        def systemDir = new File(webRootDir, defaultPath);
        if (!systemDir.exists()) {
            systemDir.mkdirs();
        }

        String file_name = "webImage.jpg";
        def csvFileDir = new File( systemDir, file_name);
        new File(systemDir, file_name).withOutputStream {
            it.write(encodedData);
          };

Но изображение не экономит на диске.

Пожалуйста, помогите мне.. Спасибо..

3 ответа

Полный код для захвата и загрузки

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
   const vid = document.querySelector('video');
navigator.mediaDevices.getUserMedia({video: true}) // request cam
.then(stream => {
  vid.srcObject = stream; // don't use createObjectURL(MediaStream)
  return vid.play(); // returns a Promise
})
.then(()=>{ // enable the button
  const btn = document.querySelector('button');
  btn.disabled = false;
  btn.onclick = e => {
    takeASnap()
    .then(download);
  };
});

function takeASnap(){
  const canvas = document.createElement('canvas'); // create a canvas
  const ctx = canvas.getContext('2d'); // get its context
  canvas.width = vid.videoWidth; // set its size to the one of the video
  canvas.height = vid.videoHeight;
  ctx.drawImage(vid, 0,0); // the video
  return new Promise((res, rej)=>{
    canvas.toBlob(res, 'image/jpeg'); // request a Blob from the canvas
  });
}
function download(blob){
  // uses the <a download> to download a Blob
  let a = document.createElement('a'); 
  a.href = URL.createObjectURL(blob);
  a.download = 'screenshot.jpg';
  document.body.appendChild(a);
  a.click();
}
});
</script>
</head>
<body>
<button disabled>
  take a snapshot</button>
<video></video>

</body>
</html>

Код для предварительного просмотра захваченного изображения

<!doctype html>

<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>WebcamJS Test Page</title>
    <style type="text/css">
        body { font-family: Helvetica, sans-serif; }
        h2, h3 { margin-top:0; }
        form { margin-top: 15px; }
        form input { margin-right: 15px; }
        #results { float:right; margin:20px; padding:20px; border:1px solid; background:#ccc; }
    </style>
</head>
<body>
    <div id="results">Your captured image will appear here...</div>

    <h1>WebcamJS Test Page</h1>
    <h3>Demonstrates 320x240 capture &amp; display with preview mode</h3>

    <div id="my_camera"></div>

    <!-- First, include the Webcam.js JavaScript Library -->
    <script type="text/javascript" src="webcam.min.js"></script>

    <!-- Configure a few settings and attach camera -->
    <script language="JavaScript">
        Webcam.set({
            width: 320,
            height: 240,
            image_format: 'jpeg',
            jpeg_quality: 90
        });
        Webcam.attach( '#my_camera' );
    </script>

    <!-- A button for taking snaps -->
    <form>
        <div id="pre_take_buttons">
            <input type=button value="Take Snapshot" onClick="preview_snapshot()">
        </div>
        <div id="post_take_buttons" style="display:none">
            <input type=button value="&lt; Take Another" onClick="cancel_preview()">
            <input type=button value="Save Photo &gt;" onClick="save_photo()" style="font-weight:bold;">
        </div>
    </form>

    <!-- Code to handle taking the snapshot and displaying it locally -->
    <script language="JavaScript">
        function preview_snapshot() {
            // freeze camera so user can preview pic
            Webcam.freeze();

            // swap button sets
            document.getElementById('pre_take_buttons').style.display = 'none';
            document.getElementById('post_take_buttons').style.display = '';
        }

        function cancel_preview() {
            // cancel preview freeze and return to live camera feed
            Webcam.unfreeze();

            // swap buttons back
            document.getElementById('pre_take_buttons').style.display = '';
            document.getElementById('post_take_buttons').style.display = 'none';
        }

        function save_photo() {
            // actually snap photo (from preview freeze) and display it
            Webcam.snap( function(data_uri) {
                // display results in page
                document.getElementById('results').innerHTML = 
                    '<h2>Here is your image:</h2>' + 
                    '<img src="'+data_uri+'"/>';

                // swap buttons back
                document.getElementById('pre_take_buttons').style.display = '';
                document.getElementById('post_take_buttons').style.display = 'none';
            } );
        }
    </script>

</body>
</html>

Полный код для записи и загрузки

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

</head>
<body>
<button disabled>start recording</button>
<video></video>
<script>
const vid = document.querySelector('video');
navigator.mediaDevices.getUserMedia({video: true}) // request cam
.then(stream => {
  vid.srcObject = stream; // don't use createObjectURL(MediaStream)
  return vid.play(); // returns a Promise
})
.then(()=>{ // enable the button
  const btn = document.querySelector('button');
  btn.disabled = false;
  btn.onclick = startRecording;
});

function startRecording(){
  // switch button's behavior
  const btn = this;
  btn.textContent = 'stop recording';
  btn.onclick = stopRecording;

  const chunks = []; // here we will save all video data
  const rec = new MediaRecorder(vid.srcObject);
  // this event contains our data
  rec.ondataavailable = e => chunks.push(e.data);
  // when done, concatenate our chunks in a single Blob
  rec.onstop = e => download(new Blob(chunks));
  rec.start();
  function stopRecording(){
    rec.stop();
    // switch button's behavior
    btn.textContent = 'start recording';
    btn.onclick = startRecording;
  }
}
function download(blob){
  // uses the <a download> to download a Blob
  let a = document.createElement('a'); 
  a.href = URL.createObjectURL(blob);
  a.download = 'recorded.webm';
  document.body.appendChild(a);
  a.click();
}
</script>
</body>
</html>
Другие вопросы по тегам