From 03afa45e6fcab6329025e3492d2665d6632e9be8 Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期一, 01 九月 2025 14:48:21 +0800
Subject: [PATCH] 多次并板

---
 pages/print/print.vue |  542 +++++++++++++++---------------------------------------
 1 files changed, 150 insertions(+), 392 deletions(-)

diff --git a/pages/print/print.vue b/pages/print/print.vue
index c61ef22..7eace59 100644
--- a/pages/print/print.vue
+++ b/pages/print/print.vue
@@ -1,416 +1,174 @@
 <template>
-	<!-- 钃濈墮鎵撳嵃椤甸潰 -->
-	<view class="page">
-		<button @click="openBluetoothAdapter">閲嶆柊鏌ヨ</button>
-		<view class="title">
-			鍙繛鎺ョ殑钃濈墮璁惧鍒楄〃锛�
-			<text style="color: red;font-size:22rpx;">(閮ㄥ垎鏈哄瀷闇�瑕佹墦寮�GPS瀹氫綅鏈嶅姟)</text>
-		</view>
-		<view class="list">
-			<view class="item" v-for="(item, i) in devices" :key="i">
-				<!-- 璁惧鍚嶇О -->
-				<text>{{ item.name }}</text>
-				<!-- 杩炴帴鐘舵�� -->
-				<view class="right">
-					<view class="font-color-3" @click="createBLEConnection(item)" v-show="!item.isShowConnect">杩炴帴璁惧</view>
-					<view class="font-color-3" v-show="item.isShowConnect">宸茶繛鎺�</view>
-				</view>
+	<view>
+		<view class="print-model" :style="style">
+			<view class="display" :style="">
+				<table>
+					<tr>
+						<td>鏂欏彿</td>
+						<td>{{mat.matnr}}</td>
+						<td colspan="1" rowspan="2" style="width: 150px;">
+							<!-- 浜岀淮鐮� -->
+							<view class="qr-box">
+								<canvas canvas-id="qrcode" v-show="qrShow" style="width: 300rpx;margin: 0 auto;" />
+							</view>
+						</td>
+					</tr>
+					<tr>
+						<td>鍟嗗搧</td>
+						<td colspan="1">{{mat.maktx}}</td>
+					</tr>
+					<tr>
+						<td>鏃ユ湡</td>
+						<td colspan="2">{{time}}</td>
+					</tr>
+				</table>
 			</view>
-			<!-- v-if="devices.length" -->
-			<button @click="writeBLECharacteristicValue">寮�濮嬫墦鍗�</button>
-			<!-- <button :class="isDisabled || isConnected ? 'submit disabled' : 'submit'" @click="writeBLECharacteristicValue" :disabled="isDisabled || isConnected">寮�濮嬫墦鍗�</button> -->
-			<view class="no-devices" v-if="!devices.length">鏈悳绱㈠埌钃濈墮璁惧</view>
+		</view>
+		<view>
+			<button @click="toPrint">鎵撳嵃</button>
 		</view>
 	</view>
 </template>
 
 <script>
