vue實現(xiàn)pc端拍照上傳功能
更新時間:2021年09月29日 16:29:10 作者:qq_39070698
這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)pc端拍照上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了vue實現(xiàn)pc端拍照上傳功能的具體代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF8">
</head>
<body>
<div id="contentHolder">
<video id="video" width="320" height="320" autoplay></video>
<button id="camera">拍照</button>
<canvas id="canvas" width="320" height="320">
</canvas>
</div>
<script type="text/javascript">
var video = document.getElementById('video');
var track;
var Camera= document.getElementById('camera');
window.addEventListener("DOMContentLoaded", function(){
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
if (navigator.getUserMedia) {
navigator.getUserMedia({video:true},
function(stream) {
track = stream.getTracks()[0]; // 通過這個關(guān)閉攝像頭
video.src = window.URL.createObjectURL(stream);
video.onloadedmetadata = function(e) {
video.play();
};
},
function(err) {
alert(err.name);
}
);
}
});
Camera.onclick = function(){
var canvas = document.getElementById('canvas');
var context2D = canvas.getContext("2d");
context2D.fillStyle = "#ffffff";
context2D.fillRect(0, 0, 320, 320);
context2D.drawImage(video, 0, 0, 320, 320);
var image_code =canvas.toDataURL("image/png");//要傳給后臺的base64
console.log(image_code)
if (null != track) {
track.stop();//關(guān)閉攝像頭
}
};
</script>
</body>
</html>
上段代碼會在打開網(wǎng)頁的時候就會調(diào)用攝像頭
傳給后臺的是個base64碼
下面是我用vue傳給后臺的代碼
var param = {
file:image_code2
}
var a = JSON.stringify(param);
uploadimg(a).then((res) => {
console.log(res);
});
下面是我的php后臺接收代碼
public function uploadImg($name="img",$path='img'){
$_POST = json_decode(file_get_contents('php://input'),true);
$param = $_POST;
$image_code = $param['file'];
$img = str_replace('data:image/png;base64,', '', $image_code);//獲取base64碼
$img = str_replace(' ', '+', $img);
$data = base64_decode($img);
$name = time().".png";
$savepath = "./upload/".$name;//將圖片存到的位置
file_put_contents($savepath,$data);//將內(nèi)容寫入文件
$this->ajaxReturn(array('status'=>'0','data'=>$savepath));
}
如果想點擊觸發(fā) 打開攝像頭可以將camera中代碼取出放在一個方法中即可
var Camera= document.getElementById('camera');
window.addEventListener("DOMContentLoaded", function(){
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
});
function demo(){
if (navigator.getUserMedia) {
navigator.getUserMedia({video:true},
function(stream) {
track = stream.getTracks()[0]; // 通過這個關(guān)閉攝像頭
video.src = window.URL.createObjectURL(stream);
video.onloadedmetadata = function(e) {
video.play();
};
},
function(err) {
alert(err.name);
}
);
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue this.$router.push(參數(shù))實現(xiàn)頁面跳轉(zhuǎn)操作
這篇文章主要介紹了Vue this.$router.push(參數(shù))實現(xiàn)頁面跳轉(zhuǎn)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
vue3中ts語法使用element plus分頁組件警告錯誤問題
這篇文章主要介紹了vue3中ts語法使用element plus分頁組件警告錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
vue3?elementPlus?table實現(xiàn)列寬可拖拽功能
這篇文章主要介紹了vue3?elementPlus?table實現(xiàn)列寬可拖拽功能,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08

