VUE项目移动端H5调用摄像头扫码

<template>
    <div>
        <div @click="moveToCameraAVG()" v-cloak>
            <div class="warm_title2">点击扫码</div>
        </div>
    </div>
</template>

<script type="text/ecmascript-6">
export default {
    data () {
        return {
        }
    },
    methods: {
        // 头像相机
        moveToCameraAVG() {
            var self = this
            if (navigator.mediaDevices === undefined) {
                navigator.mediaDevices = {}
            }
            if (navigator.mediaDevices.getUserMedia === undefined) {
                navigator.mediaDevices.getUserMedia = function (constraints) {
                    var getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia || navigator.oGetUserMedia
                    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)
                    })
                }
            }
            var constraints = window.constraints = {
                audio: false,
                video: {
                    sourceId: 'default',
                    facingMode: { exact: 'user' }
                }
            }
            navigator.mediaDevices.getUserMedia(constraints)
                .then(function (stream) {
                    var video = document.getElementById('video')
                    try {
                        window.stream = stream
                        video.srcObject = stream
                    } catch (error) {
                        video.src = window.URL.createObjectURL(stream)
                    }
                    self.localMediaStream = stream
                    video.play()
                })
                .catch(function (err) {
                    alert(err.name + ': ' + err.message)
                })
        },
    },

}
</script>

<style lang="scss"></style>

此代码须打包后在Hbuilder上
只有真机运行才能起作用

以上是我个人书写代码,仅供参考,欢迎指正

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值