-const LAST_CONNECTED_DEVICE = 'last_connected_device';
-import PrinterJobs from '../../static/js/printerjobs';
-import printerUtil from '../../static/js/printerutil';
-
-function inArray(arr, key, val) {
-	for (let i = 0; i < arr.length; i++) {
-		if (arr[i][key] === val) {
-			return i;
-		}
-	}
-	return -1;
-}
-
-// ArrayBuffer杞�16杩涘害瀛楃涓茬ず渚�
-function ab2hex(buffer) {
-	const hexArr = Array.prototype.map.call(new Uint8Array(buffer), function(bit) {
-		return ('00' + bit.toString(16)).slice(-2);
-	});
-	return hexArr.join(',');
-}
-
-function str2ab(str) {
-	// Convert str to ArrayBuff and write to printer
-	let buffer = new ArrayBuffer(str.length);
-	let dataView = new DataView(buffer);
-	for (let i = 0; i < str.length; i++) {
-		dataView.setUint8(i, str.charAt(i).charCodeAt(0));
-	}
-	return buffer;
-}
-
-export default {
-	name: 'print',
-	components: {},
-	props: {},
-	data() {
-		return {
-			devices: [],
-			connected: false,
-			isConnected: true,
-			name: '',
-			deviceId: null
-		};
-	},
-	onLoad() {},
-	onShow() {},
-	created() {},
-	mounted() {
-		this.openBluetoothAdapter();
-	},
-	methods: {
-		// 鍒濆鍖栬摑鐗�
-		openBluetoothAdapter() {
-			console.log('鍒濆鍖栬摑鐗欐ā鍧� openBluetoothAdapter');
-			if (!uni.openBluetoothAdapter) {
-				console.log('寰俊鐗堟湰杩囦綆');
-				uni.showModal({
-					title: '鎻愮ず',
-					content: '褰撳墠寰俊鐗堟湰杩囦綆锛屾棤娉曚娇鐢ㄨ鍔熻兘锛岃鍗囩骇鍒版渶鏂板井淇$増鏈悗閲嶈瘯銆�'
-				});
-				return;
+	import uQRCode from '@/static/js/uqrcode.js' //寮曞叆uqrcode.js
+	export default {
+		data() {
+			return {
+				style: {
+					height: '3px'
+				},
+				mat: {
+					matnr: '1200128-10055',
+					maktx: 'X5S-4-M03/333'
+				},
+				qrShow: false,
+				time: ''
 			}
-			uni.showLoading({
-				title: '寮�濮嬫悳绱㈣摑鐗欒澶�'
-			});
-			// uni.hideLoading();
-			uni.openBluetoothAdapter({
-				success: res => {
-					console.log('鍒濆鍖栨垚鍔無penBluetoothAdapter success', res);
-					uni.hideLoading();
-					// 鎼滃闄勮繎鐨勮摑鐗�
-					this.startBluetoothDevicesDiscovery();
-				},
-				fail: res => {
-					console.log('鍒濆鍖栧け璐penBluetoothAdapter fail', res);
-					// uni.showModal({
-					// 	content: res.errMsg,
-					// 	showCancel: false
-					// });
-					uni.hideLoading();
-					if (res.errCode === 10001) {
-						// 褰撳墠钃濈墮閫傞厤鍣ㄤ笉鍙敤
-						uni.showModal({
-							title: '閿欒',
-							content: '鏈壘鍒拌摑鐗欒澶�, 璇锋墦寮�钃濈墮鍚庨噸璇曘��',
-							showCancel: false
-						});
-						// 鐩戝惉钃濈墮閫傞厤鍣ㄧ姸鎬佸彉鍖栦簨浠�
-						uni.onBluetoothAdapterStateChange(res => {
-							console.log('鐩戝惉钃濈墮閫傞厤鍣ㄧ姸鎬� onBluetoothAdapterStateChange', res);
-							// available锛氳摑鐗欓�傞厤鍣ㄦ槸鍚﹀彲鐢�
-							if (res.available) {
-								// 鍙栨秷鐩戝惉锛屽惁鍒檚topBluetoothDevicesDiscovery鍚庝粛浼氱户缁Е鍙憃nBluetoothAdapterStateChange锛�
-								// 瀵艰嚧鍐嶆璋冪敤startBluetoothDevicesDiscovery
-								// uni.onBluetoothAdapterStateChange(() => {});
-								// 寮�濮嬫悳瀵婚檮杩戠殑钃濈墮澶栧洿璁惧
-								this.startBluetoothDevicesDiscovery();
-							}
-						});
-					}
-				}
-			});
 		},
-		// 寮�濮嬫悳瀵婚檮杩戠殑钃濈墮澶栧洿璁惧
-		startBluetoothDevicesDiscovery() {
-			console.log('寮�濮嬫悳瀵婚檮杩戠殑钃濈墮璁惧');
-			uni.startBluetoothDevicesDiscovery({
-				allowDuplicatesKey: false,
-				interval: 0,
-				success: res => {
-					console.log('鎼滃闄勮繎鐨勮摑鐗欏鍥磋澶� startBluetoothDevicesDiscovery success111', res);
-					// 鐩戝惉瀵绘壘鍒版柊璁惧鐨勪簨浠�
-					this.onBluetoothDeviceFound();
-				},
-				fail: res => {
-					console.log('鎼滃闄勮繎鐨勮摑鐗欏鍥磋澶� startBluetoothDevicesDiscovery fail', res);
-					uni.hideLoading();
-				}
-			});
+		onShow() {
+			let getWindowInfo = uni.getWindowInfo()
+			// console.log(getWindowInfo.screenHeight); //灞忓箷楂樺害
+			// console.log(getWindowInfo.screenWidth); //灞忓箷瀹藉害
+			// console.log(getWindowInfo.windowHeight); //鍙搷浣滈〉闈㈤珮搴�
+			// console.log(getWindowInfo.windowWidth); //鍙搷浣滈〉闈㈠搴�
+			// console.log(getWindowInfo);
+			// console.log('鑾峰彇绐楀彛淇℃伅');
+			let height = (getWindowInfo.screenWidth + 10) * 48 / 74
+			// console.log(height);
+			this.style.height = height + 'px'
+			this.getDate()
+
 		},
-		// 鐩戝惉瀵绘壘鍒版柊璁惧鐨勪簨浠�
-		onBluetoothDeviceFound() {
-			console.log('杩涘叆鏌ヨ璁惧');
-			uni.onBluetoothDeviceFound(res => {
-				console.log('瀵绘壘璁惧', res.devices);
-				res.devices.forEach(device => {
-					if (!device.name && !device.localName) {
-						return;
-					}
-					const foundDevices = this.devices;
-					// 鍦ㄦ暟缁勪腑鏌ユ壘鎸囧畾鍊硷紝骞惰繑鍥炲畠鐨勭储寮曞�硷紙濡傛灉娌℃湁鎵惧埌锛屽垯杩斿洖-1锛�
-					const idx = inArray(foundDevices, 'deviceId', device.deviceId);
-					const data = {};
-					if (idx === -1) {
-						this.$set(this.devices, `${foundDevices.length}`, device);
-					} else {
-						this.$set(this.devices, `${idx}`, device);
-					}
-					console.log('鎼滅储缁撴灉', this.devices);
-					uni.hideLoading();
-				});
-			});
+		onLoad(opt) {
+			let that = this
+			const eventChannel = this.getOpenerEventChannel();
+			eventChannel.on('data', function(data) {
+				that.mat = data.data 
+				that.qrFun(that.mat.matnr)
+			})
+			
 		},
-
-		// this.devices鏄摑鐗欒澶囧垪琛紝娓叉煋鍒伴〉闈㈡樉绀虹偣鍑绘墽琛岃摑鐗欒繛鎺�
-		// 鐐瑰嚮閾炬帴钃濈墮
-		createBLEConnection(e) {
-			console.log('鐐瑰嚮杩炴帴钃濈墮', e);
-			const deviceId = e.deviceId;
-			const name = e.name;
-			this._createBLEConnection(deviceId, name);
-		},
-
-		_createBLEConnection(deviceId, name) {
-			// this.$myToast('杩炴帴璁惧涓�', 'loading');
-			// 杩炴帴浣庡姛鑰楄摑鐗欒澶�
-			uni.createBLEConnection({
-				deviceId, // 鐢ㄤ簬鍖哄垎璁惧鐨� id
-				success: () => {
-					console.log('杩炴帴钃濈墮鎺ュ彛璋冪敤鎴愬姛 createBLEConnection success', this.devices);
-					this.devices.forEach((item, index) => {
-						this.$set(this.devices[index], 'isShowConnect', false);
-						if (item.deviceId === deviceId) {
-							this.$set(this.devices[index], 'isShowConnect', true);
-						}
-					});
-					this.$myToast('璁惧杩炴帴鎴愬姛', 'success');
-
-					this.connected = true;
-					this.isConnected = false;
-					this.name = name;
-					this.deviceId = deviceId;
-					// 鑾峰彇钃濈墮璁惧鎵�鏈夋湇鍔�(service)
-					this.getBLEDeviceServices(deviceId);
-					// 鏈�鍚庤繛鎺ヨ澶�
-					uni.setStorage({
-						key: LAST_CONNECTED_DEVICE,
-						data: name + ':' + deviceId
-					});
-				},
-				complete() {
-					uni.hideLoading();
-				},
-				fail: res => {
-					// 杩炴帴钃濈墮鎺ュ彛璋冪敤澶辫触
-					console.log('杩炴帴钃濈墮鎺ュ彛璋冪敤澶辫触 createBLEConnection fail', res);
-					uni.showModal({
-						title: this.$t('wechat.w227'),
-						content: '钃濈墮杩炴帴澶辫触',
-						showCancel: false
-					});
-				}
-			});
-			// 宸茬粡鎵惧埌闇�瑕佺殑钃濈墮璁惧,鍋滄鎼滃闄勮繎鐨勮摑鐗欏鍥磋澶�
-			this.stopBluetoothDevicesDiscovery();
-		},
-		// 鑾峰彇钃濈墮璁惧鎵�鏈夋湇鍔�(service)
-		getBLEDeviceServices(deviceId) {
-			uni.getBLEDeviceServices({
-				deviceId,
-				success: res => {
-					console.log('鑾峰彇钃濈墮璁惧鎵�鏈夋湇鍔� getBLEDeviceServices', res);
-					for (let i = 0; i < res.services.length; i++) {
-						if (res.services[i].isPrimary) {
-							this.getBLEDeviceCharacteristics(deviceId, res.services[i].uuid);
-							return;
-						}
-					}
-				}
-			});
-		},
-		stopBluetoothDevicesDiscovery() {
-			uni.stopBluetoothDevicesDiscovery({
-				complete: () => {
-					// console.log('stopBluetoothDevicesDiscovery')
-					this._discoveryStarted = false;
-				}
-			});
-		},
-		/*
-								鑾峰彇钃濈墮璁惧鏌愪釜鏈嶅姟涓墍鏈夌壒寰佸��(characteristic)
-								characteristic:
-									uuid:钃濈墮璁惧鐗瑰緛鍊肩殑 uuid
-									properties:璇ョ壒寰佸�兼敮鎸佺殑鎿嶄綔绫诲瀷
-							*/
-		getBLEDeviceCharacteristics(deviceId, serviceId) {
-			uni.getBLEDeviceCharacteristics({
-				// 杩欓噷鐨� deviceId 闇�瑕佸凡缁忛�氳繃 createBLEConnection 涓庡搴旇澶囧缓绔嬮摼鎺�
-				deviceId,
-				// 杩欓噷鐨� serviceId(钃濈墮鏈嶅姟 uuid) 闇�瑕佸湪 getBLEDeviceServices 鎺ュ彛涓幏鍙�
-				serviceId,
-				success: res => {
-					console.log('鐗瑰緛鍊煎彉鍖� getBLEDeviceCharacteristics success', res.characteristics);
-					// 杩欓噷浼氬瓨鍦ㄧ壒寰佸�兼槸鏀寔write锛屽啓鍏ユ垚鍔熶絾鏄病鏈変换浣曞弽搴旂殑鎯呭喌
-					// 鍙兘涓�涓釜鍘昏瘯
-					// characteristics锛氳澶囨湇鍔″垪琛�
-					for (let i = 0; i < res.characteristics.length; i++) {
-						const item = res.characteristics[i];
-						// if (item.properties.read) {
-						// 	uni.readBLECharacteristicValue({
-						// 		deviceId,
-						// 		serviceId,
-						// 		characteristicId: item.uuid
-						// 	})
-						// }
-
-						if (item.properties.write) {
-							this.canWrite = true;
-							this._deviceId = deviceId;
-							this._serviceId = serviceId;
-							this._characteristicId = item.uuid;
-						}
-
-						if (item.properties.notify || item.properties.indicate) {
-							uni.notifyBLECharacteristicValueChange({
-								deviceId,
-								serviceId,
-								characteristicId: item.uuid,
-								state: true
-							});
-						}
-
-						if (item.properties.write) {
-							this.canWrite = true;
-							this._deviceId = deviceId;
-							this._serviceId = serviceId;
-							this._characteristicId = item.uuid;
-						}
-
-						if (item.properties.notify || item.properties.indicate) {
-							uni.notifyBLECharacteristicValueChange({
-								deviceId,
-								serviceId,
-								characteristicId: item.uuid,
-								state: true
-							});
-						}
-					}
-				},
-				fail(res) {
-					console.error('鐗瑰緛鍊煎彉鍖� getBLEDeviceCharacteristics', res);
-				}
-			});
-		},
-
-		// 钃濈墮杩炴帴鎴愬姛鍚庣偣鍑绘墦鍗帮紝鎵撳嵃鏁版嵁
-		// 鐐瑰嚮鎵撳嵃锛氬啓鍏ユ暟鎹紙鏍规嵁椤圭洰闇�瑕佹墦鍗板唴瀹规潵瀹炵幇锛�
-		writeBLECharacteristicValue() {
-			console.log('鍐欐暟鎹�');
-			let printerJobs = new PrinterJobs();
-			// 瑕佹墦鍗扮殑淇℃伅
-			printerJobs
-				.setAlign('ct')
-				.setSize(2, 2)
-				.print('璁板綍鎶ュ憡')
-				.setSize(0, 0)
-				.print()
-				.setAlign('lt');
+		methods: {
 			// 鎵撳嵃
-			printerJobs.print(printerUtil.fillLine());
-			// 缁撳熬
-			printerJobs
-				.println()
-				.print('绛惧悕')
-				.println()
-				.println();
-
-			let buffer = printerJobs.buffer();
-			// console.log('ArrayBuffer', 'length: ' + buffer.byteLength, ' hex: ' + ab2hex(buffer));
-			// 1.骞惰璋冪敤澶氭浼氬瓨鍦ㄥ啓澶辫触鐨勫彲鑳芥��
-			// 2.寤鸿姣忔鍐欏叆涓嶈秴杩�20瀛楄妭
-			// 鍒嗗寘澶勭悊锛屽欢鏃惰皟鐢�
-			const maxChunk = 20;
-			const delay = 40;
-			console.log(111111);
-			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);
-				// subPackage锛氬弬鏁�
-				setTimeout(this._writeBLECharacteristicValue, j * delay, subPackage);
-			}
-
-			console.log(22222);
-		},
-		// 鍚戜綆鍔熻�楄摑鐗欒澶囩壒寰佸�间腑鍐欏叆浜岃繘鍒舵暟鎹�傛敞鎰忥細蹇呴』璁惧鐨勭壒寰佸�兼敮鎸� write 鎵嶅彲浠ユ垚鍔熻皟鐢ㄣ��
-		_writeBLECharacteristicValue(buffer) {
-			console.log('鍐欏叆鏁版嵁');
-			uni.writeBLECharacteristicValue({
-				deviceId: this._deviceId, // 钃濈墮璁惧 id
-				serviceId: this._serviceId, // 钃濈墮鐗瑰緛鍊煎搴旀湇鍔$殑 uuid
-				characteristicId: this._characteristicId, // 钃濈墮鐗瑰緛鍊肩殑 uuid
-				value: buffer, // 钃濈墮璁惧鐗瑰緛鍊煎搴旂殑浜岃繘鍒跺��
-				success(res) {
-					console.log('writeBLECharacteristicValue success', res);
-				},
-				fail(res) {
-					console.log('writeBLECharacteristicValue fail', res);
+			toPrint() {
+				let that = this
+				uni.navigateTo({
+					url: "../print/printUNI",
+					success: function(res) {
+						// 閫氳繃eventChannel鍚戣鎵撳紑椤甸潰浼犻�佹暟鎹�   鍚戝彟澶栦竴涓〉闈紶閫掑�肩殑
+						res.eventChannel.emit('data1', {
+							data: that.mat,
+							time: that.time
+						})
+					},
+					events: {
+						// 涓烘寚瀹氫簨浠舵坊鍔犱竴涓洃鍚櫒锛岃幏鍙栬鎵撳紑椤甸潰浼犻�佸埌褰撳墠椤甸潰鐨勬暟鎹�  鍙﹀涓�涓〉闈紶杩囨潵鐨�
+						acceptDataFromOpenedPage: function(data) {
+							that.matnr = data.data
+						},
+					},
+				
+				
+				});
+			},
+			//**鐢熸垚浜岀淮鐮�**//
+			qrFun(text) {
+				this.qrShow = true
+				uQRCode.make({
+					canvasId: 'qrcode',
+					componentInstance: this,
+					text: text,
+					size: 150,
+					margin: 0,
+					backgroundColor: '#ffffff',
+					foregroundColor: '#000000',
+					fileType: 'jpg',
+					errorCorrectLevel: uQRCode.errorCorrectLevel.H,
+					success: res => {}
+				})
+			},
+			// 鏃ュ巻
+			getDate() {
+				var dt = new Date();
+				var year,month,day,hours,minutes,seconds,weeks
+				year = dt.getFullYear();
+				month = (dt.getMonth()+1) < 10 ? '0'+ (dt.getMonth()+1) : (dt.getMonth()+1);
+				day = dt.getDate() < 10 ? '0'+dt.getDate() : dt.getDate();
+				hours = dt.getHours() < 10 ? '0' + dt.getHours() : dt.getHours();
+				minutes = dt.getMinutes() < 10 ? '0' + dt.getMinutes() : dt.getMinutes();
+				seconds = dt.getSeconds() < 10 ? '0' + dt.getSeconds() : dt.getSeconds(); 
+				weeks = dt.getDay(); 
+				switch (weeks) {
+					case 0: weeks = "鏄熸湡鏃�"; break;
+					case 1: weeks = "鏄熸湡涓�"; break;
+					case 2: weeks = "鏄熸湡浜�"; break;
+					case 3: weeks = "鏄熸湡涓�"; break;
+					case 4: weeks = "鏄熸湡鍥�"; break;
+					case 5: weeks = "鏄熸湡浜�"; break;
+					default : weeks = "鏄熸湡鍏�";
 				}
-			});
+				this.time = year + "骞�" + month + "鏈�" + day + "鏃� " + hours + ":" + minutes + ":" + seconds + " "
+			},
 		}
 	}
-};
 </script>
 
-<style scoped lang="scss">
-.page {
-	margin: 20rpx;
-	color: #323232;
-	background-color: #f5f9ff;
-	height: 100vh;
-}
-.title {
-	font-weight: 600;
-	margin: 20rpx 0rpx;
-}
-.list {
-	.item {
+<style>
+	.print-model {
+		width: 100%;
+		/* background-color: #555555; */
 		display: flex;
-		justify-content: space-between;
-		padding: 10rpx 20rpx;
-		height: 60rpx;
-		line-height: 60rpx;
-		background-color: #ffffff;
-		margin-bottom: 4rpx;
+		align-items: center;
+		justify-content: center;
 	}
 
-	.right {
+	.display {
+		width: 96%;
+		height: 96%;
+		border-radius: 5px;
+		background-color: #FFF;
+		box-shadow: #bdbdbd;
+		display: flex;
+		align-items: center;
+		justify-content: center;
 	}
-	.no-devices {
-		height: 400rpx;
-		font-size: 32rpx;
-		line-height: 400rpx;
+
+	.display-pak {
+		margin: 2%;
+		height: 92%;
+		border: 1px solid #8a8a8a;
+	}
+
+	table {
+		width: 92%;
+		height: 92%;
+		border: 0;
+		border-collapse: collapse;
+	}
+
+	td {
+		border: 1px solid #8a8a8a;
 		text-align: center;
-		color: #969696;
 	}
-}
-
-.font-color-3 {
-	color: #1a8cff;
-}
-
-.submit {
-	background-color: #4d88ff !important;
-	color: #f5f9ff !important;
-}
-
-.disabled {
-	background-color: #66b1ff !important;
-}
 </style>
\ No newline at end of file

--
Gitblit v1.9.1