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