前端实现: 抓拍和定时弹出任务
1.代码示例
<html> <head> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <script src="https://cdn.bootcss.com/jquery-json/2.6.0/jquery.json.min.js"></script> </head> <body> <!-- <a href="javascript:;" onClick="playorpause()">播放视频</a> --> <div class="video" style="width: 100%;height: 100%;"></div> <div id="problems" style="display: none;"> </div> <div id="problems2" style="display: none"> <div class="content"> <div class="hide_box"></div> <div id="heihei" class="shang_box" style="display: none;"> <div class="shang_tit"> <p>采集信息</p> </div> <div class="problem_order"> <div class="problem_answer"> <br/> <video id="v" style="width: 192px;height: 144px;"></video> <img src="" id="photo" alt="photo" style="width: 192px;height: 144px; float: right;"> <canvas id="canvas" style="display:none;"></canvas> <br/> </div> </div> <div class="order_info" style="display: none;"><p id="order_info_p"></p></div> <div class="shang_payselect"> <button class="btn-common" id="take">拍照</button> </div> </div> </div> </div> <script> var all_player = '' var default_avatar = '' var face_url = 'https://mooc.ndmooc.com/tmp/files/image/photo/3/3.jpg' var problem_view_ats_list2 = '[0]' // console.log('---------',problem_view_ats_list2) problem_view_ats_list2 = JSON.parse(problem_view_ats_list2) // var problem_view_ats_list2 = [5, '5',600, '600','1200','2400','4800'] console.log('---------',face_url) $('#photo').attr('src', face_url) function bbb(t) { var player_time = player.V.currentTime.toFixed(0); settimeFn2(player_time) } function settimeFn2(player_time) { //console.log('----------settimeFn2----------') var showTime = 2; var time = showTime; $(document).on('click', function() { time = showTime; }); var interCount = setInterval(function() { time--; if(time == 0) { clearInterval(interCount); var index2 = $.inArray(parseInt(player_time), problem_view_ats_list2); var index3 = $.inArray(player_time.toString(), problem_view_ats_list2); console.log(player_time,problem_view_ats_list2) if(index2 >= 0 || index3 > 0){ console.log('---index2!!!!---,') ShowMessage2(); } } }, 1000); function ShowMessage2() { console.log('---ShowMessage2---') console.log($('#heihei').css('display')) $('#heihei').attr("style",'display: block;') $('#problems2').attr("style",'display: block;') console.log($('#heihei').attr("style")) $('#heihei').css('display','block'); $('#problems2').css('display','block'); player.videoPause(); }; } </script> <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script> <script> // 拍照--------- !(function () { var avatar_video = null console.log("1111111111111111111") if (navigator.mediaDevices === undefined) { navigator.mediaDevices = {}; } if (navigator.mediaDevices.getUserMedia === undefined) { navigator.mediaDevices.getUserMedia = function (constraints) { var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia; if (!getUserMedia) { return Promise.reject(new Error('getUserMedia is not implemented in this browser')); } return new Promise(function (resolve, reject) { getUserMedia.call(navigator, constraints, resolve, reject); }); } } navigator.mediaDevices.getUserMedia({audio: true, video: true}) .then(function (stream) { var video = document.querySelector('#v'); if ("srcObject" in video) { video.srcObject = stream; } else { video.src = window.URL.createObjectURL(stream); } video.onloadedmetadata = function (e) { avatar_video = true video.play(); }; }) .catch(function (err) { console.log("ERROR"); $('#order_info_p').html('加载摄像头失败'); $('.order_info').css('display', 'block'); console.log(err.name + ": " + err.message); }); if (avatar_video) { document.getElementById('take').addEventListener('click', function () { paizhao(video) }, false); } else { console.log("不支持"); } })(); </script> <script> var face_url = 'https://mooc.ndmooc.com/tmp/files/image/photo/3/3.jpg' console.log('-------face_url-----', face_url) function paizhao(video){ let canvas = document.getElementById('canvas'); canvas.width = video.videoWidth; canvas.height = video.videoHeight; canvas.getContext('2d').drawImage(video, 0, 0); let data = canvas.toDataURL("image/jpeg", 0.8); console.log("---data---", data) document.getElementById('photo').setAttribute('src', data); var avatar_url = 'https://yykrlc.oss-cn-beijing.aliyuncs.com/2.jpg' var face_url = 'https://mooc.ndmooc.com/tmp/files/image/photo/3/3.jpg' var avatar_url = face_url imagesAjaxFace(data,avatar_url) } </script> <script> function imagesAjaxFace(img_base64,avatar_url) { var data = {}; data.img_base64 = img_base64; //data.avatar_img_base64 = img_base64; data.avatar_url = avatar_url; var face_url = 'https://mooc.ndmooc.com/tmp/files/image/photo/3/3.jpg' console.log('---imagesAjaxFace---') $.ajax({ //url: "http://192.168.1.82:5000/api/v1/dlib/face", //url: "https://11.22.com/api/v1/bdaip/face", //url: "http://127.0.0.1:5000/api/v1/bdaip/face", //url: '/api/v1/common/baidu/face', url: '/api/v1/common/baidu/face', data: data, type: "POST", dataType: 'json', success: function (re) { console.log(re) if(re.aip_face>= 80){ $('#heihei').attr("style",'display:none'); $('#problems2').attr("style",'display:none'); player.videoPlay() }else{ $('#order_info_p').html('匹配失败'); $('.order_info').attr("style",'display:block'); //setTimeout(function(){ $("#take").click() }, 9000); } } }); }; </script> <input type="hidden" value="[]" id="pro"> <script type="text/javascript"> var idLoadHandler=false; var is_live = 'false'; var course_id = '12'; var module_id = '16'; var item_id = '14'; var problem_view_ats_str = ''; var problem_view_ats_list = problem_view_ats_str.split(","); // var problem_view_ats_list2 = ['5','600','1200','2400','4800'] // var problem_view_ats_list2 = [] var problem_json = JSON.parse($("#pro").val()); // var problem_json = [{ A: "指令寄存器",B: "地址寄存器",C: "指令译码器",D: "地址译码器",id: 16,position: 0,problem_type: "Single",title: "CPU组成中不包括文库 。", // view_at: "4"}, // { A: "运算器", B: "控制器", C: "存储器",D: "I/O接口",id: 17, position: 0, problem_type: "Single",title: "CPU组成中不包括文库 。",view_at: "16"}] if(is_live == 'true'){ is_live = true }else{ is_live = false } var videoObject = { container: '.video',//“#”代表容器的ID,“.”或“”代表容器的class variable: 'player',//该属性必需设置,值等于下面的new chplayer()的对象 loaded: 'loadedHandler',//监听播放器加载成功 autoplay: true, live: is_live, video: 'https://moocfiles.ndmooc.com/course/12/videos/2020/06/16/159229134264.mp4'//视频地址 }; var player=new ckplayer(videoObject); var totaltime = player.V.duration; function loadedHandler(){//播放器加载后会调用该函数 idLoadHandler=true; player.addListener('time', aaa); //监听播放时间,addListener是监听函数,需要传递二个参数,'time'是监听属性,这里是监听时间,timeHandler是监听接受的函数 player.addListener('time', bbb); //监听播放时间,addListener是监听函数,需要传递二个参数,'time'是监听属性,这里是监听时间,timeHandler是监听接受的函数 }; var num_1 = 0; var times_status = true; function aaa(t) { //console.log('----------aaaa---------------'); var player_time = player.V.currentTime.toFixed(0); // console.log(player.V.currentTime.toFixed(0)); num_1 += 1; if (num_1 % 30 == 0) { timeHandler(t) } /*判断是视频下是否存在问题*/ if (problem_json.length > 0) { settimeFn(player_time) } // if (1) { // console.log('-----settimeFn2----') // settimeFn2(player_time) // } } function timeHandler(t){ if(!totaltime){totaltime = player.V.duration;} // console.log('当前播放的时间:'+ t); if(course_id){ sync_learn(course_id, module_id, item_id, t) } } function sync_learn(course_id, module_id, item_id, time_now){ $.ajax({ url: '/api/v1/personals/courses/'+ course_id +'/modules/'+ module_id +'/items/' + item_id + '/record', type:'get', dataType:'text', data:{ starting_time: time_now, }, success:function(data){ // console.log(data); times_status = false; } }) } function loadHandler(){ idLoadHandler=true; } function playorpause(){ if(idLoadHandler){ player.playOrPause(); } else{ alert('播放器还未加载,不能进行控制'); } } function settimeFn(player_time) { // var problem_arr_index = Math.floor((Math.random()*problem_total)); var showTime = 2; var time = showTime; $(document).on('click', function() { time = showTime; }); var interCount = setInterval(function() { time--; if(time == 0) { clearInterval(interCount); var index = $.inArray(player_time, problem_view_ats_list); if(index >= 0){ ShowMessage(problem_json[index]["id"]); } } }, 1000); function ShowMessage(problem_id) { player.videoPause(); show_problem(problem_id) }; function show_problem(problem_id){ $.ajax({ url: "/api/v1/videos/problem/" + problem_id, type: "get", dataType:'json', success: function(result) { console.log('---------------'); console.log(result); var htmladd=""; var input_type = "checkbox" var problem_type = result["paper_problem"]["problem_type"] if(problem_type == "Single"){ input_type = "radio" } htmladd +='<div class="content">'; htmladd +='<div class="hide_box" style="display: none;"></div>'; htmladd +='<div class="shang_box" style="display: none;">'; htmladd +='<div class="shang_tit">'; htmladd +='<p>'+ result["paper_problem"]["title"] + '</p>'; htmladd +='</div>'; htmladd +='<div class="problem_order">'; htmladd +='<div class="problem_answer">'; htmladd += '<p><input type='+input_type+' name="problem_answer" value="A"/> A: '+ result["paper_problem"]["problem_a"] + '</p>'; htmladd += '<p><input type='+input_type+' name="problem_answer" value="B"/> B: '+ result["paper_problem"]["problem_b"] + '</p>'; htmladd += '<p><input type='+input_type+' name="problem_answer" value="C"/> C: '+ result["paper_problem"]["problem_c"] + '</p>'; htmladd += '<p><input type='+input_type+' name="problem_answer" value="D"/> D: '+ result["paper_problem"]["problem_d"] + '</p>'; htmladd +='</div>'; htmladd +='</div>'; htmladd +='<div class="order_info" style="display: none;"><p>错误:您选择的答案有误,请重新选择!</p></div>'; htmladd +='<div class="shang_payselect">'; htmladd +='<button class="btn-common">提交</button>'; htmladd +='</div></div></div>'; $("#problems").append(htmladd); $(".hide_box").fadeToggle(); $(".shang_box").fadeToggle(); $(".btn-common").click(function () { var obj = document.getElementsByName("problem_answer"); var check_val = []; for (var i = 0; i < obj.length; i++) { if (obj[i].checked) { check_val.push(obj[i].value); } } problem_answer_list = result["paper_problem"]["problem_answer"].split(","); if (isContained(check_val, problem_answer_list)){ $('.hide_box').css('display','block'); $('#problems').css('display','block'); player.playOrPause(); $(".content").load(location.href+" .div") }else { $('.order_info').css('display','block'); }; }); $("#problems").show(); }, error: function(e){ console.log(e.status); console.log(e.responseText); } }); } } function settimeFn3(player_time) { var showTime = 2; var time = showTime; $(document).on('click', function() { time = showTime; }); var interCount = setInterval(function() { time--; if(time == 0) { clearInterval(interCount); var index2 = $.inArray(player_time, problem_view_ats_list2); if(index2 >= 0){ ShowMessage3(); } } }, 1000); function ShowMessage3() { player.videoPause(); $('#heihei').css('display','block'); $('#problems2').css('display','block'); }; } function isContained (a, b){ if(!(a instanceof Array) || !(b instanceof Array)) return false; if(a.length != b.length) return false; for(var i = 0, len = b.length; i < len; i++){ if(a.indexOf(b[i]) == -1 && b.indexOf(a[i]) == -1) { return false; } } return true; } </script> </body> </html>