279 lines
10 KiB
Plaintext
279 lines
10 KiB
Plaintext
|
<template>
|
||
|
<view class="page" :style="{height: height+'px'}" v-if="onlyFromCamera">
|
||
|
<barcode :style="{height: height+'px'}" id="hs-scan" class="barcode" ref="barcode" autostart
|
||
|
frameColor="#0cff00" scanbarColor="#0cff00" background="#000000" :filters="fil" @marked="success"
|
||
|
@error="error">
|
||
|
</barcode>
|
||
|
<view @click="back" class="back" hover-class="css-hover">
|
||
|
<image :src="scan_img.back" style="width: 28px;height: 28px;"></image>
|
||
|
</view>
|
||
|
<text class="msg">{{msg}}</text>
|
||
|
<view class="flash" :style="{bottom: (height/2 - 120)+'px'}" @click="toFlash()" hover-class="css-hover">
|
||
|
<image class="flash-img" :src="flash_img" style="width: 30px;height: 30px;"></image>
|
||
|
<text class="flash-text" :class="flash?'flash-on':''">{{flash?"轻触关闭":"轻触点亮"}}</text>
|
||
|
</view>
|
||
|
</view>
|
||
|
|
||
|
<view class="page" :style="{height: height+'px'}" v-else>
|
||
|
<barcode :style="{height: height+'px'}" id="hs-scan" class="barcode" ref="barcode" autostart
|
||
|
frameColor="#0cff00" scanbarColor="#0cff00" background="#000000" :filters="fil" @marked="success"
|
||
|
@error="error">
|
||
|
</barcode>
|
||
|
<view @click="back" class="back" hover-class="css-hover">
|
||
|
<image :src="scan_img.back" style="width: 28px;height: 28px;"></image>
|
||
|
</view>
|
||
|
<text class="msg">{{msg}}</text>
|
||
|
<view class="flash" :style="{bottom: (height/2 - 120)+'px'}" @click="toFlash()" hover-class="css-hover">
|
||
|
<image class="flash-img" :src="flash_img" style="width: 30px;height: 30px;"></image>
|
||
|
<text class="flash-text" :class="flash?'flash-on':''">{{flash?"轻触关闭":"轻触点亮"}}</text>
|
||
|
</view>
|
||
|
|
||
|
<view @click="toScan" class="album" hover-class="css-hover">
|
||
|
<image :src="scan_img.album" style="height: 26px;width: 26px;"></image>
|
||
|
</view>
|
||
|
|
||
|
</view>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
const _image = {
|
||
|
flash_off: '',
|
||
|
flash_on: '',
|
||
|
back: '',
|
||
|
album: '',
|
||
|
};
|
||
|
const SCAN_MAPS = {
|
||
|
[0]: "QR_CODE",
|
||
|
[1]: "EAN_13",
|
||
|
[2]: "EAN_8",
|
||
|
[3]: "AZTEC",
|
||
|
[4]: "DATA_MATRIX",
|
||
|
[5]: "UPC_A",
|
||
|
[6]: "UPC_E",
|
||
|
[7]: "CODABAR",
|
||
|
[8]: "CODE_39",
|
||
|
[9]: "CODE_93",
|
||
|
[10]: "CODE_128",
|
||
|
[11]: "CODE_25",
|
||
|
[13]: "PDF_417",
|
||
|
[14]: "RSS_14",
|
||
|
[15]: "RSSEXPANDED"
|
||
|
};
|
||
|
export default {
|
||
|
data: {
|
||
|
evalName: "hs-scancode", //扫码回调监听事件
|
||
|
flash: false, //手电筒
|
||
|
vibrate: true, //震动
|
||
|
sound: "none", //声音 none default
|
||
|
fil: [0, 1, 2], //条码类型
|
||
|
msg: "扫码", //提示文本
|
||
|
height: 600, //高度
|
||
|
isDark: null, //状态栏前景色 黑色
|
||
|
fullScreen: false, //是否全屏
|
||
|
onlyFromCamera: false, //从相册获取
|
||
|
},
|
||
|
computed: {
|
||
|
scan_img() {
|
||
|
return _image
|
||
|
},
|
||
|
flash_img() {
|
||
|
return this.flash ? _image.flash_on : _image.flash_off;
|
||
|
},
|
||
|
},
|
||
|
onLoad(p) {
|
||
|
//参数
|
||
|
if (p.evalName) this.evalName = p.evalName;
|
||
|
if (p.flash) this.flash = p.flash == 'true';
|
||
|
if (p.vibrate) this.vibrate = p.vibrate == 'true';
|
||
|
if (p.sound) this.sound = p.sound;
|
||
|
if (p.msg) this.msg = p.msg;
|
||
|
if (p.fil) this.fil = p.fil.split(',').map(x => parseInt(x));
|
||
|
if (p.fullScreen) this.fullScreen = p.fullScreen == 'true';
|
||
|
if (p.onlyFromCamera) this.onlyFromCamera = p.onlyFromCamera == 'true';
|
||
|
this.setFullOrStatus(true);
|
||
|
uni.getSystemInfo({
|
||
|
success: res => this.height = res.windowHeight
|
||
|
});
|
||
|
setTimeout(() => {
|
||
|
this.toStart();
|
||
|
this.webviewInit();
|
||
|
|
||
|
}, 100);
|
||
|
},
|
||
|
onUnload() {
|
||
|
this.setFullOrStatus(false);
|
||
|
this.toFlash(false);
|
||
|
uni.$off(this.evalName);
|
||
|
},
|
||
|
onBackPress(e) {
|
||
|
if (e.from === 'backbutton') this.back(0);
|
||
|
else this.setFullOrStatus(false);
|
||
|
},
|
||
|
methods: {
|
||
|
webviewInit() {
|
||
|
var pages = getCurrentPages();
|
||
|
var currentWebview = pages[pages.length - 1].$getAppWebview();
|
||
|
//ios 左滑关闭
|
||
|
currentWebview.addEventListener('popGesture', e => {
|
||
|
const type = e.type,
|
||
|
result = e.result;
|
||
|
if (type === 'start') {
|
||
|
this.setFullOrStatus(false);
|
||
|
this.toFlash(false);
|
||
|
this.toCancel();
|
||
|
} else if (type === 'end' && result) {
|
||
|
this.back(0)
|
||
|
} else if (type === 'end' && !result) {
|
||
|
this.setFullOrStatus(true);
|
||
|
this.toStart();
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
success(e) {
|
||
|
uni.$emit(this.evalName, [null, {
|
||
|
"hsScanCode": true,
|
||
|
"result": e.detail.message,
|
||
|
"scanType": SCAN_MAPS[e.detail.code],
|
||
|
"charSet": "utf8",
|
||
|
"path": e.detail.file || "",
|
||
|
"errMsg": "scanCode:ok"
|
||
|
}]);
|
||
|
},
|
||
|
error(e, cancel) {
|
||
|
uni.$emit(this.evalName, [{
|
||
|
"hsScanCode": true,
|
||
|
"errMsg": cancel === true ? "scanCode:fail cancel" : "scanCode:fail"
|
||
|
}, null]);
|
||
|
if (!cancel) this.toStart();
|
||
|
},
|
||
|
toStart: function() {
|
||
|
this.$refs.barcode && this.$refs.barcode.start({
|
||
|
conserve: false,
|
||
|
vibrate: this.vibrate,
|
||
|
sound: this.sound,
|
||
|
});
|
||
|
},
|
||
|
toCancel: function() {
|
||
|
this.$refs.barcode.cancel();
|
||
|
},
|
||
|
toFlash: function(t) {
|
||
|
this.flash = t == null ? !this.flash : t;
|
||
|
this.$refs.barcode.setFlash(this.flash);
|
||
|
},
|
||
|
toScan: async function() {
|
||
|
this.toCancel();
|
||
|
const [e, res] = await uni.chooseImage({
|
||
|
count: 1,
|
||
|
sizeType: ['original'],
|
||
|
sourceType: ['album']
|
||
|
});
|
||
|
if (res && res.tempFilePaths.length > 0) {
|
||
|
const barcodeModule = uni.requireNativePlugin('barcodeScan');
|
||
|
barcodeModule.scan(res.tempFilePaths[0], e => {
|
||
|
if (e.detail.type === "success") {
|
||
|
this.success(e);
|
||
|
} else {
|
||
|
this.error(e);
|
||
|
}
|
||
|
this.toStart();
|
||
|
});
|
||
|
} else {
|
||
|
this.toStart();
|
||
|
}
|
||
|
},
|
||
|
back(t) {
|
||
|
const p = {
|
||
|
delta: 1
|
||
|
}
|
||
|
this.setFullOrStatus(false);
|
||
|
this.toCancel();
|
||
|
this.toFlash(false);
|
||
|
if (t !== 0) uni.navigateBack(p);
|
||
|
},
|
||
|
setFullOrStatus(t) {
|
||
|
if (this.isDark == null) this.isDark = this.getStatusBarStyle() !== 'light';
|
||
|
this.isDark && plus.navigator.setStatusBarStyle(t ? "light" : "dark");
|
||
|
this.fullScreen && plus.navigator.setFullscreen(t)
|
||
|
},
|
||
|
getStatusBarStyle() {
|
||
|
let style = plus.navigator.getStatusBarStyle()
|
||
|
if (style === 'UIStatusBarStyleBlackTranslucent' || style === 'UIStatusBarStyleBlackOpaque' || style ===
|
||
|
'null') {
|
||
|
style = 'light'
|
||
|
} else if (style === 'UIStatusBarStyleDefault') {
|
||
|
style = 'dark'
|
||
|
}
|
||
|
return style
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
<style scoped>
|
||
|
.page {
|
||
|
top: 0;
|
||
|
position: fixed;
|
||
|
width: 750rpx;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
background-color: #000000;
|
||
|
}
|
||
|
|
||
|
.back {
|
||
|
position: fixed;
|
||
|
left: 5px;
|
||
|
top: 20px;
|
||
|
border-radius: 50;
|
||
|
padding: 15px;
|
||
|
}
|
||
|
|
||
|
.msg {
|
||
|
position: fixed;
|
||
|
top: 90px;
|
||
|
width: 750rpx;
|
||
|
text-align: center;
|
||
|
color: #FFFFFF;
|
||
|
font-size: 16px;
|
||
|
}
|
||
|
|
||
|
.css-hover {
|
||
|
opacity: .4;
|
||
|
}
|
||
|
|
||
|
.barcode {
|
||
|
width: 750rpx;
|
||
|
height: 100%;
|
||
|
background-color: #000000;
|
||
|
}
|
||
|
|
||
|
.flash {
|
||
|
position: absolute;
|
||
|
bottom: 500rpx;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
padding: 8px;
|
||
|
}
|
||
|
|
||
|
.flash-text {
|
||
|
margin-top: 3px;
|
||
|
color: #bfbfbf;
|
||
|
font-size: 12px;
|
||
|
}
|
||
|
|
||
|
.flash-on {
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.album {
|
||
|
position: fixed;
|
||
|
bottom: 60px;
|
||
|
right: 30px;
|
||
|
height: 42px;
|
||
|
width: 42px;
|
||
|
padding: 16px;
|
||
|
background-color: rgba(157, 157, 157, .3);
|
||
|
border-radius: 50;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
}
|
||
|
</style>
|