demo代码如下:

private void btnPrint_Click(object sender, EventArgs e)
{
if (this.btnPrint.Text == "停止打印")
{
SetBtnPrintUIEnable();
return;
}
       //禁用界面上的相关按钮
SetBtnPrintUIDisable();
var dt = new DataTable();
new Task(
() =>
{
///开始的打印
//1. 获取选中的dgv源
dt = GetDgvDataSourceChecked(); if (dt.Rows.Count <= 0)
{
SetTxtMessageInfo(this.txtMessageError, "没有选中任何数据, 不能打印");
Common.Contactor.ShowErrorMessage($"没有选中任何数据, 不能打印");
SetBtnPrintUIEnable();
return;
}
Thread.Sleep(500);
SetTxtMessageInfo(this.txtMessageInfo, "数据校验中. . ."); //开始打印
string tempPath = ConfigHelper.GetConfigString("templateName"); //模板名称
Thread.Sleep(500);
SetTxtMessageInfo(this.txtMessageInfo, $"当前使用的模板名称{tempPath}"); if (string.IsNullOrEmpty(tempPath.Trim()))
{
SetTxtMessageInfo(this.txtMessageError ,$"模板文件{tempPath}可能不存在, 请调整");
Common.Contactor.ShowErrorMessage($"模板文件{tempPath}可能不存在, 请调整");
SetBtnPrintUIEnable();
return;
}
if (Path.GetExtension(tempPath).Equals("btw"))
{
SetTxtMessageInfo(this.txtMessageError, $"不支持的文件格式{tempPath}");
Common.Contactor.ShowErrorMessage($"不支持的文件格式{tempPath}");
SetBtnPrintUIEnable();
return;
} string FileName = Path.GetFileName(tempPath);
string primKey = ConfigHelper.GetConfigString("primKey");
Thread.Sleep(500);
SetTxtMessageInfo(this.txtMessageInfo, "数据校验完毕, 准备开始打印. . .");
using (Engine engine = new Engine(true))
{
engine.Start();
if (format != null)
{
format.Close(SaveOptions.DoNotSaveChanges);
}
format = engine.Documents.Open(tempPath);// 打开路径上的btw模板文件
//设置默认打印机
format.PrintSetup.PrinterName = new System.Drawing.Printing.PrintDocument().PrinterSettings.PrinterName;
format.PrintSetup.IdenticalCopiesOfLabel = printCount;// Convert.ToInt32(GetControlText(this.cboPrintCount)); //
format.PrintSetup.NumberOfSerializedLabels = 1;
var dcs = dt.Columns.Cast<DataColumn>().Select((dc) => { return dc.Caption; }).Skip(1); //将第一个跳出去; 其实第一个跳不跳都行
var templateStrs = format.SubStrings.Select((s) => { return s.Name; }).ToArray(); string diffStr = string.Join(",", templateStrs.Except(dcs)); if (diffStr.Trim().Length > 0)
{
SetTxtMessageInfo(this.txtMessageError, $"在您的模板文件 {FileName} 中, 有这些\r\n {diffStr} \r\n字段不被即将打印的内容识别, \r\n您必须调整模板或者修改数据获取语句后才能继续");
Common.Contactor.ShowErrorRestart($"在您的模板文件 {FileName} 中, 有这些\r\n {diffStr} \r\n字段不被即将打印的内容识别, \r\n您必须调整模板或者修改数据获取语句后才能继续");
SetBtnPrintUIEnable();
format = null;
return;
}
//"templateStr" value="捆号,花型,长度,重量,机台,验布工,货架号,连幅标记,纪录时间,捆号状态,电子标签日期,电子标签编号"
lock (engine) //一定要锁定打印引擎
{
for (int i = 0; i < dt.Rows.Count; i++)
{
object oPrimKey = dt.Rows[i][primKey]; //获取主键列对应的值
if (oPrimKey == DBNull.Value || oPrimKey.ToString().Length <= 0)
{
SetTxtMessageInfo(this.txtMessageError, $"主键{primKey}数据错误, 它的值不能为NULL或者空字符");
Common.Contactor.ShowErrorMessage($"主键{primKey}数据错误, 它的值不能为NULL或者空字符");
SetBtnPrintUIEnable();
format = null;
return;
}
string currentPrimkey = oPrimKey.ToString();
string tid = operatorRFIDLabel.GetRFID_TID(); //读取标签中的TID if (!RegValidate.WordOrNumber(tid))
{
SetTxtMessageInfo(this.txtMessageError, $"标签内容TID获取错误{tid}, 打印将停止");
Common.Contactor.ShowErrorMessage($"标签内容获取错误{tid}, 打印将停止");
SetBtnPrintUIEnable();
format = null;
return;
} for (int j = 0; j < templateStrs.Length; j++)
{
format.SubStrings[templateStrs[j]].Value = dt.Rows[i][templateStrs[j]].ToString(); //给打印模板中对应的参数SN赋值
}
Messages messages;
int waitForCompletionTimeout = 10000; // 10 seconds
System.Diagnostics.Trace.WriteLine("→→→→→→→→→TID是" + tid);
Result r = format.Print("", waitForCompletionTimeout, out messages);
// string messageString = "\n\nMessages:";
// Thread.Sleep(500);
SetTxtMessageInfo(this.txtMessageInfo, $"正在打印第{i + 1}份, 它的主键编号是 {oPrimKey} ");
Thread.Sleep(2000); //根据博思得打印机实测,需要停2s, 否则TID将重复
////写数据库, 不能阻塞来写库, 会影响打印机读取TID超时
queuePrint.Enqueue(string.Format(ConfigHelper.GetConfigString("updateTid"), tid, currentPrimkey.Trim())); string com = ConfigHelper.GetConfigString("insertMysql");
string HN_NO = dt.Rows[i]["花型"] == DBNull.Value ? string.Empty : dt.Rows[i]["花型"].ToString();
string GH_NO = dt.Rows[i]["捆号"] == DBNull.Value ? string.Empty : dt.Rows[i]["捆号"].ToString();
string QTY_XD = dt.Rows[i]["长度"] == DBNull.Value ? string.Empty : dt.Rows[i]["长度"].ToString();
string QTY_GJ = dt.Rows[i]["重量"] == DBNull.Value ? string.Empty : dt.Rows[i]["重量"].ToString();
string JT_NO = dt.Rows[i]["机台"] == DBNull.Value ? string.Empty : dt.Rows[i]["机台"].ToString();
string YB_NO = dt.Rows[i]["验布工"] == DBNull.Value ? string.Empty : dt.Rows[i]["验布工"].ToString();
string FJ_NO = dt.Rows[i]["货架号"] == DBNull.Value ? string.Empty : dt.Rows[i]["货架号"].ToString();
string LF_ID = dt.Rows[i]["连幅标记"] == DBNull.Value ? string.Empty : dt.Rows[i]["连幅标记"].ToString();
DateTime USR_DD = dt.Rows[i]["纪录时间"] == DBNull.Value ? DateTime.Now : Convert.ToDateTime(dt.Rows[i]["纪录时间"]);
string GH_STA = dt.Rows[i]["捆号状态"] == DBNull.Value ? string.Empty : dt.Rows[i]["捆号状态"].ToString(); string strsql = string.Format(ConfigHelper.GetConfigString("insertMysql"), tid, HN_NO, GH_NO, QTY_XD, QTY_GJ, JT_NO, YB_NO, FJ_NO, LF_ID, USR_DD, GH_STA);
queuePrint.Enqueue(strsql);
}
}
format.Close(SaveOptions.DoNotSaveChanges);
format = null;
engine.Stop(); //启动那些按钮
SetBtnPrintUIEnable();
}
}
).Start(); /*1) Print方法:这个就是最常用的打印方法,里面可设置打印的任务名,是否等待打印完成,等待超时时间,打印过程输出的信息。
2) PrintOut方法:如果你需要在打印时出现打印设置对话框和状态框,你可以选择这个方法来实现。
3) Save方法:保存对Format的更改。
4) SetNamedSubStringValue方法:设置某个特定的SubString的值,这里就可以作为一个动态改变打印内容的方法。
5) SetPromt方法:跟SetNamedSubStringValue方法类似,不过他设置的是打印提示的值,某些标签通过设置可以在打印的时候弹出对话框,输入某些变量的值来改变打印内容,这个方法就是动态设置这些变量的。不过在集成中比较少用。
6) IdenticalCopiesOfLabel属性:这个是设置打印时要打印多少份相同的标签的,默认为标签设置。
7) NumberSerializedLabels属性:这个是序列化打印时使用的,当你的标签启动了序列化后,这个属性代表的就是打印的份数,譬如你的序列化初始数据是1,增量为1,NumberSerializedLabels设置为5,那么就会打印出1、2、3、4、5,五个标签出来。
8) Printer属性:指定要使用的打印机,默认为系统指定的默认打印机
9) PrintToFile属性:标示是马上用打印机打印出实物,还是生成一个打印文件。
*/
}

  

20190626_二次开发BarTender打印机_C#代码_一边读取TID_一边打印_打印机POSTEK的更多相关文章

  1. NX二次开发-NX+VS写代码设断点调试技巧

    在做NX二次开发的时候写完代码,编译可以通过,但是执行的时候却没有反应,或者得到的结果不对,说明肯定有地方传值出错了.我在查找代码错误的时候有几种方法:1.uc1601打印函数输入和输出的值看对不对. ...

  2. 20190620_二次开发BarTender打印机时,未能解析主引用“Seagull.BarTender.Print, Version=1.0.0.0, Culture=neutral, processorArchitecture=x86”

    错误提示: 严重性 代码 说明 项目 文件 行 禁止显示状态警告 未能解析主引用"Seagull.BarTender.Print, Version=1.0.0.0, Culture=neut ...

  3. Civil 3D .NET二次开发第11章代码升级至2018版注意事项

    原来涉及2017的,均需要改为2018 原来的21改为22 代码中AeccXUiLand.AeccApplication.11.0"改为AeccXUiLand.AeccApplication ...

  4. 3.NetDh框架之缓存操作类和二次开发模式简单设计(附源码和示例代码)

    前言 NetDh框架适用于C/S.B/S的服务端框架,可用于项目开发和学习.目前包含以下四个模块 1.数据库操作层封装Dapper,支持多种数据库类型.多库实例,简单强大: 此部分具体说明可参考博客: ...

  5. 【wireshark】Wireshark原理分析与二次开发系列

    1.版权声明 本系列文章是本人花了很多心血写成,wireshark本是开源软件,本人也乐于技术知识和经验的分享,更是欣赏和推崇开源精神,因此任何看到本文的人都可以随意转载,但只有一个要求: 在大段甚至 ...

  6. kettle工具二次开发-代码启动JOB

    kettle工具是一款优秀的数据同步.数据处理的BI工具,收到了很多人的青睐.kettle软件通过可视化的图标可以让我们很轻易的能完成数据同步.处理的开发工作.但是使用kettle可视化界面在跑JOB ...

  7. Linux内核启动代码分析二之开发板相关驱动程序加载分析

    Linux内核启动代码分析二之开发板相关驱动程序加载分析 1 从linux开始启动的函数start_kernel开始分析,该函数位于linux-2.6.22/init/main.c  start_ke ...

  8. 美客分销商城-接力购源码系统,全开源代码可进行二次开发,微信小程序分销商城

    1. 准备服务器.域名(SSL证书).认证的微信小程序.微信支付商户号 2. 系统功能简介 三.演示案例,微信扫码查看 四.后台管理系统 五. 全套开源源码,进行二次开发 六.本系统完美运营,全套代码 ...

  9. SkylineDemoForWeb JavaScript二次开发示例代码

    SkylineDemoForWeb JavaScript二次开发示例代码 http://files.cnblogs.com/files/yitianhe/SkylineDemoForWeb.zip

