You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
320 lines
8.9 KiB
320 lines
8.9 KiB
|
4 days ago
|
<template>
|
||
|
|
<view class="">
|
||
|
|
<view class="btn">
|
||
|
|
<button type="primary" :loading="isSearching" v-if="isSearching == false" @tap="startSearch(true)"
|
||
|
|
text="">搜索蓝牙设备
|
||
|
|
</button>
|
||
|
|
<button type="primary" :loading="isSearching" v-if="isSearching == true" @tap="stopSearch" text="">搜索蓝牙设备
|
||
|
|
</button>
|
||
|
|
<button type="primary" style="margin-top: 40rpx;" v-if="okAddress !=''" @tap="endSearch(true)"
|
||
|
|
text="">删除已连接蓝牙设备
|
||
|
|
</button>
|
||
|
|
<button type="primary" style="margin-top: 40rpx;font-size: 32rpx;" :loading="isPrint" v-if="okAddress"
|
||
|
|
@tap="pickUpOnce" text=''>打印测试</button>
|
||
|
|
</view>
|
||
|
|
|
||
|
|
<view class="content">
|
||
|
|
<text>新设备</text>
|
||
|
|
<view v-for="(item) in list" :data-title="item.deviceId" :data-name="item.name"
|
||
|
|
:data-advertisData="item.advertisServiceUUIDs" :key="item.deviceId"
|
||
|
|
@tap="bindViewTap(item.deviceId,true)">
|
||
|
|
<view>
|
||
|
|
<text>{{item.name}}</text>
|
||
|
|
<view v-if="linkAddress == item.deviceId" style="background-color: #4caf50;">正在匹配</view>
|
||
|
|
<view v-if="okAddress == item.deviceId">匹配成功</view>
|
||
|
|
</view>
|
||
|
|
</view>
|
||
|
|
</view>
|
||
|
|
</view>
|
||
|
|
</template>
|
||
|
|
|
||
|
|
<script>
|
||
|
|
import PrinterJobs from '@/components/print/printerjobs.js'
|
||
|
|
import printerUtil from '@/components/print/printerutil.js'
|
||
|
|
import util from '@/components/print/util.js'
|
||
|
|
import drawQrcode from '@/components/print/weapp.qrcode.esm.js'
|
||
|
|
import Bluetooth from '@/components/print/bluetooth.js'
|
||
|
|
let bluetooth = new Bluetooth();
|
||
|
|
export default {
|
||
|
|
components: {},
|
||
|
|
data() {
|
||
|
|
return {
|
||
|
|
isSearching: false,
|
||
|
|
list: [],
|
||
|
|
okAddress: '',
|
||
|
|
linkAddress: '',
|
||
|
|
data: {
|
||
|
|
"settled_name": "#0112配送",
|
||
|
|
"detail": {
|
||
|
|
"total_amount": "137.00",
|
||
|
|
"other_amount": "0.00",
|
||
|
|
"discount_amount": "0.00",
|
||
|
|
"actual_amount": "137.00",
|
||
|
|
"order_sn": "20220512165337",
|
||
|
|
"goods_count": 3,
|
||
|
|
"order_time": "2022-05-12 16:53:00",
|
||
|
|
"supplier_id": 1
|
||
|
|
},
|
||
|
|
"code": "https://www.oulaisong.com/purchase?id=8",
|
||
|
|
"list": [{
|
||
|
|
"id": 8,
|
||
|
|
"goods_name": "红烧带鱼",
|
||
|
|
"article_number": "1",
|
||
|
|
'sum_price':'16.00'
|
||
|
|
}, {
|
||
|
|
"id": 9,
|
||
|
|
"goods_name": "女童外套",
|
||
|
|
"article_number": "2",
|
||
|
|
|
||
|
|
"sum_price": "34.00"
|
||
|
|
}, {
|
||
|
|
"id": 10,
|
||
|
|
"goods_name": "25",
|
||
|
|
"article_number": "3",
|
||
|
|
"sum_price": "3.00"
|
||
|
|
}]
|
||
|
|
},
|
||
|
|
isPrint: false,
|
||
|
|
}
|
||
|
|
},
|
||
|
|
//页面卸载是关闭蓝牙链接
|
||
|
|
// onUnload() {
|
||
|
|
// uni.hideLoading()
|
||
|
|
// bluetooth.closeBLEConnection();
|
||
|
|
// bluetooth.closeBluetoothAdapter();
|
||
|
|
// },
|
||
|
|
//页面打开,获取位置,打开蓝牙链接
|
||
|
|
onLoad() {
|
||
|
|
uni.getLocation({
|
||
|
|
type: 'wgs84',
|
||
|
|
success: function(res) {
|
||
|
|
console.log('当前位置的经度:' + res.longitude);
|
||
|
|
console.log('当前位置的纬度:' + res.latitude);
|
||
|
|
}
|
||
|
|
});
|
||
|
|
// this.getData()
|
||
|
|
|
||
|
|
},
|
||
|
|
onShow() {
|
||
|
|
console.log('---')
|
||
|
|
},
|
||
|
|
methods: {
|
||
|
|
endSearch(){
|
||
|
|
uni.hideLoading()
|
||
|
|
bluetooth.closeBLEConnection();
|
||
|
|
bluetooth.closeBluetoothAdapter();
|
||
|
|
this.okAddress = ''
|
||
|
|
},
|
||
|
|
getData() {
|
||
|
|
var that = this;
|
||
|
|
that.startSearch(false);
|
||
|
|
},
|
||
|
|
async bindViewTap(deviceId, state) {
|
||
|
|
var _this = this;
|
||
|
|
_this.okAddress = '';
|
||
|
|
_this.linkAddress = deviceId;
|
||
|
|
console.log(deviceId)
|
||
|
|
if (state == true) {
|
||
|
|
_this.isSearching = false
|
||
|
|
}
|
||
|
|
try {
|
||
|
|
//1.链接设备
|
||
|
|
await bluetooth.createBLEConnection(deviceId).then((res) => {
|
||
|
|
bluetooth.deviceId = deviceId;
|
||
|
|
}).catch((e) => {
|
||
|
|
throw e;
|
||
|
|
});
|
||
|
|
|
||
|
|
let server = [];
|
||
|
|
//2.寻找服务
|
||
|
|
await bluetooth.getBLEDeviceServices().then((res) => {
|
||
|
|
console.log(res)
|
||
|
|
bluetooth.notifyId = '';
|
||
|
|
bluetooth.writeId = '';
|
||
|
|
bluetooth.num = 0;
|
||
|
|
bluetooth.serviceList = res
|
||
|
|
}).catch((e) => {
|
||
|
|
throw e;
|
||
|
|
});
|
||
|
|
|
||
|
|
//3.获取蓝牙设备所有服务
|
||
|
|
let result3 = await bluetooth.getBLEDeviceCharacteristics().then(res => {
|
||
|
|
_this.okAddress = deviceId;
|
||
|
|
_this.linkAddress = '';
|
||
|
|
uni.setStorageSync('bluetoothDeviceId', deviceId);
|
||
|
|
}).catch((e) => {
|
||
|
|
throw e;
|
||
|
|
});
|
||
|
|
} catch (e) {
|
||
|
|
_this.okAddress = '';
|
||
|
|
_this.linkAddress = '';
|
||
|
|
//TODO handle the exception
|
||
|
|
console.log("e: " + JSON.stringify(e));
|
||
|
|
}
|
||
|
|
},
|
||
|
|
//打印一次
|
||
|
|
pickUpOnce() {
|
||
|
|
this.isPrint = true;
|
||
|
|
bluetooth.notifyBLECharacteristicValue();
|
||
|
|
let self = this;
|
||
|
|
setTimeout(() => {
|
||
|
|
self.writeBLECharacteristicValue();
|
||
|
|
}, 500);
|
||
|
|
},
|
||
|
|
//写入控制命令
|
||
|
|
async writeBLECharacteristicValue() {
|
||
|
|
let data = this.data;
|
||
|
|
let printerJobs = new PrinterJobs();
|
||
|
|
printerJobs.setAlign('ct').setSize(2, 2).setLineSpacing(80).print('#0112配送')
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('预计时间:2026-02-01 13:41:00')
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('七里香快餐明珠店')
|
||
|
|
.print(printerUtil.fillLine('-', 1, 50))
|
||
|
|
.setAlign('lt').setSize(2, 2).setLineSpacing(80).print('王先生')
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('联系电话: *******0775')
|
||
|
|
.setAlign('lt').setSize(2, 2).setLineSpacing(80).print('地址:黑背生东川建设集团有限公司黑恶生运河区****')
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('为保护隐私,顾客电话及地址已被隐藏,您可登录商家端或骑手端查看')
|
||
|
|
.print(printerUtil.fillLine('-', 1, 50));
|
||
|
|
|
||
|
|
|
||
|
|
for (var i = 0; i < data.list.length; i++) {
|
||
|
|
printerJobs.setAlign('lt').setSize(1, 1).setLineSpacing(40).print(data.list[i].goods_name)
|
||
|
|
|
||
|
|
|
||
|
|
let setLineSpacing = 40
|
||
|
|
|
||
|
|
printerJobs.setLineSpacing(setLineSpacing).print(printerUtil.inlineArr([{
|
||
|
|
'text': 'X' + data.list[i].article_number,
|
||
|
|
'width': 20,
|
||
|
|
}, {
|
||
|
|
'text': data.list[i].sum_price,
|
||
|
|
'width': 10,
|
||
|
|
}], 1, 50));
|
||
|
|
}
|
||
|
|
printerJobs.print(printerUtil.fillLine('-', 1, 50))
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('配送费:1圆')
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('合计金额:17圆')
|
||
|
|
.print(printerUtil.fillLine('-', 1, 50))
|
||
|
|
.setAlign('lt').setSize(1, 1).setLineSpacing(40).print('商品取到后,如有任何商品问题,请及时联系商家和平台,客服将为您服务,客服电话15533910775,谢谢您的惠顾')
|
||
|
|
.println();
|
||
|
|
let buffer = printerJobs.buffer();
|
||
|
|
this.sendPrint(buffer);
|
||
|
|
},
|
||
|
|
sendPrint(buffer) {
|
||
|
|
// 1.并行调用多次会存在写失败的可能性
|
||
|
|
// 2.建议每次写入不超过20字节
|
||
|
|
// 分包处理,延时调用
|
||
|
|
let that = this
|
||
|
|
const maxChunk = 20;
|
||
|
|
const delay = 20;
|
||
|
|
that.isPrint = true;
|
||
|
|
for (let i = 0, j = 0, length = buffer.byteLength; i < length; i += maxChunk, j++) {
|
||
|
|
let subPackage = buffer.slice(i, i + maxChunk <= length ? (i + maxChunk) : length);
|
||
|
|
setTimeout(this.sendPrintData, j * delay, subPackage);
|
||
|
|
}
|
||
|
|
that.isPrint = false;
|
||
|
|
},
|
||
|
|
sendPrintData(buffer) {
|
||
|
|
bluetooth.writeBLECharacteristicValue(buffer).then(res => {});
|
||
|
|
},
|
||
|
|
startSearch(state) {
|
||
|
|
let that = this
|
||
|
|
bluetooth.openBluetoothAdapter().then(e => {
|
||
|
|
that.isSearching = true;
|
||
|
|
uni.startBluetoothDevicesDiscovery({
|
||
|
|
success: res => {
|
||
|
|
uni.onBluetoothDeviceFound(result => {
|
||
|
|
let arr = that.list;
|
||
|
|
let devices = [];
|
||
|
|
let list = result.devices;
|
||
|
|
for (let i = 0; i < list.length; ++i) {
|
||
|
|
console.log(list[i])
|
||
|
|
if (list[i].name && list[i].name != "未知设备") {
|
||
|
|
let arrNew = arr.filter((item) => {
|
||
|
|
return item.deviceId == list[i].deviceId;
|
||
|
|
});
|
||
|
|
if (arrNew.length == 0) {
|
||
|
|
devices.push(list[i]);
|
||
|
|
}
|
||
|
|
if (uni.getStorageSync('bluetoothDeviceId') == list[i]
|
||
|
|
.deviceId) {
|
||
|
|
// that.bindViewTap(list[i].deviceId, state)
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
that.list = arr.concat(devices);
|
||
|
|
});
|
||
|
|
},
|
||
|
|
fail: res => {
|
||
|
|
uni.hideLoading();
|
||
|
|
uni.showToast({
|
||
|
|
title: `搜索设备失败` + JSON.stringify(err)
|
||
|
|
})
|
||
|
|
}
|
||
|
|
})
|
||
|
|
}).catch(e => {
|
||
|
|
console.log(e)
|
||
|
|
});
|
||
|
|
},
|
||
|
|
// 停止搜索
|
||
|
|
stopSearch() {
|
||
|
|
this.isSearching = false;
|
||
|
|
uni.hideLoading();
|
||
|
|
bluetooth.stopBluetoothDevicesDiscovery();
|
||
|
|
},
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<style>
|
||
|
|
page {
|
||
|
|
background: #F7F8FA;
|
||
|
|
}
|
||
|
|
</style>
|
||
|
|
<style scoped lang="scss">
|
||
|
|
.btn {
|
||
|
|
padding: 40rpx;
|
||
|
|
}
|
||
|
|
|
||
|
|
.content {
|
||
|
|
padding: 40rpx;
|
||
|
|
|
||
|
|
&>text {
|
||
|
|
display: block;
|
||
|
|
padding-bottom: 30rpx;
|
||
|
|
font-size: 28rpx;
|
||
|
|
color: #333
|
||
|
|
}
|
||
|
|
|
||
|
|
&>view {
|
||
|
|
background-color: #fff;
|
||
|
|
padding: 30rpx 40rpx;
|
||
|
|
margin-bottom: 24rpx;
|
||
|
|
|
||
|
|
&>view {
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
justify-content: space-between;
|
||
|
|
|
||
|
|
&>text {
|
||
|
|
margin-left: 24rpx;
|
||
|
|
font-size: 32rpx;
|
||
|
|
font-weight: 500;
|
||
|
|
color: #333333;
|
||
|
|
}
|
||
|
|
|
||
|
|
&>view {
|
||
|
|
border-radius: 10rpx;
|
||
|
|
font-size: 24rpx;
|
||
|
|
color: #fff;
|
||
|
|
background-color: #3769FF;
|
||
|
|
padding: 5rpx 10rpx;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
&>view:last-child {
|
||
|
|
margin-bottom: 0;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</style>
|