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

C#版OPOS打印(基于北洋OPOS SDK二次开发包,支持EPSON和北洋、佳博、商祺等支持标准ESC/POS指令的POS打印机) 收藏C#版OPOS打印基于北洋OPOS SDK二次开发包,支持EPSON和北洋、佳博、商祺等支持标准ESC/POS指令的POS打印机支持并口,串口,网口,USB口,驱动方式等多种端口支持开关钱箱支持条码打印SDK中支持的其他设备的控制(扫描枪等)北洋SDK中只有VB...
摘要由CSDN通过智能技术生成

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
支持所有标准ESC/POS指令打印机北洋商祺支持串口、并口、USB、网口 1.4是目前最新的公用本了,其它后续本都有厂家的标示 含DLL文件,帮助,VB/VC/DELPHI例程 下边是POS_OPEN函数原型 HANDLE POS_Open(LPCTSTR lpName, int nComBaudrate, int nComDataBits, int nComStopBits, int nComParity, int nParam) 描述 打开端口。 参数 lpName [in] 指向以 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地址,打印时参考“网络打印简介”。 nComBaudrate [in] 指定串口的波特率(bps)。 可以为以下值之一: 2400,4800,9600,19200,38400,57600,115200等。 具体的值与打印机的端口参数有关,不过最大不应超过256000。 nComDataBits [in] 指定串口通讯时的数据位数。 可以为 5 到 8。 具体的值与打印机的端口参数有关。 nComStopBits [in] 指定串口通讯时的数据停止位数。 可以为以下值之一: Flag Value Meaning POS_COM_ONESTOPBIT 0x00 停止位为1 POS_COM_ONE5STOPBITS 0x01 停止位为1.5 POS_COM_TWOSTOPBITS 0x02 停止位为2 nComParity [in] 指定串口的奇偶校验方法。 可以为以下值之一: Flag Value Meaning POS_COM_NOPARITY 0x00 无校验 POS_COM_ODDPARITY 0x01 奇校验 POS_COM_EVENPARITY 0x02 偶校验 POS_COM_MARKPARITY 0x03 标记校验 POS_COM_SPACEPARITY 0x04 空格校验 nParam [in] 指定串口的流控制(握手)方式、或表示通讯方式。请参考参数lpName的说明。 可以为以下值之一: Flag Value Meaning POS_COM_DTR_DSR 0x00 流控制为DTR/DST POS_COM_RTS_CTS 0x01 流控制为RTS/CTS POS_COM_XON_XOFF 0x02 流控制为XON/OFF POS_COM_NO_HANDSHAKE 0x03 无握手 POS_OPEN_PARALLEL_PORT 0x12 打开并口通讯端口 POS_OPEN_BYUSB_PORT 0x13 打开USB通讯端口 POS_OPEN_PRINTNAME 0X14 打开打印机驱动程序 POS_OPEN_NETPORT 0x15 打开网络接口 其前两项也统称为硬件流控制,一般选用 RTS/CTS 方式。 返回值 如果函数调用成功,返回一个已打开的端口句柄。 如果函数调用失败,返回值为 INVALID_HANDLE_VALUE (-1)。 备注 1.如果打开的是并口(LPT1,LPT2等),那么后面的参数 nComBaudrate,nComDataBits,nComStopBits,nComParity将被忽略,可以设置为0,并且参数nParam必需指定为POS_OPEN_PARALLEL_PORT。同样,打开USB端口或打印机驱动程序,nParam必需指定为相应的参数修改。 2.如果由 lpName 指定的通讯端口被其他程序占用,那么返回值为 INVALID_HANDLE_VALUE。 3.如果参数出错,也返回INVALID_HANDLE_VALUE。 4.如果通讯端口已经打开,则会尝试关闭已经打开的端口,然后再去打开。 5.如果参数nParam指定打开USB端口,则需要安装随机附带的端口驱动程序,并把打印机配置为支持USB端口模式。 6.另请参考 POS_Close,POS_Reset。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值