TSC打印机打印条形码和二维码,JS实现方式

时间:2024-02-21 19:10:39

自上一篇TSC打印条形码和二维码的文章发布以来,有不 少网友咨询相关技术,

今天全部整理一下,实现的源码和文件也全部公开。

 

-- 2019.03.28  整理最新的js打印的实现方式

 

说明:

1、以下为JS的实现方式,实现相对简单很多。

2、applet的实现方式比较复杂,几乎没有优点,不建议使用。估计不少人applet的jar包也弄不出来。

3、打印前需要先注册 ocx控件,只支持IE浏览器。

4、TSC applet和js打印测试包(包含打印机驱动、打印插件、applet和js调试代码),http://www.xinac.com/front/article/4253.html

5、有问题请尽量发邮件,[email protected]

 

客户端打印配置说明(每个需要打印的客户端都需要配置):

1、连接TSC打印机。网络共享打印机的方式没试过,有试过的可以反馈一下。

2、下载打印机驱动和打印控件。

3、安装打印机驱动,注册打印插件。

4、打开IE浏览器(只能用IE或其他浏览器的兼容模式),修改“Internet选项→安全→自定义级别”,把ActiveX相关的都启用。

5、访问系统,点击打印按钮。

6、正常情况下,打印机被调起并打印一张条码。

 

-- 打印按钮事件,点击按钮后将参数传到打印页面,这样的好处是:只需要将打印页用IE打开即可

// 打印条码
Asset.print = function () {
	// 资产名称
	var _name = \'\';
	// 资产编号
	var _code = \'\';
	// 部门
	var _depart = \'\';
	// 产品规格/型号
	var _model = \'\';
	// 领用日期
	var _receiveDate = \'\';
	// 判断是否选中
	if (this.check()) {
		_name = Asset.seItem["name"];
		_code = Asset.seItem["code"];
		_depart = Asset.seItem["department"];
		_model = Asset.seItem["model"];
		_receiveDate = Asset.seItem["receiveDate"];
		if(isNotNull(_name) && isNotNull(_code) && isNotNull(_depart) && isNotNull(_model) && isNotNull(_receiveDate)){
			window.open("/static/tsc_print.html?arg1=" + encodeURI(_name) + "&arg2=" + encodeURI(_code) + "&arg3=" + encodeURI(_depart) + "&arg4=" + encodeURI(_model) + "&arg5=" + encodeURI(_receiveDate), "_blank");
		}else{
			alert("内容不能为空!");
		}
	}
};

-- 打印页,接收打印参数并调用打印机接口完成打印

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<title>固定资产标识卡打印</title>
		<style type="text/css">
			table {
				border: 1px solid #0997D6;
				border-collapse: collapse;
				font-famliy: \'宋体\';
				font-size: 14px;
				text-align: center;
				margin: 0 auto;
			}
			th {
				border: 1px solid #0997D6;
				text-align: center;
				height: 30px;
			}
			td {
				border: 1px solid #0997D6;
			}
			tr.version {
				background: #C6E6FF;
			}
		</style>
	</head>
	<body>
		<h1 style="text-align: center;">打印条码</h1>
		<h3 style="text-align: center; color: red;">【请使用IE浏览器或兼容模式打开此页面】</h3>
		<br>
		<br>
		<table>
			<tr class="version">
				<th colspan="2" style="">固定资产标识卡</th>
			</tr>
			<tr>
				<th style="width: 150px;">资产名称</td>
				<td style="width: 300px;"><span id="name"></span></td>
			</tr>
			<tr>
				<th>资产编号</td>
				<td><span id="code"></span></td>
			</tr>
			<tr>
				<th>使用部门</td>
				<td><span id="depart"></span></td>
			</tr>
			<tr>
				<th>型号规格</td>
				<td><span id="model"></span></td>
			</tr>
			<tr>
				<th>领用日期</td>
				<td><span id="date"></span></td>
			</tr>
		</table>
	</body>
	
	    <script type="text/javascript">
                    urlinfo = window.location.href; //获取当前页面的url 
		    len = urlinfo.length;
		    offset = urlinfo.indexOf("?");
		    newsidinfo = urlinfo.substr(offset, len);
		    newsids = newsidinfo.split("&");
		    var _name = newsids[0].split("=")[1];
		    var _code = newsids[1].split("=")[1];
		    var _depart = newsids[2].split("=")[1];
		    var _model = newsids[3].split("=")[1];
		    var _receiveDate = newsids[4].split("=")[1];
		    _receiveDate = _receiveDate.substring(0, 10);
		    // 显示参数内容
		    document.getElementById("name").innerHTML = decodeURI(_name);
		    document.getElementById("code").innerHTML = decodeURI(_code);
		    document.getElementById("depart").innerHTML = decodeURI(_depart);
		    document.getElementById("model").innerHTML = decodeURI(_model);
		    document.getElementById("date").innerHTML = decodeURI(_receiveDate);
		    
		    // 打印条形码和二维码
                    var TSCObj;
		    TSCObj = new ActiveXObject("TSCActiveX.TSCLIB");
		    TSCObj.ActiveXopenport("TSC TTP-244 Pro");
		    TSCObj.ActiveXsetup("60", "40", "5", "12", "0", "2", "0");
		    TSCObj.ActiveXsendcommand("SET TEAR ON");
		    TSCObj.ActiveXclearbuffer();
		    TSCObj.ActiveXwindowsfont(230, 310, 48, 180, 2, 0, "Arial", "固定资产标识卡");
		    TSCObj.ActiveXwindowsfont(500, 305, 48, 180, 2, 1, "Arial", "                                          ");
		    TSCObj.ActiveXwindowsfont(450, 250, 30, 180, 2, 0, "Arial", "资产名称:" + decodeURI(_name));
		    TSCObj.ActiveXwindowsfont(450, 220, 30, 180, 2, 0, "Arial", "资产编号:" + decodeURI(_code));
		    TSCObj.ActiveXwindowsfont(450, 190, 30, 180, 2, 0, "Arial", "使用部门:" + decodeURI(_depart));
		    TSCObj.ActiveXwindowsfont(450, 160, 30, 180, 2, 0, "Arial", "型号规格:" + decodeURI(_model));
		    TSCObj.ActiveXwindowsfont(450, 130, 30, 180, 2, 0, "Arial", "领用日期:" + decodeURI(_receiveDate));
		    TSCObj.ActiveXbarcode("450", "90", "128", "60", "1", "180", "2", "2", decodeURI(_code));
                    TSCObj.ActiveXsendcommand("QRCODE 12,10,L,3,A,0,M2,S3,\"http://cary.tech/qrCode?code=" + decodeURI(_code) + "\"");
		    TSCObj.ActiveXprintlabel("1", "1");
		    TSCObj.ActiveXcloseport();
		</script>
		
</html>

打印页效果:

打印效果: