uniapp 微信小程序小票打印机打印教程(超详细讲解) 完整代码,下载后可直接使用

这篇具有很好参考价值的文章主要介绍了uniapp 微信小程序小票打印机打印教程(超详细讲解) 完整代码,下载后可直接使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

天梦星官网 (tmxkj.top)https://tmxkj.top/#/  编程资源

直接上代码:

           ly_text:"点击搜索",
		   connected_ly:false,//蓝牙按钮是否显示
	       blue_list_ly:false,//蓝牙连接列表显示
           discoveryStarted: false,
		   devices: [],//设备列表
	    	name: '',
	    	deviceId: '',
	       chs: [],
	    	canWrite: false,
	
/**
			 * 第一步
			 * @param {打开蓝牙}
			 * @param {搜索}
			 */
			openBluetoothAdapter() {
				if (!wx.openBluetoothAdapter) {
					wx.showModal({
						title: '提示',
						content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。'
					})
					return
				}
				/**
				 * 初始化蓝牙模块
				 */
			this.openBluetoothAdapters()
			},
			/**
			 * 第二步
			 * @param {初始化蓝牙模块}  
			 * @param {请求打开蓝牙}
			 */
			openBluetoothAdapters() {
				this.ly_text="搜索设备中"
				uni.openBluetoothAdapter({//请求打开蓝牙情况
					success: (res) => {
						this.startBluetoothDevicesDiscovery();//打开蓝牙后 开始搜索
					},
					fail: (err) => {
						if (err.errCode === 10001) {
							uni.showModal({
								title: '错误',
								content: '未找到蓝牙设备,请打开蓝牙重试!',
								showCancel: false
							});
							uni.onBluetoothAdapterStateChange(res => {
								console.log('请求打开蓝牙失败再次请求', res);
								if (res.available) {
									uni.onBluetoothAdapterStateChange(() => {});
									this.startBluetoothDevicesDiscovery();
								}
							})
						}
					}
				});
			},
			/**
			 * 第三步
			 * @param {开始搜寻附近的蓝牙外围设备}  
			 */		
			startBluetoothDevicesDiscovery() {
				this.discoveryStarted = true
				uni.startBluetoothDevicesDiscovery({
					success: (res) => {
						this.onBluetoothDeviceFound();//蓝牙搜索成功后监听搜索
					},
					fail: (res) => {
						console.log('搜索蓝牙失败', res)
					}
				})
			 },
			
			/**
			 * 第四步
			 * @param {监听寻找到新设备的事件} 
			 * @param {最终得到最后的蓝牙连接列表}
			 * @param {搜素事件到此结束}
			 */
			onBluetoothDeviceFound() {
				uni.onBluetoothDeviceFound(res => {
					//res:发现的设备列表
					res.devices.forEach(device => {
						if (!device.name && !device.localName) {
							return
						}
						let foundDevices = this.devices;
						let idx = this.inArray(foundDevices, 'deviceId', device.deviceId);
						let data = {};
						if (idx === -1) {
							this.devices.push(device);
						} else {
							this.devices[index] = device;
						}
					})
					if(this.devices.length>=1){
						this.blue_list_ly=true;
						this.ly_text="发现设备"
					}else{
						// uni.showToast({
						// 	title:'暂无搜索内容',
						// 	icon:'error'
						// })
						this.ly_text="未发现设备"
					}
					console.log('发现的设备列表:', this.devices);
				})
			},
			/**
			 * 第五步
			 * @param {手动点击连接蓝牙事件}
			 * @param {创建连接蓝牙}
			 * @param {如果已经连接过可直接连接}
			 */			
			_createBLEConnection(e) {
				uni.createBLEConnection({
					deviceId:e.deviceId,
					success: (res) => {
						this.blue_list_ly=false;
						this.connected_ly=true;
						this.ly_text="已连接";
						this.name = e.name;
						this.deviceId =e.deviceId;
						//获取蓝牙
						this.getBLEDeviceServices(e.deviceId);
						uni.setStorage({
							key: LAST_CONNECTED_DEVICE,
							data: {
								name:e.name,
								deviceId:e.deviceId
							}
						})
					},
					fail: (err) => {
						this.connected_ly =false;
						this.ly_text="连接失败";
					}
				})
				this.stopBluetoothDevicesDiscovery();
			},				
			/**
			 * 第六步
			 * @param {蓝牙连接成功关闭监听搜索}
			 * @param {蓝牙搜索比较消耗资源}
			 */	
		    stopBluetoothDevicesDiscovery() {
		    	wx.stopBluetoothDevicesDiscovery({
		    		complete: () => {
		    			console.log('停')
		    			this.discoveryStarted = false
		    		}
		    	})
		    },
			/**
			 * 第七步
			 * @param {蓝牙连接成功关闭搜索}
			 * @param {功能}
			 */	
			closeBLEConnection(e) {
				uni.closeBLEConnection({
					deviceId: e.deviceId
				})
			   this.connected_ly=false;
			},
			/**
			 * 第八步
			 * @param {蓝牙功能查询}
			 * @param {蓝牙连接成功后}
			 * @param {找到主要服务功能}
			 */	
			getBLEDeviceServices(deviceId) {
				uni.getBLEDeviceServices({
					deviceId,
					success: (res) => {
						for (let i = 0; i < res.services?.length; i++) {
							if (res.services[i].isPrimary) {
								this.getBLEDeviceCharacteristics(deviceId, res.services[i].uuid);
								return
							}
						}
					}
				})
			},
			/**
			 * 第九步
			 * @param {蓝牙功能特征查询}
			 * @param {主要功能的特性}
			 * @param {找到主要服务功能的特征}
			 * @param {到此步骤连接结束}
			 */	
			getBLEDeviceCharacteristics(deviceId, serviceId) {
				uni.getBLEDeviceCharacteristics({
					deviceId,
					serviceId,
					success: (res) => {
						for (let i = 0; i < res.characteristics?.length; i++) {
							const item = res.characteristics[i]
							if (item.properties.write) {
								this.canWrite = true;
								this._deviceId = deviceId
								this._serviceId = serviceId
								this._characteristicId = item.uuid
							   uni.setStorage({
							   	key: "BlueKey",
							   	data: {
									_close:true,
									_name:this.name,
									_deviceId : deviceId,
									_serviceId : serviceId,
									_characteristicId : item.uuid,
							   	}
							   })
								break;
							}
						}
						setTimeout(()=>{
							if (this.canWrite) {
							  this.connected_ly=true;
							  this.ly_text="已连接"
						} else {
							uni.showToast({
								icon: 'error',
								title: '您当前选择的设备不支持打印功能,请重新选择!',
								duration: 3000
							})
						}
						},1000)
					},
					fail: (res) => {
						console.error('获取蓝牙特征失败', res)
					}
				})
			},
			/**
			 * 第十步
			 * @param {编写蓝牙需要打印的内容}
			 * @param {打印按钮的事件}
			 * @param {打印功能前准备}
			 */	
			writeBLECharacteristicValue() {
			   var that=this
		     	setTimeout(() => {
				let printerJobs = new PrinterJobs();
				let dayun1 = '当事人 (单位):' + this.listObj?.contactinfo?.client + '\r\n' +
							'被处罚人姓名:' + this.listObj?.contactinfo?.name + '\r\n' +
							'被处罚人性别:' + this.listObj?.contactinfo?.sex + '\r\n' +
							'被处罚人联系方式:' + this.listObj?.contactinfo?.iPhone + '\r\n' +
							'被处罚人身份证号码:' + this.listObj?.contactinfo?.idcard + '\r\n' 
							
				printerJobs
					.setSize(2, 2)
					.setAlign('CT')
					.print('! 0 100 203 100 1\r\n法决定书\r\nPRINT\r\n')
					.setSize(1, 1).setAlign('LT')
					.print(dayun1)
				
			
			
				let buffer = printerJobs.buffer();
				// console.log('ArrayBuffer', 'length: ' + buffer.byteLength, ' hex: ' + this.ab2hex(
				// 	buffer));
				// 1.并行调用多次会存在写失败的可能性
				// 2.建议每次写入不超过20字节
				// 分包处理,延时调用
				const maxChunk = 20;
				const delay = 20;
				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._writeBLECharacteristicValue, j * delay, subPackage);
				}
			
				this.lanyardShow = false;
				this.$refs.uUpload.clear();
				this.clearFormData();
				uni.showToast({
					title: '打印成功',
					icon: 'success'
				})
			}, 5000)
									
			},
						
			/**
			 * 第十一步
			 * @param {最终的打印}
			 * @param {由第十步骤调用}
			 * @param {轮询打印}
			 * @param {打印机输出}
			 * @param {打印结束}
			 */	
			_writeBLECharacteristicValue(buffer) {
				wx.writeBLECharacteristicValue({
					deviceId: this._deviceId,
					serviceId: this._serviceId,
					characteristicId: this._characteristicId,
					value: buffer,
					success(res) {
						console.log('最后执行打印了===========', res)
					},
					fail(res) {
						console.log('打印失败', res)
					}
				})
			},
			/**
			 * 第十二步
			 * @param {蓝牙相关事件}
			 * @param {和以上打印不衔接}
			 * @param {关闭蓝牙}
			 */		
			closeBluetoothAdapter() {
				wx.closeBluetoothAdapter()
				this.discoveryStarted = false
			},
			/**
			 * 第十三步
			 * @param {判断蓝牙是否已经连接}
			 * @param {只支持wx. 不支持uni.}
			 * @param {只支持安卓, 不支持苹果}
			 */	
			isBluetoothDevicePaired(){
				  var that =this
					wx.isBluetoothDevicePaired({
					deviceId:uni.getStorageSync("BlueKey")?._deviceId,
				    success(res){
						console.log(res,"判断连接成功")
						that.connected_ly=true;
						that.ly_text="连接成功"
					},fail(err){
						console.log(err,"判断连接失败");
						that.ly_text="点击搜索"
					}
				})
				
			},	
			/**
			 * 第十四步
			 * @param {蓝牙相关资源事件}
			 * @param {搜索 资源 打印}
			 * @param {转换}
			 */	
			inArray(arr, key, val) {
				for (let i = 0; i < arr.length; i++) {
					if (arr[i][key] === val) {
						return i
					}
				}
				return -1
			},
			ab2hex(buffer) {	// ArrayBuffer转16进度字符串示例
				const hexArr = Array.prototype.map.call(
					new Uint8Array(buffer),
					function(bit) {
						return ('00' + bit.toString(16)).slice(-2)
					}
				)
				return hexArr.join(',')
			},	
			str2ab(str) {
				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;
			},
			/**
			 * 第十五步
			 * @param {进入页面就自动连接}
			 * @param {该方法存在BUG}
			 * @param {目前该方法先不投放使用}
			 */	
		    createBLEConnectionWithDeviceId(e) {
		      //创建蓝牙链接
		       uni.openBluetoothAdapter({
		       	success: (res) => {
		       		let ly_data={
		       			name:uni.getStorageSync("BlueKey")?._deviceId,
		       			deviceId:uni.getStorageSync("BlueKey")?._name
		       		}
		       		this._createBLEConnection(ly_data);
		       	},
		       	fail: (res) => {
		       		if (res.errCode === 10001) {
		       			uni.showModal({
		       				title: '错误',
		       				content: '未找到蓝牙设备, 请打开蓝牙后重试。',
		       				showCancel: false
		       			});
		       			this.connected_ly=false
		       		} else if (res.errCode === -1 || res.errCode === 10010) { //已连接
		       			this.connected_ly = true;
		       		}
		       	}
		       })
		    },
		    
			/**
			 * 第十六步
			 * @param {获取蓝牙适配状态}
			 * @param {在蓝牙连接成功后调用查看}
			 * @param {判断连接用}
			 */	
			getBluetoothAdapterState() {
				wx.getBluetoothAdapterState({
					success: (res) => {
						console.log(res)
						if(res.available){
							this.connected_ly=true
							this.ly_text="已连接"
							console.log("蓝牙已经连接",res)
						}else{
							this.connected_ly=false;
							this.ly_text="点击连接"
							console.log("蓝牙已经断开")
						}
					}
				})
			},
				
			

