低代码可视化-uniapp蓝牙标签打印-代码生成器

news2025/1/22 19:12:36

蓝牙标签打印

蓝牙标签打印技术结合了蓝牙通信与标签打印的功能,为用户提供了一种便捷、高效的打印解决方案。以下是对蓝牙标签打印的详细解析:

蓝牙标签打印机的特点

  1. 无线连接:蓝牙标签打印机最大的亮点在于其无线连接方式。用户可以通过蓝牙轻松地将手机、平板电脑或电脑与打印机连接,无需复杂的网络设置或线缆连接,极大地提高了使用的便捷性。
  2. 兼容性强:蓝牙标签打印机通常支持多种操作系统和设备,包括安卓、iOS以及Windows等,满足不同用户的需求。
  3. 便携小巧:许多蓝牙标签打印机设计得小巧轻便,便于携带,用户可以随时随地进行打印操作。
  4. 功能多样:除了基本的文本打印外,蓝牙标签打印机还支持打印条形码、二维码、图片等,广泛应用于物流、仓储、零售、医疗等行业。

蓝牙标签打印机的应用场景

  1. 物流管理:在快递、物流行业中,蓝牙标签打印机可以快速打印出运单、标签等,提高包裹的分拣和配送效率。
  2. 仓储管理:在仓库中,蓝牙标签打印机可以打印出货物标签、货架标签等,帮助工作人员快速识别和定位货物。
  3. 零售管理:在超市、便利店等零售场所,蓝牙标签打印机可以打印出价格标签、促销标签等,方便商品管理和顾客选购。
  4. 医疗管理:在医疗行业中,蓝牙标签打印机可以打印出药品标签、患者信息标签等,确保医疗过程的安全和准确。

蓝牙标签打印的优势

  1. 提高效率:无线连接和便携设计使得蓝牙标签打印机可以在任何需要的地方进行打印操作,大大提高了工作效率。
  2. 降低成本:相比于传统的有线打印方式,蓝牙标签打印机减少了线缆和设备的投入成本,同时降低了维护成本。
  3. 增强灵活性:蓝牙标签打印机支持多种打印格式和内容,可以根据实际需求进行灵活调整和优化。

打印核心代码

打印核心代码基于网上资源自己进行了二次开发,兼容了uniapp。

print.js核心代码

import tsc from './tsc.js';
import esc from './esc.js';

// 打印程序begin---------------------------------
/**
 * android 6.0以上需授权地理位置权限
 */
var checkPemission = function(that) {
	var systemInfo = uni.getSystemInfoSync();
	var platform = systemInfo.platform;
	if (platform == "ios") {
		getBluetoothDevices(that)
	} else if (platform == "android") {
		let system = systemInfo.system;
		let system_no = system.replace('android', '');
		system_no = system.replace('Android', '');
		if (Number(system_no) > 5) {
			uni.getSetting({
				success: function(res) {
					if (!res.authSetting['scope.userLocation']) {
						uni.authorize({
							scope: 'scope.userLocation',
							complete: function(res) {
								getBluetoothDevices(that)
							}
						})
					} else {
						getBluetoothDevices(that)
					}
				}
			})
		}
	}
}

/**
 * 获取蓝牙设备信息
 */
var getBluetoothDevices = function(that) {
	console.log("start search")
	uni.showLoading({
		title: '搜索中',
	})
	that.setData({
		isScanning: true
	})
	uni.startBluetoothDevicesDiscovery({
		success: function(res) {
			setTimeout(function() {
				uni.getBluetoothDevices({
					success: function(res) {
						var devices = []
						var num = 0
						for (var i = 0; i < res.devices.length; ++i) {
							if (res.devices[i].name != "未知设备") {
								devices[num] = res.devices[i]
								num++
							}
						}
						that.setData({
							devicesList: devices,
							isScanning: false
						})
						uni.hideLoading()
						uni.stopPullDownRefresh()
					},
				})
			}, 3000)
		},
	})
}

/**
 * 开始连接蓝牙设置
 */
var connectBluetoothSettings = function(app, that) {
	let deviceId = that.deviceId;
	uni.stopBluetoothDevicesDiscovery({
		success: function(res) {
			//console.log(res)
		},
	})
	that.setData({
		serviceId: 0,
		writeCharacter: false,
		readCharacter: false,
		notifyCharacter: false
	})
	uni.showLoading({
		title: '正在连接',
	})
	uni.createBLEConnection({
		deviceId: deviceId,
		success: function(res) {
			app.globalData.bluetoothDeviceId = deviceId
			getBLEDeviceServices(app, that);
			uni.showLoading({
				title: '连接好可以打印',
			})
		},
		fail: function(e) {
			uni.showModal({
				title: '提示',
				content: '连接失败',
			})
			uni.hideLoading()
		},
		complete: function(e) {
			//console.log(e)
		}
	})
}

/**
 * 获取蓝牙设备所有服务
 */
