Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

johni_9

WebCam PHP

Recommended Posts

Boa tarde pessoal!

Já pesquisei no fórum, testei os tópico apresentados, porém não obtive sucesso.

Eu preciso desenvolver um projeto em PHP, o qual realize a interação com a Webcam e a imagem capturada seja salva em um diretório e o nome dela na Base de Dados;

Segue parte das páginas:

 

FORM que contém a captura da webcam

<form method="post" action="model/cadMaquina.php" enctype="multipart/form-data">

    <div class="col-md-12 mb-3"><center>
        <div id="my_photo_booth">
            <div id="my_camera"></div>

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

            <!-- Configure a few settings and attach camera -->
            <script language="JavaScript">
                Webcam.set({
                    // live preview size
                    width: 320,
                    height: 240,

                    // device capture size
                    dest_width: 640,
                    dest_height: 480,

                    // final cropped size
                    crop_width: 480,
                    crop_height: 480,

                    // format and quality
                    image_format: 'jpg',
                    jpeg_quality: 90,

                    // flip horizontal (mirror mode)
                    flip_horiz: true
                });
                Webcam.attach( '#my_camera' );
            </script>

            <!-- A button for taking snaps -->
            <!-- <form> -->
                <div id="pre_take_buttons">
                    <!-- This button is shown before the user takes a snapshot -->
                    <input type=button value="Capturar Imagem" onClick="preview_snapshot()">
                </div>
                <div id="post_take_buttons" style="display:none">
                    <!-- These buttons are shown after a snapshot is taken -->
                    <input type=button value="Novo Registro" onClick="cancel_preview()">
                    <!-- <input type=button value="Save Photo >" onClick="save_photo()" style="font-weight:bold;"> -->
                </div>
            <!-- </form> -->
        </div>

        <div id="results" style="display:none">
            <!-- Your captured image will appear here... -->
        </div>

        <!-- Code to handle taking the snapshot and displaying it locally -->
        <script language="JavaScript">
            // preload shutter audio clip
            var shutter = new Audio();
            shutter.autoplay = false;
            shutter.src = navigator.userAgent.match(/Firefox/) ? 'shutter.ogg' : 'shutter.mp3';

            function preview_snapshot() {
                // play sound effect
                //try { shutter.currentTime = 0; } catch(e) {;} // fails in IE
                //shutter.play();

                Webcam.snap( function(data_uri) {
                Webcam.upload( data_uri, 'model/cadMaquina.php', function(code, text) {
                document.getElementById('results').innerHTML =
                '<h2>Here is your image:</h2>' +
                '<img src="'+text+'"/>';
                });
                });

                // freeze camera so user can preview current frame
                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 view
                Webcam.unfreeze();

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

    </div></center>
    <div class="col-md-12 mb-1">
        <input type="submit" class="btn btn-success" style="margin-top: 2px; width: 100%;" value="Cadastrar">
    </div>

CADMAQUINA.PHP

<?php
    include("../conexao.php");

    $nome =  md5(time()) . '.jpg';

    $filepath = 'img/';
 
    move_uploaded_file($_FILES['webcam']['tmp_name'], $filepath.$nome);

   
    $cadMaquina = "INSERT INTO inventario SET fotoMaquina='$nome'";

    if ($conn->query($cadMaquina)) {
        echo "Máquina cadastrada com sucesso!!!";
    } else {
        echo "Máquina não cadastrada!!!";
    }
?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 hora atrás, marcosmarcolin disse:

Certo, mas o que está acontecendo? O que você não conseguiu fazer? Está conseguindo tirar a foto? Detalhe bem a sua questão para ajudarmos.

O sistema captura a foto, mantém a imagem congelada após o click, porém quando clico no SUBMIT não salva a imagem na pasta IMG e não envia o nome para o banco de dados

A página possui um botão para captura da imagem, outro para realizar um novo registro da câmera e o submit.

 

cam.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Certo, primeiro precisa certificar algumas coisas:

 

1. A pasta img existe na raiz?

 

2. A imagem está chegando no arquivo php para ser processada?

$_FILES['webcam']['tmp_name'] existe mesmo? Sugiro você criar uma variável para receber $_FILES['webcam'], depois você utiliza ela para mover.

 

3. Seu INSERT está incorreto, corrija para:

"INSERT INTO inventario SET (fotoMaquina) VALUES ('$nome')";

Verifica isso e retorne.

 

A principal questão é saber se a imagem está chegando no cadmaquina.php, depois fica fácil de tratar, garanto que resolveremos.

 

Aguardo seu retorno.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Consegui resolver a situação com a ajuda de um colega da empresa.

Estou postando o código para que a comunidade possa utilizar:

 

FORM:

<form method="post" action="cadMaquina.php" enctype="multipart/form-data">
    <!-- ################################################################# -->
    <div class="col-md-12 mb-3"><center>
        <div id="my_photo_booth">
            <div id="my_camera"></div>

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

            <!-- Configure a few settings and attach camera -->
            <script language="JavaScript">
                Webcam.set({
                    // live preview size
                    width: 320,
                    height: 240,

                    // device capture size
                    dest_width: 640,
                    dest_height: 480,

                    // final cropped size
                    crop_width: 480,
                    crop_height: 480,

                    // format and quality
                    image_format: 'jpg',
                    jpeg_quality: 90,

                    // flip horizontal (mirror mode)
                    flip_horiz: true
                });

                Webcam.attach( '#my_camera' );
            </script>

            <!-- A button for taking snaps -->
            <!-- <form> -->
                <div id="pre_take_buttons">
                    <!-- This button is shown before the user takes a snapshot -->
                    <input type=button value="Capturar Imagem" onClick="preview_snapshot()">
                </div>
                <div id="post_take_buttons" style="display:none">
                    <!-- These buttons are shown after a snapshot is taken -->
                    <input type=button value="Novo Registro" onClick="cancel_preview()">
                    <!-- <input type=button value="Save Photo >" onClick="save_photo()" style="font-weight:bold;"> -->
                </div>
            <!-- </form> -->
        </div>

        <div id="results" style="display:none">
            <!-- Your captured image will appear here... -->
        </div>

        <!-- Code to handle taking the snapshot and displaying it locally -->
        <script language="JavaScript">
            // preload shutter audio clip
            var shutter = new Audio();
            shutter.autoplay = false;
            shutter.src = navigator.userAgent.match(/Firefox/) ? 'shutter.ogg' : 'shutter.mp3';

            function preview_snapshot() {
                // play sound effect
                //try { shutter.currentTime = 0; } catch(e) {;} // fails in IE
                //shutter.play();

                var imgbase64 = undefined;

                Webcam.snap((data_uri) => {
                    imgbase64 = data_uri;
                    /* Opção 1 - Inserindo a imagem em BASE64 no formulário */
                    document.getElementById('fotoMaquina').value=imgbase64;
                    //console.log(data_uri);
                });

                /* Opção 2 - Caso queira fazer o upload em tempo real para algum outro lugar...
                Webcam.upload(imgbase64,'model/cadMaquina.php', function(code,text){
                    console.log(code);
                    console.log(text);
                });*/

                // freeze camera so user can preview current frame
                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 view
                Webcam.unfreeze();

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

        <input type="hidden" id="fotoMaquina" name="fotoMaquina">

    </div></center>
    <!-- ################################################################# -->
    <div class="col-md-12 mb-1">
        <input type="submit" class="btn btn-success" style="margin-top: 2px; width: 100%;" value="Cadastrar">
    </div>
</form>

TRATAMENTO.PHP

<?php
    if(!empty($_FILES)) {
        $nome =  md5(time()) . '.jpg';
        $filepath = 'img/';
 
        move_uploaded_file($_FILES['webcam']['tmp_name'], $filepath.$nome);
    }

    session_start();
    include("../conexao.php");

    $fotoMaquina = $_POST['fotoMaquina'];

    if ($fotoMaquina) {
        $filepath = '../maquinas/';

        $img = str_replace('data:image/png;base64,', '', $fotoMaquina);
        $img = str_replace(' ', '+', $img);
        $data = base64_decode($img);
        $nome = uniqid() . '.png';

        $salvarFoto = (file_put_contents($filepath . $nome, $data) ? true : false);
    }

    /** #################################### **/
    /** #################################### **/
    
    $cadMaquina = "INSERT INTO inventario SET fotoMaquina='$nome'";

    // $cadastrado = mysqli_query($conn, $cadMaquina);

    if ($conn->query($cadMaquina)) {
        echo "Máquina cadastrada com sucesso!!!";
        header('Location: ../maquina.php');
    } else {
        echo "Máquina não cadastrada!!!";
    }
?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por juliosonic
      Boa noite..
      Estou desenvolvendo um site de https://www.maithunatantra.com.br/ e estou com um duvida sobre o menu de navegação da versão mobile.
      O menu que tem o dropdown "Terapeutas" e "Terapias" quando clico em cima ele expande como deve ser, mas quando clico denovo para recolher os submenus
      nao acontece nada.. segue o trecho do codigo do menu..
      <div class="collapse navbar-collapse" id="navbarsExample09">             <ul class="navbar-nav ml-auto">               <li class="nav-item  active"><a class="nav-link" href="index.html">Home</a></li>               <li class="nav-item  active"><a class="nav-link" href="about-us.html">Quem Somos</a></li>               <li class="nav-item dropdown1">                     <a class="nav-link dropdown-toggle" data-toggle="dropdown1" href="#">Terapeutas</a>                     <ul class="dropdown-menu">                         <li><a class="dropdown-item" href="terapeuta-julio-cezar.html">Julio Cezar</a></li>                         <li><a class="dropdown-item" href="terapeuta-pamela-priscila.html">Pamela Priscila</a></li>                     </ul>                                    </li>               <li class="nav-item dropdown">                     <a class="nav-link dropdown-toggle" data-toggle="dropdown1" href="#">Terapias</a>                     <ul class="dropdown-menu" aria-labelledby="dropdown01">                         <li><a class="dropdown-item" href="o-que-e-reiki.html">O que é Reiki</a></li>                         <li><a class="dropdown-item" href="beneficios-reiki.html">Benefícios do Reiki</a></li>                         <li><a class="dropdown-item" href="principios-reiki.html">Princípios do Reiki</a></li>                         <li><a class="dropdown-item" href="animais-reiki.html">Reiki em Animais</a></li>                         <li><a class="dropdown-item" href="animais-reiki.html">Estudos Sobre Reiki</a></li>                         <li><a class="dropdown-item" href="terapia-massagem-tantrica.html">Terapia Tântrica</a></li>                     </ul>               </li>               <li class="nav-item  active"><a class="nav-link" href="blog.html">Blog</a></li>                <li class="nav-item"><a class="nav-link" href="contato.html">Contato</a></li>             </ul>         </div>  
      Massagem Tantrica em Curitiba
      Tantra Curitiba
      Massagem Tântrica
      Tantra
      Julio Darshan

      Obrigado
      Att
      Julio Cezar
       
       
       
    • Por joeythai
      Boa tarde pessoal,
       
      Eu criei um formulário em que tenho 3 interações: evento click, change e uma chamada ajax. No evento on change ("select#removal_table_from" )eu faço uma chamada ajax onde eu passo como parametro o id do item selecionado e construo uma tabela dinamica com o próprio javascript, após isto, tenho um input em que o usuario coloca um valor de percentual para que eu possa preencher em 3 colunas da tabela que foi criada dinamicamente: moto_atualizado, carro_atualizado e caminhao_atualizado, até aí tudo bem, o codigo está fazendo isso, porém, como a tabela é criada dinamicamente eu preciso de alguma forma enviar o arrayData para meu backend mas quando faço o calculo dentro do loop apos resposta do meu ajax, os valores desses 3 campos chegam como null, não sei se é possível fazer o que pretendo ou se é ainda não sei como faz
       
      <code>
           $(document).ready(function (event) {   let arrayData = []; let percentage; let removal_vehicle; let removal_motorcycle; let removal_tuck; let apply_removal = $('#apply_removal');   // apply_removal.on('click', function () { // percentage = $('#percentage').val();   // $('.table-body tr').each(function () {   // let veiculo = $(this).find('.veiculo').text(); // let moto = $(this).find('.moto').text(); // let caminhao = $(this).find('.caminhao').text();   // let removal_vehicle = parseFloat(veiculo) + (parseFloat(veiculo) * parseFloat(percentage)) / 100; // let removal_motorcycle = parseFloat(moto) + (parseFloat(moto) * parseFloat(percentage)) / 100; // let removal_tuck = parseFloat(caminhao) + (parseFloat(caminhao) * parseFloat(percentage)) / 100;   // arrayData.push({ // removal_vehicle, // removal_motorcycle, // removal_tuck // })   // $(this).find('.veiculo_atualizado').val(removal_vehicle.toFixed(2)); // $(this).find('.moto_atualizado').val(removal_motorcycle.toFixed(2)); // $(this).find('.caminhao_atualizado').val(removal_tuck.toFixed(2)); // }); // });   apply_removal.on('click', function () { percentage = $('#percentage').val();   $('.table-body tr').each(function () {   let veiculo = $(this).find('.veiculo').text(); let moto = $(this).find('.moto').text(); let caminhao = $(this).find('.caminhao').text();   removal_vehicle = parseFloat(veiculo) + (parseFloat(veiculo) * parseFloat(percentage)) / 100; removal_motorcycle = parseFloat(moto) + (parseFloat(moto) * parseFloat(percentage)) / 100; removal_tuck = parseFloat(caminhao) + (parseFloat(caminhao) * parseFloat(percentage)) / 100;   arrayData.push({ removal_vehicle, removal_motorcycle, removal_tuck })   $(this).find('.veiculo_atualizado').val(removal_vehicle.toFixed(2)); $(this).find('.moto_atualizado').val(removal_motorcycle.toFixed(2)); $(this).find('.caminhao_atualizado').val(removal_tuck.toFixed(2));     console.log('Removal Vehicle:', removal_vehicle); console.log('Removal Motorcycle:', removal_motorcycle); console.log('Removal Truck:', removal_tuck); }); });   $('select#removal_table_from').on('change', function (e) { let table_id = $(this).val(); let action = route('removal.removal-values.show', table_id);   $.ajax({ type: "GET", url: action, headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') },   success: function (data) { $('.table-body').empty();   for (let i = 0; i < data.length; i++) { let carro = parseFloat(data[i].CARRO); let moto = parseFloat(data[i].MOTO); let caminhao = parseFloat(data[i].CAMINHAO); let distancia = data[i].DISTANCIA; let origem = data[i].ORIGEM; let destino = data[i].DESTINO; let localidadeOrigem = data[i].LocalidadeOrigem_ID; let localidadeDestino = data[i].LocalidadeDestino_ID;   let newRow = '<tr class="removal-row">' + '<td class="align-middle">' + '<div class="row">' + '<div class="col-1">' + '<span class="font-weight-bold">Origem</span><br>' + '<span class="origem">' + origem + '</span>' + '</div>' + '<div class="col-1">' + '<span class="font-weight-bold">Destino</span><br>' + '<span class="destino">' + destino + '</span>' + '</div>' + '<div class="col-1">' + '<span class="font-weight-bold">KM</span><br>' + '<span class="km">' + distancia + '</span>' + '</div>' + '<div class="col-1">' + '<span class="font-weight-bold">Veículo</span><br>' + '<span class="veiculo">' + carro + '</span>' + '</div>' + '<div class="col-2">' + '<span class="font-weight-bold">Veículo Atualizado</span><br>' + '<input type="text" class="veiculo_atualizado">' + '</div>' + '<div class="col-1">' + '<span class="font-weight-bold">Moto</span><br>' + '<span class="moto">' + moto + '</span>' + '</div>' + '<div class="col-2">' + '<span class="font-weight-bold">Moto Atualizado</span><br>' + '<input type="text" class="moto_atualizado">' + '</div>' + '<div class="col-1">' + '<span class="font-weight-bold">Caminhão</span><br>' + '<span class="caminhao">' + caminhao + '</span>' + '</div>' + '<div class="col-2">' + '<span class="font-weight-bold">Caminhão Atualizado</span><br>' + '<input type="text" class="caminhao_atualizado">' + '</div>' + '</div>' + '</div>' + '</td>' + '</tr>';   $('.table-body').append(newRow); //let row = $('.removal-row:last');   // Calcula o valor atualizado e define nos campos diretamente // let veiculo_atualizado = carro + (carro * percentage) / 100; // let moto_atualizado = moto + (moto * percentage) / 100; // let caminhao_atualizado = caminhao + (caminhao * percentage) / 100; // console.log('PORCENTS: ', percentage); //console.log('Veiculo Atualizado:', veiculo_atualizado, 'Moto Atualizado:', moto_atualizado, 'Caminhao Atualizado:', caminhao_atualizado);   // Define os valores diretamente nos campos da nova linha // row.find('.veiculo_atualizado').val(veiculo_atualizado.toFixed(2)); // row.find('.moto_atualizado').val(moto_atualizado.toFixed(2)); // row.find('.caminhao_atualizado').val(caminhao_atualizado.toFixed(2));   arrayData.push({ carro, moto, caminhao, distancia, origem, destino, localidadeOrigem, localidadeDestino, removal_vehicle, removal_motorcycle, removal_tuck }); }   $('#copy_data_table').val(JSON.stringify(arrayData)); }   }); });   //javascript para o formulario de cadastro // $(document).ready(function (event) { $('#uf').change(function () { let code_city = $(this).val(); let deposit = localStorage.getItem('selected_deposit_id'); let action = route('removal.removal-values.cities', code_city); $.ajax({ type: "POST", url: action, headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }, data: { code_city: code_city },   success: function (data) {   $('#city').empty(); $('#deposit').empty();   for (let i = 0; i < data.cities.length; i++) { $('#city').append('<option value="' + data.cities[i].NM + '">' + data.cities[i].NM + '<option>'); }   if (data.deposits.length > 0) { for (let i = 0; i < data.deposits.length; i++) { $('#deposit').append('<option value="' + data.deposits[i].NM + '">' + data.deposits[i].NM + '<option>'); } } else { // $('#deposit').prop('disabled', true); // $('#city').prop('disabled', false); }   $('#city').trigger('change'); } });   });   $('#deposit').on('change', function () { depositId = $(this).val(); localStorage.setItem('selected_deposit_id', depositId); });   $('#uf_destiny').change(function () { let code_city = $(this).val(); let depositDestiny = localStorage.getItem('selected_deposit_destiny_id'); let action = route('removal.removal-values.cities', code_city); $.ajax({ type: "POST", url: action, headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }, data: { code_city: code_city },   success: function (data) {   $('#city_destiny').empty(); $('#deposit_destiny').empty();   for (let i = 0; i < data.cities.length; i++) { $('#city_destiny').append('<option value="' + data.cities[i].NM + '">' + data.cities[i].NM + '</option>'); }   if (data.deposits.length > 0) { // $('#deposit_destiny').prop('disabled', false); //$('#city_destiny').empty(); // $('#city_destiny').prop('disabled', true); for (let i = 0; i < data.deposits.length; i++) { $('#deposit_destiny').append('<option value="' + data.deposits[i].NM + '">' + data.deposits[i].NM + '</option>'); } } else { // $('#deposit_destiny').prop('disabled', true); // $('#city_destiny').prop('disabled', false); }   $('#city_destiny').trigger('change'); } }); });   $('#deposit_destiny').on('change', function () { let depositDestinyId = $(this).val(); localStorage.setItem('selected_deposit_destiny_id', depositDestinyId); });   }); </code>
    • Por babylon
      Olá galera tudo bem?
      Deixa eu perguntar, estava mexendo no meu site e queria adicionar em html essa tabela porem esta dando erro pois fica assim:
       

      Porem gostaria que ficasse assim:

      Segue o código da tabela:
      <center><table border="0">
          <tr>
      <td bgcolor="#0092df" width="24%"><a href="/categorias?ename=smartphones"><span style="font-size: 20px; color: #ffffff;"><b> <font color="#0092df">..</font>Bicicleta<br> <font color="#0092df">..</font>Track Bikes<br> <font color="#0092df">..</font>Aro 29 TKS</b></a></span><br><br><font size="5"><center><span style="background-color: #A1CD44">DE:</span></font> <br><font size="5"><s>R$ 1.999,99</center></font></s> </td><td><p><a href="/categorias?ename=smartphones"><img src="/static/img/itembicicleta.jpg"><br><font size="5"><center><span style="background-color: #A1CD44">COM - 60%:</span></font> <br><font size="5">1.199,99</font></center></a></td>
             <td><font color="#ffffff">....</font></td>
              <td bgcolor="#0092df" width="24%"><a href="/categorias?ename=smartphones"><span style="font-size: 20px; color: #ffffff;"><b> <font color="#0092df">..</font>Monitor 24"<br> <font color="#0092df">..</font>Samsung<font color="#0092df">aa.aa</font><br> <font color="#0092df">..</font>1ms 144hz</b></a></span></center></td><td><p><a href="/categorias?ename=smartphones"><img src="/static/img/itemmonitor.jpg"></a></td>
          </tr>
          </table></center>
      O que estaria errado, pois não sei como colocar nessa tabela outro fundo de outra cor, veja que usei td bgcolor="#0092df" para o azul escuro mas não sei como usaria pro "#e4f1fb" para o fundo ficar de azul claro em baixo bem como não ficou correto em altura o "DE:" com o "COM - 60%:".
      Bom é isso, obg.


    • Por Alessandro Bodão
      Fala galerinha, 
       
      Tenho um container com um título (h1) no cabeçalho do meu site, esse container ocupa metade da tela (50vw), e eu gostaria que esse título ocupasse toda a largura desse container, independente do seu tamanho ou do tamanho do monitor, de forma com que a palavra tenha exactamente o mesmo tamanho do container (vou anexar uma foto de exemplo). Já tentei todos os valores pra essa h1, como % e vw... mas nada parece fazer sentido.
       
       

    • Por viniciusfroner
      Tenho um pequeno sistema de envio, estou utilizando o "PHPMailerAutoload". Após o usuário inserir as informações e clicar em enviar a mensagem é enviada com sucesso, o único problema é que apresentado ao usuário a seguinte mensagem:
      if ($enviado){ echo "E-mail enviado com sucesso!"; } else { echo "Não foi possível enviar o e-mail."; echo "<b>Informações do erro:</b> " . $msg->ErrorInfo; } Acabei procurando e não achei como posso remover a mensagem "Error:"
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.