随机推荐

  1. 排序算法—快速排序(Quick Sort)

    快速排序(Quick Sort) 快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. ...

  2. Java_三大特征相关

    重写 子类通过重写父类的方法, 可以用自身的行为替换父类的行为 重写的三个要点: "==" :方法名, 形参列表, 返回值类型相同 "<=" : 返回值类 ...

  3. 获取List集合对象中某一列属性值

    例:获取disposeList集合中CorpusMarkPage对象中的responseId属性,生成新的List集合 List<String> responseIdList = disp ...

  4. knn-demo

    from __future__ import print_functionfrom numpy import *# 导入科学计算包numpy和运算符模块operatorimport operatorf ...

  5. 线程安全之ConcurrentQueue<T>队列

    最近在弄一个小项目,大概600w行的数据,要进行数据清洗,因数据量偏大,如果单线程去执行,会造成效率偏低,只能用多线程了,但采用多线程存在线程安全问题,于是查了下资料,发现有ConcurrentQue ...

  6. TCP Persist 坚持定时器

    1.坚持定时器在接收方通告接收窗口为0,阻止发送端继续发送数据时设定. 由于连接接收端的发送窗口通告不可靠(只有数据才会确认),如果一个确认丢失了,双方就有可能因为等待对方而使连接终止: 接收放等待接 ...

  7. leetcode Reverse Nodes in k-Group翻转链表K个一组

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k  ...

  8. 幻读在 InnoDB 中是被如何解决的?(转)

    在MySQL事务初识中,我们了解到不同的事务隔离级别会引发不同的问题,如在 RR 级别下会出现幻读.但如果将存储引擎选为 InnoDB ,在 RR 级别下,幻读的问题就会被解决.在这篇文章中,会先介绍 ...

  9. VGA详解及色块碰撞示例

    引言 VGA:video Graphics array,视频图形阵列,阴极射线显像管(CRT)显示器时代产物,很多老显卡.笔记本电脑.投影仪所用接口,已经比较过时. CRT是模拟设备,所以VGA也采用 ...

  10. PID算法的C语言实现

    1.根据我控制算法类文章中关于PID的理论的一些描述,同时也根据网络上一些其他的PID文章,以及自己最近一个项目的实践后,总结了几套基于C语言的PID算法,由于网络中很少有人进行分享完整的PID算法实 ...