var getBLEDeviceServices = function(app, that) {
	console.log(app.globalData.bluetoothDeviceId)
	uni.getBLEDeviceServices({
		deviceId: app.globalData.bluetoothDeviceId,
		success: function(res) {
			that.setData({
				services: res.services
			})
			getBLEDeviceCharacteristics(app, that)
		},
		fail: function(e) {
			console.log(e)
		},
		complete: function(e) {
			//console.log(e)
		}
	})
}

/**
 * 获取蓝牙设备某个服务中所有特征值
 */
var getBLEDeviceCharacteristics = function(app, that) {
	var list = that.services
	var num = that.serviceId
	var write = that.writeCharacter
	var read = that.readCharacter
	var notify = that.notifyCharacter
	uni.getBLEDeviceCharacteristics({
		deviceId: app.globalData.bluetoothDeviceId,
		serviceId: list[num].uuid,
		success: function(res) {
			for (var i = 0; i < res.characteristics.length; ++i) {
				var properties = res.characteristics[i].properties
				var item = res.characteristics[i].uuid
				if (!notify) {
					if (properties.notify) {
						app.globalData.notifyCharaterId = item
						app.globalData.notifyServiceId = list[num].uuid
						notify = true
					}
				}
				if (!write) {
					if (properties.write) {
						app.globalData.writeCharaterId = item
						app.globalData.writeServiceId = list[num].uuid
						write = true
					}
				}
				if (!read) {
					if (properties.read) {
						app.globalData.readCharaterId = item
						app.globalData.readServiceId = list[num].uuid
						read = true
					}
				}
			}
			if (!write || !notify || !read) {
				num++
				that.setData({
					writeCharacter: write,
					readCharacter: read,
					notifyCharacter: notify,
					serviceId: num
				})
				if (num == list.length) {
					uni.showModal({
						title: '提示',
						content: '找不到该读写的特征值',
					})
				} else {
					getBLEDeviceCharacteristics(app, that)
				}
			} else {
				notifyBLECharacteristicValueChange(app)
			}
		},
		fail: function(e) {
			console.log(e)
		},
		complete: function(e) {
			//console.log("write:" + app.globalData.writeCharaterId)
			//console.log("read:" + app.globalData.readCharaterId)
			//console.log("notify:" + app.globalData.notifyCharaterId)
		}
	})
}

/**
 * 启用低功耗蓝牙设备特征值变化时的 notify 功能
 */
var notifyBLECharacteristicValueChange = function(app) {
	//console.log("deviceId:" + app.globalData.bluetoothDeviceId)
	//console.log("serviceId:" + app.globalData.notifyServiceId)
	//console.log("notifyCharaterId:" + app.globalData.notifyCharaterId)
	uni.hideLoading();
	uni.notifyBLECharacteristicValueChange({
		deviceId: app.globalData.bluetoothDeviceId,
		serviceId: app.globalData.notifyServiceId,
		characteristicId: app.globalData.notifyCharaterId,
		state: true,
		success: function(res) {
			uni.onBLECharacteristicValueChange(function(r) {
				//console.log('onBLECharacteristicValueChange=', r);
			})
		},
		fail: function(e) {
			console.log('fail', e)
		},
		complete: function(e) {
			//console.log('complete', e)
		}
	})
}

/**
 * 标签模式
 */
var labelTest = function(app, that) {
	var command = tsc.jpPrinter.createNew()
	command.setSize(70, 50) //纸宽度70,高度50
	command.setGap(0)
	command.setCls() //需要设置这个,不然内容和上一次重复
	// 10起始位置,10行距,TSS24.BF2字体,1字与字之间的间距,1字体大小,最后一个打印内容
	command.setText(10, 10, "TSS24.BF2", 2, 2, 'DIY可视化蓝牙打印')
	command.setText(10, 70, "TSS24.BF2", 1, 1, '联系人:邓志锋')
	command.setText(10, 110, "TSS24.BF2", 1, 1, '网址:diygw.com')
	command.setText(10, 150, "TSS24.BF2", 1, 1, '电话:15655555555')
	//command.setText(10, 40, "TSS24.BF2", 1, 2, "蓝牙热敏标签打印测试2")
	command.setPagePrint()
	prepareSend(app, that, command.getData())
}

// 打印标签
var printLabel = function(app, that) {
	var command = tsc.jpPrinter.createNew()
	command.setSpeed(0)
	command.setSize(that.form.width, that.form.height) //纸宽度,高度
	command.setGap(0)
	command.setCls() //需要设置这个,不然内容和上一次重复
	// 10起始位置,TSS24.BF2字体,1字与字之间的间距,1字体大小,一行行增加40高度打印
	// 打印位置
	let y = 0;
	let content = that.form.content
	for (let i = 0; i < content.length; i++) {
		command.setText(10, y, "TSS24.BF2", content[i].scale, content[i].scale, content[i].text)
		y = y + 40
	}
	command.setPagePrint()
	prepareSend(app, that, command.getData())
}

/**
 * 准备发送数据
 */
var prepareSend = function(app, that, buff) {
	//console.log('buff', buff)
	var time = that.oneTimeData
	var looptime = parseInt(buff.length / time);
	var lastData = parseInt(buff.length % time);
	that.setData({
		looptime: looptime + 1,
		lastData: lastData,
		currentTime: 1,
	})
	Send(app, that, buff)
}

/**
 * 查询打印机状态
 */
var queryPrinterStatus = function() {
	var command = esc.jpPrinter.Query();
	command.getRealtimeStatusTransmission(1);
	this.setData({
		returnResult: "查询成功"
	})
}

/**
 * 分包发送
 */
var Send = function(app, that, buff) {
	var currentTime = that.currentTime;
	var loopTime = that.looptime;
	var lastData = that.lastData;
	var onTimeData = that.oneTimeData;
	var printNum = that.printNum; //打印多少份
	var currentPrint = that.currentPrint;
	var buf
	var dataView
	if (currentTime < loopTime) {
		buf = new ArrayBuffer(onTimeData)
		dataView = new DataView(buf)
		for (var i = 0; i < onTimeData; ++i) {
			dataView.setUint8(i, buff[(currentTime - 1) * onTimeData + i])
		}
	} else {
		buf = new ArrayBuffer(lastData)
		dataView = new DataView(buf)
		for (var i = 0; i < lastData; ++i) {
			dataView.setUint8(i, buff[(currentTime - 1) * onTimeData + i])
		}
	}
	console.log("第" + currentTime + "次发送数据大小为:" + buf.byteLength);
	console.log("deviceId:" + app.globalData.bluetoothDeviceId)
	console.log("serviceId:" + app.globalData.writeServiceId)
	console.log("characteristicId:" + app.globalData.writeCharaterId)
	uni.writeBLECharacteristicValue({
		deviceId: app.globalData.bluetoothDeviceId,
		serviceId: app.globalData.writeServiceId,
		characteristicId: app.globalData.writeCharaterId,
		value: buf,
		success: function(res) {
			console.log('写入成功', res)
		},
		fail: function(e) {
			console.error('写入失败', e)
		},
		complete: function() {
			currentTime++
			if (currentTime <= loopTime) {
				that.setData({
					currentTime: currentTime
				})
				Send(app, that, buff)
			} else {
				if (currentPrint == printNum) {
					that.setData({
						looptime: 0,
						lastData: 0,
						currentTime: 1,
						isReceiptSend: false,
						isLabelSend: false,
						currentPrint: 1
					})
				} else {
					currentPrint++
					that.setData({
						currentPrint: currentPrint,
						currentTime: 1,
					})
					console.log("开始打印")
					Send(app, that, buff)
				}
			}
			//console.log('打印完成')
		}
	})
}

/**
 * 蓝牙搜索
 */
var searchBluetooth = function(that) {
	//判断蓝牙是否打开
	if(uni.openBluetoothAdapter){
		uni.openBluetoothAdapter({
			success: function(res) {
				uni.getBluetoothAdapterState({
					success: function(res) {
						if (res.available) {
							if (res.discovering) {
								uni.stopBluetoothDevicesDiscovery({
									success: function(res) {
										//console.log(res)
									}
								})
							}
							checkPemission(that)
						} else {
							uni.showModal({
								title: '提示',
								content: '请开启手机蓝牙后再试',
							})
						}
					},
				})
			},
			fail: function() {
				uni.showModal({
					title: '提示',
					content: '蓝牙初始化失败,请打开蓝牙',
				})
			}
		})
	}else{
		that.showToast('只支持APP或小程序')
	}
	
}
// -end---------------------------------

var print = {
	searchBluetooth: searchBluetooth,
	connectBluetoothSettings: connectBluetoothSettings,
	labelTest: labelTest,
	printLabel: printLabel
}
export default print;

tsc.js核心代码


import encode from './encoding.js';
var jpPrinter = {
  createNew: function () {
    var jpPrinter = {};
    var data = "";
    var command = []

    jpPrinter.name = "标签模式";

    jpPrinter.init = function () { };

    jpPrinter.addCommand = function (content) {  //将指令转成数组装起
      var code = new encode.TextEncoder(
        'gb18030', {
          NONSTANDARD_allowLegacyEncoding: true
        }).encode(content)
      for (var i = 0; i < code.length; ++i) {
        command.push(code[i])
      }
    }

    jpPrinter.setSize = function (pageWidght, pageHeight) { //设置页面大小
      data = "SIZE " + pageWidght.toString() + " mm" + "," + pageHeight.toString() + " mm" + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setSpeed = function (printSpeed) { //设置打印机速度
      data = "SPEED " + printSpeed.toString() + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setDensity = function (printDensity) { //设置打印机浓度
      data = "DENSITY " + printDensity.toString() + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setGap = function (printGap) { //传感器
      data = "GAP " + printGap.toString() + " mm\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setCountry = function (country) { //选择国际字符集
      /*
      001:USA
      002:French
      003:Latin America
      034:Spanish
      039:Italian
      044:United Kingdom
      046:Swedish
      047:Norwegian
      049:German
       */
      data = "COUNTRY " + country + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setCodepage = function (codepage) { //选择国际代码页
      /*
      8-bit codepage 字符集代表
      437:United States
      850:Multilingual
      852:Slavic
      860:Portuguese
      863:Canadian/French
      865:Nordic
      Windows code page
      1250:Central Europe
      1252:Latin I
      1253:Greek
      1254:Turkish
      以下代码页仅限于 12×24 dot 英数字体
      WestEurope:WestEurope
      Greek:Greek
      Hebrew:Hebrew
      EastEurope:EastEurope
      Iran:Iran
      IranII:IranII
      Latvian:Latvian
      Arabic:Arabic
      Vietnam:Vietnam
      Uygur:Uygur
      Thai:Thai
      1252:Latin I
      1257:WPC1257
      1251:WPC1251
      866:Cyrillic
      858:PC858
      747:PC747
      864:PC864
      1001:PC100
      */
      data = "CODEPAGE " + codepage + "\r\n";
      jpPrinter.addCommand(data)
    }

    jpPrinter.setCls = function () { //清除打印机缓存
      data = "CLS" + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setFeed = function (feed) { //将纸向前推出n
      data = "FEED " + feed + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setBackFeed = function (backup) { //将纸向后回拉n
      data = "BACKFEED " + backup + "\r\n";
      jpPrinter.addCommand(data)
    }

    jpPrinter.setDirection = function (direction) { //设置打印方向,参考编程手册  
      data = "DIRECTION " + direction + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setReference = function (x, y) { //设置坐标原点,与打印方向有关
      data = "REFERENCE " + x + "," + y + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setFromfeed = function () { //根据Size进一张标签纸
      data = "FORMFEED \r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setHome = function () { //根据Size找到下一张标签纸的位置
      data = "HOME \r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setSound = function (level, interval) { //控制蜂鸣器
      data = "SOUND " + level + "," + interval + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setLimitfeed = function (limit) { // 检测垂直间距
      data = "LIMITFEED " + limit + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setBar = function (x, y, width, height) { //绘制线条
      data = "BAR " + x + "," + y + "," + width + "," + height + "\r\n"
      jpPrinter.addCommand(data)
    };

    jpPrinter.setBox = function (x_start, y_start, x_end, y_end, thickness) { //绘制方框
      data = "BOX " + x_start + "," + y_start + "," + x_end + "," + y_end + "," + thickness + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setErase = function (x_start, y_start, x_width, y_height) { //清除指定区域的数据
      data = "ERASE " + x_start + "," + y_start + "," + x_width + "," + y_height + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setReverse = function (x_start, y_start, x_width, y_height) { //将指定的区域反相打印
      data = "REVERSE " + x_start + "," + y_start + "," + x_width + "," + y_height + "\r\n";
      jpPrinter.addCommand(data)
    };

    jpPrinter.setText = function (x, y, font, x_, y_, str) { //打印文字
      data = "TEXT " + x + "," + y + ",\"" + font + "\"," + 0 + "," + x_ + "," + y_ + "," + "\"" + str + "\"\r\n"
      jpPrinter.addCommand(data)
    };

    jpPrinter.setQR = function (x, y, level, width, mode, content) { //打印二维码
      data = "QRCODE " + x + "," + y + "," + level + "," + width + "," + mode + "," + 0 + ",\"" + content + "\"\r\n"
      jpPrinter.addCommand(data)
    };

    jpPrinter.setBar = function (x, y, codetype, height, readable, narrow, wide, content) { //打印条形码
      data = "BARCODE " + x + "," + y + ",\"" + codetype + "\"," + height + "," + readable + "," + 0 + "," + narrow + "," + wide + ",\"" + content + "\"\r\n"
      jpPrinter.addCommand(data)
    };

    jpPrinter.setBitmap = function (x, y, mode, res) {  //添加图片,res为画布参数
      console.log(res)
      var width = parseInt((res.width + 7) / 8 * 8 / 8)
      var height = res.height;
      var time = 1;
      var temp = res.data.length - width * 32;
      var pointList = []
      console.log(width + "--" + height)
      data = "BITMAP " + x + "," + y + "," + width + "," + height + "," + mode + ","
      jpPrinter.addCommand(data)
      for (var i = 0; i < height; ++i) {
        console.log(temp)
        for (var j = 0; j < width; ++j) {
          for (var k = 0; k < 32; k += 4) {
            if (res.data[temp] == 0 && res.data[temp + 1] == 0 && res.data[temp + 2] == 0 && res.data[temp + 3] == 0) {
              pointList.push(1)
            } else {
              pointList.push(0)
            }
            temp += 4
          }
        }
        time++
        temp = res.data.length - width * 32 * time
      }
      for (var i = 0; i < pointList.length; i += 8) {
        var p = pointList[i] * 128 + pointList[i + 1] * 64 + pointList[i + 2] * 32 + pointList[i + 3] * 16 + pointList[i + 4] * 8 + pointList[i + 5] * 4 + pointList[i + 6] * 2 + pointList[i + 7]
        command.push(p)
      }
    }

    jpPrinter.setPagePrint = function () { //打印页面
      data = "PRINT 1,1\r\n"
      jpPrinter.addCommand(data)
    };
    //获取打印数据
    jpPrinter.getData = function () {
      return command;
    };
    return jpPrinter;
  }
};

var tsc={
	jpPrinter
}
export default tsc;

页面调用

<template>
	<view class="container container329843">
		<button @tap="navigateTo" data-type="searchBluetoothFunction" class="diygw-col-24 btn-clz diygw-btn-default">搜索打印机</button>
		<text class="diygw-col-24 text-clz"> 如果是微信小程序,请前往微信官方公众平台设置隐私协议 </text>
		<u-form-item labelWidth="auto" class="diygw-col-24" v-if="devicesList.length > 0" label="选择打印机" labelPosition="top" prop="deviceId">
			<diy-checkbox class="diygw-col-24" col="12" mode="radio" valueField="deviceId" labelField="name" v-model="deviceId" :list="devicesList" @change="changeDeviceId"> </diy-checkbox>
		</u-form-item>
		<u-form-item labelAlign="justify" class="diygw-col-24" label="打印份数" prop="printNum">
			<u-input :focus="printNumFocus" placeholder="请输入打印份数" v-model="printNum" type="number"></u-input>
		</u-form-item>
		<u-form :model="form" :rules="formRules" :errorType="['message', 'toast']" ref="formRef" class="flex diygw-form diygw-col-24">
			<view class="flex flex-wrap diygw-col-24">
				<u-form-item labelAlign="justify" class="diygw-col-12" label="标签宽度" prop="width">
					<u-input :focus="formData.widthFocus" placeholder="请输入宽度" v-model="form.width" type="number"></u-input>
				</u-form-item>
				<u-form-item labelAlign="justify" class="diygw-col-12" label="标签高度" prop="height">
					<u-input :focus="formData.heightFocus" placeholder="请输入宽度" v-model="form.height" type="number"></u-input>
				</u-form-item>
			</view>
			<view class="flex flex-wrap diygw-col-24">
				<view class="diygw-col-24" v-for="(contentItem, contentIndex) in form.content" :key="contentIndex">
					<u-form class="diygw-col-24" :model="form.content[contentIndex]" :errorType="['message', 'toast']" ref="contentRef" :rules="contentItemRules">
						<view class="flex flex-wrap diygw-col-24 flex1-clz">
							<u-form-item labelAlign="justify" class="diygw-col-24" label="放大倍数" prop="scale">
								<u-input :focus="formData.contentItemDatas[contentIndex].scaleFocus" placeholder="请输入宽度" v-model="contentItem.scale" type="number"></u-input>
							</u-form-item>
							<u-form-item labelAlign="justify" class="diygw-col-24" label="打印内容" prop="text">
								<u-input :focus="formData.contentItemDatas[contentIndex].textFocus" placeholder="请输入宽度" v-model="contentItem.text"></u-input>
							</u-form-item>
						</view>
					</u-form>
					<view class="formcontenttools flex justify-end">
						<button @tap="upContentItem" :data-index="contentIndex" class="diygw-btn flex-sub radius margin-xs">
							<text class="button-icon diy-icon-fold"></text>
						</button>
						<button @tap="downContentItem" :data-index="contentIndex" class="diygw-btn flex-sub radius margin-xs">
							<text class="button-icon diy-icon-unfold"></text>
						</button>
						<button @tap="addContentItem" :data-index="contentIndex" class="diygw-btn flex-sub radius margin-xs">
							<text class="button-icon diy-icon-add"></text>
						</button>
						<button @tap="delContentItem" :data-index="contentIndex" class="diygw-btn flex-sub radius margin-xs">
							<text class="button-icon diy-icon-close"></text>
						</button>
					</view>
				</view>
			</view>
		</u-form>
		<button @tap="navigateTo" data-type="printFunction" class="diygw-col-24 prt-clz diygw-btn-default">开始打印</button>
		<view class="clearfix"></view>
	</view>
</template>

<script>
	import print from '@/common/print/print.js';
	export default {
		data() {
			return {
				//用户全局信息
				userInfo: {},
				//页面传参
				globalOption: {},
				//自定义全局变量
				globalData: {},
				devicesList: [],
				services: [],
				serviceId: 0,
				writeCharacter: false,
				readCharacter: false,
				notifyCharacter: false,
				isScanning: false,
				looptime: 0,
				currentTime: 1,
				lastData: 0,
				oneTimeData: 20,
				returnResult: 'returnResult',
				currentPrint: 1,
				isReceiptSend: false,
				isLabelSend: true,
				deviceId: '',
				printNumFocus: false,
				printNum: 1,
				form: {
					width: 40,
					height: 70,
					content: []
				},
				formRules: {},
				contentItem: {
					scale: 1,
					text: 'DIYGW可视化蓝牙打印'
				},
				contentItemData: {
					scaleFocus: false,
					textFocus: false
				},
				formData: {
					widthFocus: false,
					heightFocus: false,
					contentItemDatas: []
				},
				contentItemRules: {}
			};
		},
		onShow() {
			this.setCurrentPage(this);
		},
		onLoad(option) {
			this.setCurrentPage(this);
			if (option) {
				this.setData({
					globalOption: this.getOption(option)
				});
			}

			this.init();
		},
		onReady() {
			this.$refs.formRef?.setRules(this.formRules);
			this.initContentData();
		},
		methods: {
			async init() {
				await this.initResetform();
			},
			// 搜索打印机 自定义方法
			async searchBluetoothFunction(param) {
				let thiz = this;
				print.searchBluetooth(this);
			},

			// 打印 自定义方法
			async printFunction(param) {
				let thiz = this;
				if (!this.deviceId) {
					this.navigateTo({
						type: 'tip',
						tip: '请选择打印机'
					});
					return;
				}
				print.printLabel(getApp(), this);
			},

			// 连接打印 自定义方法
			async connectFunction(param) {
				let thiz = this;
				print.connectBluetoothSettings(getApp(), this);
			},
			changeDeviceId(evt) {
				this.navigateTo({ type: 'connectFunction' });
			},
			//初始化显示子表单数据条数
			initContentData() {
				for (let i = 0; i < 1; i++) {
					this.form.content.push(JSON.parse(JSON.stringify(this.contentItem)));
					this.formData.contentItemDatas.push(JSON.parse(JSON.stringify(this.contentItemData)));
				}
				this.initContentValid();
			},
			//子表单验证
			initContentValid() {
				this.$nextTick(() => {
					this.$refs['contentRef']?.forEach((subform) => {
						subform.setRules(this.contentItemRules);
					});
				});
			},
			//上移子表单
			upContentItem(evt) {
				let { index } = evt.currentTarget.dataset;
				if (index == 0) {
					this.navigateTo({
						type: 'tip',
						tip: '已经是第一个'
					});
					return false;
				}
				this.form.content[index] = this.form.content.splice(index - 1, 1, this.form.content[index])[0];
				this.formData.contentItemDatas[index] = this.formData.contentItemDatas.splice(index - 1, 1, this.formData.contentItemDatas[index])[0];
				this.initContentValid();
			},
			//下移子表单
			downContentItem(evt) {
				let { index } = evt.currentTarget.dataset;
				if (index == this.form.content.length - 1) {
					this.navigateTo({
						type: 'tip',
						tip: '已经是最后一个'
					});
					return false;
				}
				this.form.content[index] = this.form.content.splice(index + 1, 1, this.form.content[index])[0];
				this.formData.contentItemDatas[index] = this.formData.contentItemDatas.splice(index + 1, 1, this.formData.contentItemDatas[index])[0];
				this.initContentValid();
			},
			//删除子表单
			delContentItem(evt) {
				if (this.form.content.length == 1) {
					this.showToast('不能小于1个');
					return;
				}
				let { index } = evt.currentTarget.dataset;
				this.form.content.splice(index, 1);
				this.formData.contentItemDatas.splice(index, 1);
				this.initContentValid();
			},
			//增加子表单
			addContentItem() {
				this.form.content.push(JSON.parse(JSON.stringify(this.contentItem)));
				this.formData.contentItemDatas.push(JSON.parse(JSON.stringify(this.contentItemData)));
				this.initContentValid();
			},
			//验证所有的子表单
			checkContentValid() {
				let flag = true;
				this.$refs['contentRef']?.forEach((subform) => {
					subform.validate((valid) => {
						if (!valid) {
							flag = false;
							return false;
						}
					});
				});
				return flag;
			},
			initResetform() {
				this.initform = JSON.stringify(this.form);
				//如果想给表单默认初始值,其中row为某一行数据也可能是API返回的结果集,然后给到this.form
				//this.form = this.$tools.changeRowToForm(row,this.form)
			},
			resetForm() {
				this.form = JSON.parse(this.initform);
			},

			async submitForm(e) {
				this.$refs.formRef?.setRules(this.formRules);

				this.initContentValid();
				this.$nextTick(async () => {
					let contentvalid = await this.checkContentValid();
					let valid = await this.$refs.formRef.validate();
					if (valid && contentvalid) {
						//保存数据
						let param = this.form;
						let header = {
							'Content-Type': 'application/json'
						};
						let url = '';
						if (!url) {
							this.showToast('请先配置表单提交地址', 'none');
							return false;
						}

						let res = await this.$http.post(url, param, header, 'json');

						if (res.code == 200) {
							this.showToast(res.msg, 'success');
						} else {
							this.showModal(res.msg, '提示', false);
						}
					} else {
						console.log('验证失败');
					}
				});
			}
		}
	};
</script>

<style lang="scss" scoped>
	.btn-clz {
		padding-top: 20rpx;
		border-bottom-left-radius: 120rpx;
		color: #fff;
		padding-left: 20rpx;
		padding-bottom: 20rpx;
		border-top-right-radius: 120rpx;
		margin-right: 30rpx;
		background-color: #07c160;
		margin-left: 30rpx;
		overflow: hidden;
		width: calc(100% - 30rpx - 30rpx) !important;
		border-top-left-radius: 120rpx;
		margin-top: 20rpx;
		border-bottom-right-radius: 120rpx;
		margin-bottom: 20rpx;
		text-align: center;
		padding-right: 20rpx;
	}
	.text-clz {
		border-bottom-left-radius: 120rpx;
		overflow: hidden;
		border-top-left-radius: 120rpx;
		border-top-right-radius: 120rpx;
		border-bottom-right-radius: 120rpx;
		text-align: center;
	}
	.formcontenttools {
		position: absolute;
		z-index: 1;
		right: 0rpx;
		top: 0rpx;
	}
	.formcontenttools .diygw-btn {
		padding: 5px;
		height: auto;
		flex: inherit;
		border-radius: 20px;
	}
	.flex1-clz {
		border: 2rpx solid #eee;
		padding-top: 10rpx;
		border-bottom-left-radius: 12rpx;
		padding-left: 10rpx;
		padding-bottom: 10rpx;
		border-top-right-radius: 12rpx;
		margin-right: 20rpx;
		margin-left: 20rpx;
		overflow: hidden;
		width: calc(100% - 20rpx - 20rpx) !important;
		border-top-left-radius: 12rpx;
		margin-top: 10rpx;
		border-bottom-right-radius: 12rpx;
		margin-bottom: 10rpx;
		padding-right: 10rpx;
	}
	.prt-clz {
		padding-top: 20rpx;
		border-bottom-left-radius: 120rpx;
		color: #fff;
		padding-left: 20rpx;
		padding-bottom: 20rpx;
		border-top-right-radius: 120rpx;
		margin-right: 30rpx;
		background-color: #07c160;
		margin-left: 30rpx;
		overflow: hidden;
		width: calc(100% - 30rpx - 30rpx) !important;
		border-top-left-radius: 120rpx;
		margin-top: 20rpx;
		border-bottom-right-radius: 120rpx;
		margin-bottom: 20rpx;
		text-align: center;
		padding-right: 20rpx;
	}
	.container329843 {
	}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2178357.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Redis基础篇】超详细♥Redis安装教程、5种常用数据结构和常见命令、Jedis和SpringDataRedis的使用

文章目录 一、Redis与客户端安装教程1、NoSQL介绍&#xff08;1&#xff09;结构化与非结构化&#xff08;2&#xff09;关联和非关联&#xff08;3&#xff09;查询方式&#xff08;4&#xff09;事务&#xff08;5&#xff09;总结 2、Redis介绍3、安装Redis&#xff08;1&am…

毕业论文设计javaweb+VUE高校教师信息管理系统

目录 一、系统概述 二、功能详解 1. 教师管理 2. 部门管理 3. 奖惩管理 4. 业绩管理 5. 培训管理 6. 报表查询 三、总结 四、示例代码 1 前端VUE 2 后端SpringBootjava 3 数据库表 随着教育信息化的发展&#xff0c;传统的手工管理方式已经不能满足现代学校对教师…

Python安装流程(Windows + MAC)

目录 Windows 版 1.下载Python 2.开始安装 3.配置环境变量 4.测试python是否成功安装 MAC版 1.下载Python 2.开始安装 Windows 版 1.下载Python 进入Python官网下载&#xff1a;&#xff08;Python更新频繁&#xff0c;下载最新版即可&#xff0c;安装流程一致&#x…

打印机共享错误11b解决方法介绍

共享打印机遇见各种错误&#xff0c;例如0x00000709,0x0000011b&#xff0c;浪费大量的时间去尝试各种方法去解决此问题&#xff0c;最终结果还是也连接共享失败&#xff1f;这个时候就说是不是系统有问题了&#xff0c;绝大多数的情况下是把电脑的系统重新安装了一遍&#xff…

前端工程规范-4:Git提交前代码规范检查(Husky + Lint-staged)

Git提交前代码规范检查 在前端项目开发中&#xff0c;规范git提交信息&#xff0c;也是经常使用的手段&#xff0c;如何确保团队成员都遵循ESint规则&#xff0c;且不会将不符合规范的代码推送到Git仓库&#xff1f; 答案是&#xff1a;使用带有git hooks功能的husky。git hoo…

文心一言 VS 讯飞星火 VS chatgpt (357)-- 算法导论24.2 3题

三、上面描述的 PERT 图的公式有一点不太自然。在一个更自然的结构下&#xff0c;图中的结点代表要执行的工作&#xff0c;边代表工作之间的次序限制&#xff0c;即边 (u&#xff0c;v) 表示工作 u 必须在工作 v 之前执行。在这种结构的图中&#xff0c;我们将权重赋给结点&…

SQL中基本SELECT语句及常见关键字的使用(内连接,左/右连接)

这里写目录标题 SQL中基本SELECT语句的使用SQL语法简介DDL、DML、DCLSEECT SELECT常用关键词group by分组having筛选limit限定条数UION和UION ALL合并SQL执行顺序 联表查询多表查询示例特殊用法&#xff1a;笛卡尔积&#xff08;交叉连接&#xff09;等值连接vs非等值连接自连接…

ResNet18果蔬图像识别分类

关于深度实战社区 我们是一个深度学习领域的独立工作室。团队成员有&#xff1a;中科大硕士、纽约大学硕士、浙江大学硕士、华东理工博士等&#xff0c;曾在腾讯、百度、德勤等担任算法工程师/产品经理。全网20多万粉丝&#xff0c;拥有2篇国家级人工智能发明专利。 社区特色…

接口隔离原则(学习笔记)

客户端不应该被迫依赖于它不使用的方法&#xff1a;一个类对另一个类的依赖应该建立在最小的接口上。 上面的设计我们发现他存在的问题&#xff0c;黑马品牌的安全门具有防盗&#xff0c;防水&#xff0c;防火的功能。现在如果我们还需要再创建一盒传智品牌的安全门&#xff0c…

王道-计网

2 采用滑动窗口机制对两个相邻结点A(发送方)和B(接收方)的通信过程进行流量控制。假定帧的序号长度为3比特,发送窗口与接收窗口的大小均为7,当A发送了编号为0、1、2、3这4个帧后,而B接收了这4个帧,但仅应答了0、1两个帧,A继续发送4、5两个帧,且这两个帧已进入B的接收…

Oracle 表空间时间点恢复

已有一个数据库全备&#xff0c;在PDB中恢复被drop掉的表空间 1.新建表空间 create tablespace PITR_TBS datafile /u01/app/oracle/oradata/PRODCDB/PDBPROD2/PITR_TBS01.dbf size 10m; 2.使用RMAN备份. backup as compressed backupset database INCLUDE CURRENT CONTROLFI…

秘AI模型登顶评分网站:网友猜测是F.1新作诞生?

神秘的 AI 生成模型 就在近日&#xff0c;有一个“幽灵模型”直接登顶了模型评测网站&#xff0c;直接力压近期爆火的 Flux.1 等一众模型。但奇怪的是这个名为 Blueberry 的模型却没有任何一家公司或团队出来“认领”。这件事情也引发了众多人的讨论。 疑似 Flux 团队续作 幽灵…

ADRC线性跟踪微分器TD详细测试(Simulink 算法框图+CODESYS ST+博途SCL完整源代码)

1、ADRC线性跟踪微分器 ADRC线性跟踪微分器(ST+SCL语言)_adrc算法在博途编程中scl语言-CSDN博客文章浏览阅读784次。本文介绍了ADRC线性跟踪微分器的算法和源代码,包括在SMART PLC和H5U平台上的实现。文章提供了ST和SCL语言的详细代码,并讨论了跟踪微分器在自动控制中的作用…

【车载开发系列】ParaSoft单元测试环境配置(四)

【车载开发系列】ParaSoft单元测试环境配置(四) 【车载开发系列】ParaSoft单元测试环境配置(四) 【车载开发系列】ParaSoft单元测试环境配置(四)一. 如何设置过滤二. 如何设置静态扫描的规则三. 如何设置单个测试用例的超时时间四. 如何获取测试用例的数量五. 如何设置Gc…

数字图像处理:边缘检测

数字图像处理&#xff1a;边缘检测 笔记来源&#xff1a; 1.Gradient and Laplacian Filter, Difference of Gaussians (DOG) 1.1 图像一阶梯度 水平方向的一阶导数 一阶导数滤波器在实际应用中难实现的原因 图像梯度中&#xff0c;一阶梯度中找局部极大值就是边缘所在处&a…

2、Stable Diffusion

2、Stable Diffusion Stable Diffusion 是一种高效的文本到图像生成模型&#xff0c;它利用扩散模型&#xff08;Diffusion Model&#xff09;技术将自然语言描述转换为高质量的图像。其工作原理是通过反向扩散过程&#xff0c;逐渐将噪声引导到符合输入文本描述的图像上。相比…

HTB:Three[WriteUP]

使用OpenVPN连接并启动机器 1.How many TCP ports are open? 使用nmap对靶机进行扫描&#xff1a;nmap -sV 10.129.233.85 可见仅开启了 22、80 共2个端口 2.What is the domain of the email address provided in the "Contact" section of the website? 直接对…

探索自闭症寄宿学校:为孩子的未来铺设坚实基石

在自闭症儿童教育的广阔天地中&#xff0c;寄宿学校以其独特的教育模式和全方位的关怀体系&#xff0c;为这些特殊孩子提供了一个安全、稳定且充满爱的成长环境。这些学校不仅关注孩子们的学习与康复&#xff0c;更致力于培养他们独立生活的能力&#xff0c;为他们的未来铺设坚…

java 解析excel (网络资源)

在Java中解析Excel文件&#xff0c;可以使用Apache POI库。以下是一个简单的例子&#xff0c;展示如何使用Apache POI读取一个Excel文件&#xff08;假设为.xlsx格式&#xff09;的内容。 首先&#xff0c;确保你的项目中包含了Apache POI的依赖。如果你使用Maven&#xff0c;…

【muduo源码分析】「阻塞」「非阻塞」「同步」「异步」

欢迎来到 破晓的历程的 博客 ⛺️不负时光&#xff0c;不负己✈️ 文章目录 引言何为「muduo库」安装muduo库阻塞、非阻塞、同步、异步数据准备数据准备 引言 从本篇博客开始&#xff0c;我会陆续发表muduo库源码分析的相关文章。感谢大家的持续关注&#xff01;&#xff01;…