html

	<view class="ly-cass-box">
		  <view class="ly-cass"  @click="openBluetoothAdapter()">
		   <image src="../../static/bluetooth.png" style="width: 70rpx;height: 70rpx;" />
	 	  </view>
		 <text class="ly-text">{{ly_text}}</text>
		</view>
		
		<u-popup v-model="blue_list_ly" mode="center" border-radius="14" mask-close-able=false closeable=true
			width=85%>
			<view style="margin: 80rpx 20rpx 30rpx 20rpx;">
			<view class="has-devices-list-container">
				<view class="tip-search">搜索到的设备</view>
				<view class="devices-list">
					<view v-for="(item,index) in devices" :key="index" class="devices-item">
						<view>{{item.name ? item.name : item.localName}}</view>
						<u-button size="mini" type="warning" @click="_createBLEConnection(item)">
							连接
						</u-button>
					</view>
				</view>
			</view>
			</view>
		</u-popup>
	

css

	.ly-cass-box{
		width: 150rpx;
		height: auto;
		display: flex;
		align-items: center;
		justify-content: center;
		flex-direction: column;
		position: fixed;
		bottom:70rpx;
		right: 50rpx;
		z-index: 500;
	}
	.ly-cass{
		width: 120rpx;
		height: 120rpx;
		background-color: #f4f4f5;
		border-radius: 50%;
        display: flex;
		align-items: center;
		justify-content: center;
	}
	.ly-text{
	  margin-top: 20rpx;
	  background-color: #eee;
	  padding: 2rpx 8rpx 2rpx 8rpx;
	  border-radius: 6rpx;
	  font-size: 25rpx;
	}
	

 	.no-open-gps-tip {
		width: 100%;
		display: flex;
		flex-direction: row;
		align-items: center;
		color: #fa3534;
		font-weight: 400;
		font-size: 30rpx;
		background: rgba(235, 207, 48, 0.8);
		padding: 30rpx;
	}
	.devices-item {
		width: 100%;
		display: flex;
		justify-content: space-between;
		margin-top: 20rpx;
		align-items: flex-end;
		padding-bottom: 5rpx;
		border-bottom: 1px solid #f4f4f5;
	}

	.devices-list {
		width: 100%;
		padding: 0 20rpx;
		display: flex;
		flex-direction: column;

	}

	.tip-search {
		width: 100%;
		margin: 20rpx 0;
		text-align: left;
		font-size: 16px;
		color: #2979ff;
	}

	.has-devices-list-container {
		width: 100%;
		display: flex;
		flex-direction: column;
		margin: 30rpx 0;
	}



