8 changed files with 216 additions and 66 deletions
-
73public/h5.html
-
100src/components/patientRegister/Camera.vue
-
53src/components/patientRegister/PatientRegisterEdit.vue
-
15src/components/patientRegister/PatientRegisterList.vue
-
5src/router/index.js
-
2src/store/index.js
-
11src/utlis/proFunc.js
-
3src/views/Home.vue
@ -0,0 +1,73 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html lang="en"> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge"> |
||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
||||
|
<title>Document</title> |
||||
|
</head> |
||||
|
<body> |
||||
|
<!--显示头像--> |
||||
|
<div class="show-picture" id="picture_div" > |
||||
|
<video id="video" class="picture-video" width="360" height="360" autoplay></video> |
||||
|
<canvas id="canvas" class="picture-canvas" width="360" height="360"></canvas> |
||||
|
<img id="headSculpture"> |
||||
|
<button type="button" class="layui-btn layui-btn-normal snap" id="snap">拍照</button> |
||||
|
</div> |
||||
|
<script language="JavaScript"> |
||||
|
//开启摄像头 |
||||
|
var MediaStreamTrack; |
||||
|
var isPhotograph=true; |
||||
|
function getMedia() { |
||||
|
let constraints = { |
||||
|
video: {width: 360, height: 360}, |
||||
|
audio: false, |
||||
|
}; |
||||
|
//获得video摄像头区域 |
||||
|
let video = document.getElementById("video"); |
||||
|
//这里介绍新的方法,返回一个 Promise对象 |
||||
|
// 这个Promise对象返回成功后的回调函数带一个 MediaStream 对象作为其参数 |
||||
|
// then()是Promise对象里的方法 |
||||
|
// then()方法是异步执行,当then()前的方法执行完后再执行then()内部的程序 |
||||
|
// 避免数据没有获取到 |
||||
|
let promise = navigator.mediaDevices.getUserMedia(constraints); |
||||
|
promise.then(function (MediaStream) { |
||||
|
MediaStreamTrack=typeof MediaStream.stop==='function'?MediaStream:MediaStream.getTracks()[1]; |
||||
|
video.srcObject = MediaStream; |
||||
|
video.play(); |
||||
|
isPhotograph = false |
||||
|
}); |
||||
|
} |
||||
|
//拍照 |
||||
|
function takePhoto() { |
||||
|
if(isPhotograph){ |
||||
|
getMedia(); |
||||
|
clearCanvas(); |
||||
|
isPhotograph=false; |
||||
|
}else{ |
||||
|
//获得Canvas对象 |
||||
|
let video = document.getElementById("video"); |
||||
|
let canvas = document.getElementById("canvas"); |
||||
|
let ctx = canvas.getContext('2d'); |
||||
|
ctx.drawImage(video, 0, 0,360, 360); |
||||
|
MediaStreamTrack && MediaStreamTrack.stop(); |
||||
|
imgData = document.getElementById("canvas").toDataURL("image/jpeg"); |
||||
|
isPhotograph=true; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
document.getElementById("snap").addEventListener("click", takePhoto); |
||||
|
/** |
||||
|
* @description 重置canvas(清除照片) |
||||
|
* @version 1.0 |
||||
|
* @returns |
||||
|
*/ |
||||
|
function clearCanvas() { |
||||
|
var c = document.getElementById("canvas"); |
||||
|
var cxt = c.getContext("2d"); |
||||
|
c.height = c.height; |
||||
|
} |
||||
|
|
||||
|
</script> |
||||
|
</body> |
||||
|
</html> |
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue