c# 中崎_C#版OPOS打印(基于北洋OPOS SDK二次开发包,支持EPSON和北洋、佳博、商祺等支持标准ESC/POS指令的POS打印机)...

该博客介绍了如何使用C#进行OPOS打印,基于北洋OPOS SDK,支持EPSON、北洋、佳博等打印机。内容包括打开不同端口(串口、并口、USB、网络)、打印控制、位图打印、切纸功能、以及错误处理等。还提供了代码示例,展示了如何进行串口、并口、USB口和网络接口的打开与关闭。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C#版OPOS打印(基于北洋OPOS SDK二次开发包,支持EPSON和北洋、佳博、商祺等支持标准ESC/POS指令的POS打印机) 收藏

C#版OPOS打印

基于北洋OPOS SDK二次开发包,支持EPSON和北洋、佳博、商祺等支持标准ESC/POS指令的POS打印机

支持并口,串口,网口,USB口,驱动方式等多种端口

支持开关钱箱

支持条码打印

SDK中支持的其他设备的控制(扫描枪等)

北洋SDK中只有VB和Delphi的例程,所以参照Delphi转成了C#的版本,并集成到软件中实际应用。希望给需要了解C#使用OPOS SDK开发的朋友提供一些帮助。

废话少说,直接上代码。

using System;

using System.Collections.Generic;

using System.Text;

using System.Runtime.InteropServices;

using System.IO.Ports;

namespace RMSPOS

{

///

/// 北洋OPOS指令集二次开发包DLL调用

///

/// 备注:

/// 因为北洋的demo包里没有C#的,所以参考delphi包的代码转成了C#的.

/// 北洋的dll支持市面上所有的 支持ESC/ POS指令的小票打印机的打印(EPSON,佳博,中崎等)

///

/// 如果有任何修改请邮件通知本人,欢迎志同道合的朋友共同交流;

/// coder: 萧远峰  mail: 71008973@qq.com

///

/// POSDLL 动态库的出口函数是用来直接控制 POS 打印机工作的,

/// 分为四个部分:通用函数、标准模式打印函数、页模式打印函数、调试等函数。

///

public class BeiYangOPOS

{

const string _DllVer = "1.4";

///

/// 获取动态库版本号

///

public string GetDllVer

{

get { return _DllVer;}

}

///

/// 设备打开后的句柄

///

public IntPtr POS_IntPtr;

///

/// 函数返回值

///

public uint POS_SUCCESS = 1001;//  函数执行成功

public uint POS_FAIL = 1002;   //  函数执行失败

public uint POS_ERROR_INVALID_HANDLE = 1101; // 端口或文件的句柄无效

public uint POS_ERROR_INVALID_PARAMETER = 1102;// 参数无效

public uint POS_ERROR_NOT_BITMAP = 1103 ; // 不是位图格式的文件

public uint POS_ERROR_NOT_MONO_BITMAP = 1104;// 位图不是单色的

public uint POS_ERROR_BEYONG_AREA = 1105 ;//位图超出打印机可以处理的大小

public uint POS_ERROR_INVALID_PATH = 1106; // 没有找到指定的文件路径或名

///

/// 停止位

///

public uint POS_COM_ONESTOPBIT = 0x00;//停止位为1

public uint POS_COM_ONE5STOPBITS = 0x01;//停止位为1.5

public uint POS_COM_TWOSTOPBITS = 0x02;//停止位为2

///

/// 奇偶校验

///

public uint POS_COM_NOPARITY = 0x00;//无校验

public uint POS_COM_ODDPARITY = 0x01;//奇校验

public uint POS_COM_EVENPARITY = 0x02;//偶校验

public uint POS_COM_MARKPARITY = 0x03;//标记校验

public uint POS_COM_SPACEPARITY = 0x04;//空格校验

///

/// 其他COM口参数及端口类型定义

///

public uint POS_COM_DTR_DSR = 0x00;// 流控制为DTR/DST

public uint POS_COM_RTS_CTS = 0x01;// 流控制为RTS/CTS

public uint POS_COM_XON_XOFF = 0x02;// 流控制为XON/OFF

public uint POS_COM_NO_HANDSHAKE = 0x03;//无握手

public uint POS_OPEN_PARALLEL_PORT = 0x12;//打开并口通讯端口

public uint POS_OPEN_BYUSB_PORT = 0x13;//打开USB通讯端口

public uint POS_OPEN_PRINTNAME = 0X14;// 打开打印机驱动程序

public uint POS_OPEN_NETPORT = 0x15;// 打开网络接口

public uint POS_CUT_MODE_FULL = 0x00;// 全切

public uint POS_CUT_MODE_PARTIAL = 0x01;// 半切

///

/// 打开POS机的端口 开始会话

///

///

///指向以 null 结尾的打印机名称或端口名称。

///当参数nParam的值为POS_COM_DTR_DSR、POS_COM_RTS_CTS、POS_COM_XON_XOFF或POS_COM_NO_HANDSHAKE 时, “COM1”,“COM2”,“COM3”,“COM4”等表示串口;

///当参数nParam的值为POS_OPEN_PARALLEL_PORT时,“LPT1”,“LPT2”等表示并口;

///当参数nParam的值为POS_OPEN_BYUSB_PORT时,“BYUSB-0”、“BYUSB-1”、“BYUSB-2”、“BYUSB-3”等表示USB端口。

///当参数nParam的值为POS_OPEN_PRINTNAME时,表示打开指定的打印机。

///当参数nParam的值为POS_OPEN_NETPORT时,表示打开指定的网络接口,如“192.168.10.251”表示网络接口IP地址

/// 串口通信需要的波特率

/// 串口通信需要的数据位

/// 串口通信需要的停止位

/// 串口通信需要的是否要奇偶校验

/// 指向以 null 结尾的打印机名称或端口名称。

/// 参数nParam的值为POS_COM_DTR_DSR、POS_COM_RTS_CTS、POS_COM_XON_XOFF或POS_COM_NO_HANDSHAKE 时,

/// “COM1”,“COM2”,“COM3”,“COM4”等表示串口;

/// 当参数nParam的值为POS_OPEN_PARALLEL_PORT时,“LPT1”,“LPT2”等表示并口;

/// 当参数nParam的值为POS_OPEN_BYUSB_PORT时,“BYUSB-0”、“BYUSB-1”、“BYUSB-2”、“BYUSB-3”等表示USB端口。

/// 当参数nParam的值为POS_OPEN_PRINTNAME时,表示打开指定的打印机。

/// 如果函数调用成功,返回一个已打开的端口句柄。如果函数调用失败,返回值为 INVALID_HANDLE_VALUE (-1)。

[DllImport("POSDLL.dll", CharSet = CharSet.Ansi)]

public static extern IntPtr POS_Open([MarshalAs(UnmanagedType.LPStr)]string lpName,

uint nComBaudrate,

uint nComDataBits,

uint nComStopBits,

uint nComParity,

uint nParam);

///

/// 关闭已经打开的并口或串口,USB端口,网络接口或打印机。

///

///

[DllImport("POSDLL.dll", SetLastError = true)]

public static extern IntPtr POS_Close();

///

/// 复位打印机,把打印缓冲区中的数据清除,字符和行高的设置被清除,打印模式被恢复到上电时的缺省模式。

///

///

[DllImport("POSDLL.dll", SetLastError = true)]

public static extern IntPtr POS_Reset();

///

/// 设置打印机的移动单位。

///

/// 把水平方向上的移动单位设置为 25.4 / nHorizontalMU 毫米。可以为0到255。

/// 把垂直方向上的移动单位设置为 25.4 / nVerticalMU 毫米。可以为0到255。

///

/// 如果函数成功,则返回值为 POS_SUCCESS。

/// 如果函数失败,则返回值为以下值之一:POS_FAIL POS_ERROR_INVALID_HANDLE POS_ERROR_INVALID_PARAMETER

[DllImport("POSDLL.dll", SetLastError = true)]

public static extern IntPtr POS_SetMotionUnit(uint nHorizontalMU, uint nVerticalMU);

///

/// 选择国际字符集和代码页

///

///

/// 指定国际字符集。不同的国际字符集对0x23到0x7E的ASCII码值对应的符号定义是不同的。

/// 可以为以下列表中所列值之一。

/// 0x00 U.S.A  0x01 France  0x02 Germany  0x03 U

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值