当前位置: 首页 > news >正文

政府门户网站建设的保障体系电商运营公司

政府门户网站建设的保障体系,电商运营公司,什么网站可以做公务员考试题,五金技术支持东莞网站建设项目中需要前端调用,所以做了如下操作 先看一下效果吧 主要是基于vue3,通过canvas把画面转成base64的形式,然后是把base64转成 file文件,最后调用了一下上传接口 以下是代码 进入页面先调用一下摄像头 navigator.mediaDevices.ge…

项目中需要前端调用,所以做了如下操作
先看一下效果吧
主要是基于vue3,通过canvas把画面转成base64的形式,然后是把base64转成
file文件,最后调用了一下上传接口

在这里插入图片描述
以下是代码

进入页面先调用一下摄像头

navigator.mediaDevices.getUserMedia({ video: true }).then((stream) => {video.value.srcObject = stream}).catch((error) => {console.error(error)})state.photoUrl = ''state.photo = true

拍照


const canvas = document.createElement('canvas')canvas.width = video.value.videoWidthcanvas.height = video.value.videoHeightcanvas.getContext('2d').drawImage(video.value, 0, 0, canvas.width, canvas.height)state.photoUrl = canvas.toDataURL('image/png')

转base64

  let arr = dataurl.split(',')let mime = arr[0].match(/:(.*?);/)[1]let suffix = mime.split('/')[1]let bstr = atob(arr[1])let n = bstr.lengthlet u8arr = new Uint8Array(n)while (n--) {u8arr[n] = bstr.charCodeAt(n)}return new File([u8arr], `${filename}.${suffix}`, {type: mime,})

完整代码

<template><div><div><div>摄像头实时画面</div><div class="hm"><video ref="video" v-if="state.photo" autoplay></video><img :src="state.photoUrl" v-else></div></div><div class="maT10"><el-button @click="takePhoto">拍照</el-button><el-button @click="retake">重拍</el-button></div></div>
</template><script setup lang="ts" name="photo">
import axios from 'axios'
const state = reactive({photo: true,photoUrl: '',
})
const video = ref()const takePhoto = () => {const canvas = document.createElement('canvas')canvas.width = video.value.videoWidthcanvas.height = video.value.videoHeightcanvas.getContext('2d').drawImage(video.value, 0, 0, canvas.width, canvas.height)state.photoUrl = canvas.toDataURL('image/png')clearVideo()state.photo = falselet file = base64ImgtoFile(state.photoUrl)let param = new FormData()param.append('file', file, file.name)param.append('fileReName', 'true')let config = {headers: {'Content-Type': 'multipart/form-data',Authorization: 'token',  //此处是token},}let url = import.meta.env.VITE_API_URL + '/api/admin/file/upload-file'axios.post(url, param, config).then((response) => {})
}
const base64ImgtoFile = (dataurl, filename = 'file') => {let arr = dataurl.split(',')let mime = arr[0].match(/:(.*?);/)[1]let suffix = mime.split('/')[1]let bstr = atob(arr[1])let n = bstr.lengthlet u8arr = new Uint8Array(n)while (n--) {u8arr[n] = bstr.charCodeAt(n)}return new File([u8arr], `${filename}.${suffix}`, {type: mime,})
}
const clearVideo = () => {const stream = video.value.srcObjectconst tracks = stream.getTracks()tracks.forEach((track) => {track.stop()})video.value.srcObject = null
}const retake = () => {navigator.mediaDevices.getUserMedia({ video: true }).then((stream) => {video.value.srcObject = stream}).catch((error) => {console.error(error)})state.photoUrl = ''state.photo = true
}onMounted(() => {retake()
})
//在离开当前页面的时候把摄像头关了,不然页面一直会显示摄像头的图标
onBeforeUnmount(() => {video.value.srcObject = null
})
</script><style scoped lang="scss">
.hm {width: 400px;height: 300px;video,img {width: 100%;}
}
</style>
http://www.15wanjia.com/news/30353.html

相关文章:

  • 外贸独立网站建设镇江网站建设
  • 深圳网站开发是什么网站seo优化运营
  • 医院网站建设步骤湖南省人民政府
  • 廊坊市固安县建设局网站厨师培训学校
  • 西安网站建设g全网营销软件
  • 广东做网站今日油价92汽油价格调整最新消息
  • 珠海网站关键词推广上海网站建设咨询
  • 合肥怎么做网站推广平台 赚佣金
  • 网站建设考虑哪些因素考试培训
  • 创建网站代码网站制作公司高端
  • 做纺织生意用什么网站好有友情链接的网站
  • 网站开发宣传单北京千锋教育培训机构怎么样
  • 网络营销的发展趋势和前景百度seo快速提升排名
  • 网站动图怎么做的关于进一步优化
  • 网站建设资料 优帮云seo关键词优化排名哪家好
  • 好网站开发win优化大师有免费版吗
  • 哪里做网站排名郑州seo培训
  • 范例网站怎么做公司怎么在百度上推广
  • 电商网站 服务器专业北京seo公司
  • 长沙装修公司排名榜seo咨询服务价格
  • 怎么知道公司网站是哪家做的互联网搜索引擎有哪些
  • 网站加背景音乐新闻类软文
  • 电子商务网站技术站长工具最近查询
  • 怎么样做网站视频百度搜索推广登录入口
  • 网站日志分析教程厦门人才网官网
  • 淘宝可做的团购网站爱站网是什么
  • 有什么网站可以做运动seo优化员
  • 做外贸哪些网站可以找客户网络媒体推广方案
  • 厦门正规网站建设企业推广公司好做吗
  • 百度网站推广费用网站优化公司开始上班了