打印执行的方法(这个方法已经封装好调用即可)

const PrinterJobs = require('./common/printer/printerjobs');//根据自己放的路径调用
const printerUtil = require('./common/printer/printerutil');//根据自己放的路径调用

目录结构

uniapp实现打印功能,uni-app,微信小程序,小程序,javascript

 核心代码代码下载

备注:核心代码在头顶上的zip当中

使用逻辑:

1.用户第一次进来点击连接,只用连接一次,只要用户不关闭程序就不会断开,可接着打印,

2.如果已经连接需要在主动加载函数里面调用判断是否已经连接文章来源地址https://www.toymoban.com/news/detail-610380.html

到了这里,关于uniapp 微信小程序小票打印机打印教程(超详细讲解) 完整代码,下载后可直接使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序连接蓝牙汉印HM-A300L标签打印机

    需求: 以下文章针对打印一讲解,打印二的代码放在最后。 打印一 打印二 参考文章: 微信小程序实现蓝牙打印 打印机CPCL编程参考手册(CPCL 语言) 蓝牙打印机CPCL编程手册~汉印HM-A300 无用小知识: A300系列:先将打印机关机然后装好纸,同时按住屏幕左右两边的按键不放,

    2024年01月18日
    浏览(53)
  • js、PHP连接外卖小票机打印机方案(调用佳博、芯烨等)

    前言:         目前开发需要用到电脑直接连接外卖小票机打印小票,查阅各种资料,使用 6612345浏览器 终于解决了这个问题。 效果:         PHP、js直接连接小票机并且自动出票。 支持的小票机:          目前测试可以的有:电脑A4打印机、佳博GP58MBIII(USB直

    2024年02月11日
    浏览(42)
  • 惠普m1136打印机驱动程序安装教程

    惠普m113打印机是一款功能强大的多功能打印机,它能够打印、复印、扫描和传真等。如果你要使用这款打印机,你需要下载并安装驱动程序,以确保它能够在你的计算机上正常工作。在本文中,我们将介绍如何下载和安装惠普m1136打印机驱动程序。 一.惠普m1136打印机驱动 惠

    2024年02月09日
    浏览(59)
  • 前端js,uniapp使用printease连接打印机打印,打印命令生成

    接下来我们将使用printease实现前端js,uniapp打印。 此外,连接打印机的方式有很多种,这里并不会涉及到,该库只是提供了一种打印机指令的生成方式,你可以将生成的指令发送到打印机,打印机会执行一次印刷过程。 这个教程是关于tspl指令的,如果你使用的其他指令,可

    2024年02月13日
    浏览(58)
  • mac Canon打印机连接教程(附打印机驱动下载)

    网上大多是windows版驱动和安装教程,mac链接相对参考材料较少,记录于此方便节省大家时间。本篇以Canon iR C3025打印机为例,流程大同小异。

    2024年02月12日
    浏览(72)
  • 小程序商品如何指定打印机

    有些商家,可能有多个仓库。不同的仓库,存放不同的商品。当客户下单时,小程序如何自动按照仓库拆分订单,如何让打印机自动打印对应仓库的订单呢?下面就来介绍一下吧。 1. 设置订单分发模式。进入管理员后台,在待处理订单后面点击设置图标按钮(仅超级管理员能

    2024年02月12日
    浏览(40)
  • 3D 打印机 G 代码命令:完整列表和教程

    查看原文 了解 G 代码命令将开启 3D 打印的下一个层次。继续阅读以快速了解此代码的基础知识! 内容 它是什么? 3D 打印的重要命令 G0 G1:直线运动 G90 G91:绝对和相对定位 G28 和 G29:汽车家庭和床调平 M104、M109、M140 和 M190:设定温度 M106 M107:风扇控制 程序结构 阶段 1:初

    2024年02月03日
    浏览(48)
  • 安装打印机驱动程序的操作步骤,详细方法介绍

    安装打印机驱动程序是使用打印机的前提条件,因此学会正确的安装方法是非常重要的。下面是安装打印机驱动程序的详细步骤分析,为你全面的讲解安装和出现故障如何处理等问题。 一.安装打印机的准备工作 在安装打印机驱动程序之前,需要先准备好一些必要的工具和信

    2024年02月09日
    浏览(71)
  • OpenWrt网络打印机TCP/IP共享设置教程——以703N为例(PCL)

    在本教程中,我们将探讨如何在OpenWrt路由器上设置TCP/IP共享以实现打印机的网络共享。我们以OpenWrt路由器型号703N为例,并使用PCL作为打印机的语言。 步骤1:准备工作 首先,确保你已经在OpenWrt路由器上安装了最新版本的OpenWrt固件,并且已经连接到你的网络。另外,确保你

    2024年02月08日
    浏览(82)
  • 惠普官网驱动程序与软件下载,如何安装打印机驱动

    惠普(HP)是一家全球知名的计算机硬件制造商,其产品涵盖台式电脑、笔记本电脑、打印机、扫描仪等。为了保证产品的正常运行和最佳性能,惠普为其设备提供了驱动程序和软件的下载服务。本文将介绍如何在惠普官网下载所需的驱动程序和软件。 一.查找你的产品型号

    2024年02月09日
    浏览(75)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包