c# 中崎_C# 打开钱箱支持北洋、佳博、爱普生

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Runtime.InteropServices;

using System.IO.Ports;

using System.Drawing.Printing;

namespace ××××××××××××××

{

///

/// 北洋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";

private static PrintDocument fPrintDocument = new PrintDocument();

///

/// 获取动态库版本号

///

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.K. 0x04 Denmark I 0x05 Sweden

/// 0x06 Italy 0x07 Spain I 0x08 Japan 0x09 Nonway 0x0A Denmark II 0x0B Spain II

/// 0x0C Latin America 0x0D Korea

///

/// 指定字符的代码页。不同的代码页对0x80到0xFF的ASCII码值对应的符号定义是不同的。

/// 0x00 PC437 [U.S.A. Standard Europe 0x01 Reserved 0x02 PC850 [Multilingual]

/// 0x03 PC860 [Portuguese] 0x04 PC863 [Canadian-French] 0x05 PC865 [Nordic]

/// 0x12 PC852 0x13 PC858

///

///

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

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

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

public static extern IntPtr POS_SetCharSetAndCodePage(uint nCharSet, uint nCodePage);

///

/// POS字体样式

///

///

public uint POS_FONT_TYPE_STANDARD = 0x00;// 标准 ASCII

public uint POS_FONT_TYPE_COMPRESSED = 0x01;// 压缩 ASCII

public uint POS_FONT_TYPE_UDC = 0x02; // 用户自定义字符

public uint POS_FONT_TYPE_CHINESE = 0x03; // 标准 “宋体”

public uint POS_FONT_STYLE_NORMAL = 0x00; // 正常

public uint POS_FONT_STYLE_BOLD = 0x08; // 加粗

public uint POS_FONT_STYLE_THIN_UNDERLINE = 0x80; // 1点粗的下划线

public uint POS_FONT_STYLE_THICK_UNDERLINE = 0x100; // 2点粗的下划线

public uint POS_FONT_STYLE_UPSIDEDOWN = 0x200; // 倒置(只在行首有效)

public uint POS_FONT_STYLE_REVERSE = 0x400; // 反显(黑底白字)

public uint POS_FONT_STYLE_SMOOTH = 0x800; // 平滑处理(用于放大时)

public uint POS_FONT_STYLE_CLOCKWISE_90 = 0x1000; // 每个字符顺时针旋转 90 度

///

/// 把将要打印的字符串数据发送到打印缓冲区中,并指定X 方向(水平)上的绝对起始点位置,

/// 指定每个字符宽度和高度方向上的放大倍数、类型和风格。

///

/// 指向以 null 结尾的字符串缓冲区

/// 指定 X 方向(水平)的起始点位置离左边界的点数。

/// 指定字符的宽度方向上的放大倍数。可以为 1到 6。

/// 指定字符高度方向上的放大倍数。可以为 1 到 6。

/// 指定字符的字体类型。

/// 指定字符的字体风格。

///

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

public static extern IntPtr POS_S_TextOut([MarshalAs(UnmanagedType.LPStr)]string pszString,

uint nOrgx, uint nWidthTimes, uint nHeightTimes,

uint nFontType, uint nFontStyle);

///

/// 设置POS的打印模式 (只有两种 页模式和标准模式)

///

///

/// POS_PRINT_MODE_STANDARD 0x00 标准模式(行模式)

/// POS_PRINT_MODE_PAGE 0x01 页模式

/// POS_PRINT_MODE_BLACK_MARK_LABEL 0x02 黑标记标签模式

/// POS_PRINT_MODE_WHITE_MARK_LABEL 0x03 白标记标签模式

///

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

public static extern IntPtr POS_SetMode(uint nPrintMode);

///

/// 设置字符的行高。

///

/// 指定行高点数。可以为 0 到 255。每点的距离与打印头分辨率相关。

///

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

public static extern IntPtr POS_SetLineSpacing(uint nDistance);

///

/// 设置字符的右间距(相邻两个字符的间隙距离)。

///

/// 指定右间距的点数。可以为 0 到 255。每点的距离与打印头分辨率相关。

///

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

public static extern IntPtr POS_SetRightSpacing(int nDistance);

///

/// 向前走纸。

/// 1.如果在标准打印模式(行模式)下打印文本,则打印缓冲区中的数据,且打印位置自动移动到下一行的行首。

/// 2.如果在标准打印模式(行模式)下打印位图,则在指定的位置打印位图,且打印位置自动移动到下一行的行首。

/// 3.如果在页模式或标签模式下,则把需要打印的数据设置在指定的位置,同时把打印位置移动到下一个行首,

/// 但是并不立即进纸并打印,而是一直到调用 POS_PL_Print 函数时才打印。

///

///

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

public static extern IntPtr POS_FeedLine();

///

/// 打印头换n行

///

///

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

public static extern IntPtr POS_FeedLines(uint nLines);

///

/// 切纸

///

/// 模式编号 半切或是全切

/// 走位的距离

///

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

public static extern IntPtr POS_CutPaper(uint nMode, uint nDistance);

///

/// 设置右边距

///

/// 右边距

///

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

public static extern IntPtr POS_SetRightSpacing(uint nDistance);

///

/// 预下载一幅位图到打印机的 RAM 中,同时指定此位图的 ID 号。

///

/// 指向以 null 结尾的表示位图路径及其文件名的字符串。

/// 指定将要下载的位图的 ID 号。可以为 0 到 7。

///

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

public static extern IntPtr POS_PreDownloadBmpToRAM([MarshalAs(UnmanagedType.LPStr)]string pszPath, uint nID);

///

/// 下载并打印位图

///

/// 指向以null 结尾的包含位图文件路径及其名称的字符串。

/// 指定将要打印的位图和左边界的距离点数。可以为 0到 65535 点。

/// 指定位图的打印模式。

///

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

public static extern IntPtr POS_S_DownloadAndPrintBmp([MarshalAs(UnmanagedType.LPStr)]string pszPath, uint nOrgx, uint nMode);

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

public static extern IntPtr POS_S_PrintBmpInRAM(uint nID, uint nOrgx, uint nMode);

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

public static extern IntPtr POS_S_PrintBmpInFlash(uint nID, uint nOrgx, uint nMode);

///

/// 通过串口返回当前打印机的状态。此函数是实时的。

///

///

///

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

public static extern IntPtr POS_RTQueryStatus(byte[] address);

///

/// 通过串口查询打印机当前的状态。此函数是非实时的。

///

///

/// 指向返回的状态数据的缓冲区,缓冲区大小为 1 个字节。

/// 0,1 0/1 容纸器中有纸 / 纸将用尽 2,3 0/1 打印头处有纸 / 无纸

/// 4,5 0/1 钱箱连接器引脚 3 的电平为低 / 高(表示打开或关闭)

/// 6,7 0 保留(固定为0)

///

/// 设置查询状态时大约的超时时间(毫秒)。

///

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

public static extern IntPtr POS_QueryStatus(byte[] pszStatus, int nTimeouts);

///

/// 通过网络接口查询返回当前打印机的状态。

///

/// 设备IP地址。如“192.168.10.251”。

///

/// 指向接收返回状态的缓冲区,缓冲区大小为 1 个字节。

/// 0 0/1 钱箱连接器引脚 3 的电平为低/高(表示打开或关闭)

/// 1 0/1 打印机联机/脱机

/// 2 0/1 上盖关闭/打开

/// 3 0/1 没有/正在由Feed键按下而进纸

/// 4 0/1 打印机没有/有出错

/// 5 0/1 切刀没有/有出错

/// 6 0/1 有纸/纸将尽(纸将尽传感器探测)

/// 7 0/1 有纸/纸用尽(纸传感器探测)

///

///

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

public static extern int POS_NETQueryStatus([MarshalAs(UnmanagedType.LPStr)]string ipAddress, out Byte pszStatus);

///

/// 设置并打印条码。

///

/// 指向以 null 结尾的字符串。每个字符允许的范围和格式与具体条码类型有关。

/// 指定将要打印的条码的水平起始点与左边界的距离点数。可以为 0 到65535。

///

/// 指定条码的类型。可以为以下列表中所列值之一。

/// POS_BARCODE_TYPE_UPC_A 0x41 UPC-A POS_BARCODE_TYPE_UPC_E 0x42 UPC-C

/// POS_BARCODE_TYPE_JAN13 0x43 JAN13(EAN13) POS_BARCODE_TYPE_JAN8 0x44 JAN8(EAN8)

/// POS_BARCODE_TYPE_CODE39 0x45 CODE39 POS_BARCODE_TYPE_ITF 0x46 INTERLEAVED 2 OF 5

/// POS_BARCODE_TYPE_CODEBAR 0x47 CODEBAR POS_BARCODE_TYPE_CODE93 0x48 25

/// POS_BARCODE_TYPE_CODE128 0x49 CODE 128

///

/// 指定条码的基本元素宽度。

/// 2 0.25mm 0.25mm 0.625mm 3 0.375mm 0.375mm 1.0mm 4 0.5mm 0.5mm 1.25mm

/// 5 0.625mm 0.625mm 1.625mm 6 0.75mm 0.75mm 1.875mm

///

/// 指定条码的高度点数。可以为 1 到 255 。默认值为162 点。

///

/// 指定 HRI(Human Readable Interpretation)字符的字体类型。可以为以下列表中所列值之一。

/// POS_FONT_TYPE_STANDARD 0x00 标准ASCII POS_FONT_TYPE_COMPRESSED 0x01 压缩ASCII

///

///

/// 指定HRI(Human Readable Interpretation)字符的位置。

/// POS_HRI_POSITION_NONE 0x00 不打印 POS_HRI_POSITION_ABOVE 0x01 只在条码上方打印

/// POS_HRI_POSITION_BELOW 0x02 只在条码下方打印 POS_HRI_POSITION_BOTH 0x03 条码上、下方都打印

///

/// 指定由参数 pszInfoBuffer指向的字符串个数,即将要发送给打印机的字符总数。具体值与条码类型有关。

///

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

public static extern IntPtr POS_S_SetBarcode([MarshalAs(UnmanagedType.LPStr)]string pszInfo,

uint nOrgx, uint nType, uint nWidthX, uint nheight,

uint nHriFontType, uint nHriFontPosition, uint nBytesOfInfo);

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

public static extern IntPtr POS_PL_SetArea(uint nOrgx, uint nOrgY, uint nWidth, uint nheight, uint nDirection);

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

public static extern IntPtr POS_PL_TextOut([MarshalAs(UnmanagedType.LPStr)]string pszString, uint nOrgx, uint nOrgY,

uint nWidthTimes, uint nHeightTimes, uint nFontType, uint nFontStyle);

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

public static extern IntPtr POS_PL_PrintBmpInRAM(uint nID, uint nOrgx, uint nOrgY, uint nMode);

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

public static extern IntPtr POS_PL_PrintBmpInFlash(uint nID, uint nOrgx, uint nOrgY, uint nMode);

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

public static extern IntPtr POS_PL_SetBarcode([MarshalAs(UnmanagedType.LPStr)]string pszInfo,

uint nOrgx, uint nOrgY, uint nType, uint nWidthX, uint nheight,

uint nHriFontType, uint nHriFontPosition, uint nBytesOfInfo);

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

public static extern IntPtr POS_PL_Clear();

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

public static extern IntPtr POS_PL_Print();

///

/// 往钱箱引脚发送脉冲以打开钱箱。

///

/// 指定钱箱的引脚。0x00 钱箱连接器引脚2 0x01 钱箱连接器引脚5

/// 指定往钱箱发送的高电平脉冲保持时间,即 nOnTimes × 2 毫秒。可以为1 到 255。

/// 指定往钱箱发送的低电平脉冲保持时间,即 nOffTimes × 2 毫秒。可以为1 到 255。

///

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

public static extern IntPtr POS_KickOutDrawer(uint nID, uint nOnTimes, uint nOffTimes);

///

/// 新建一个打印作业。

///

///

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

public static extern bool POS_StartDoc();

///

/// 结束一个打印作业。

///

///

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

public static extern bool POS_EndDoc();

///

/// 发送数据到端口或文件。通用端口打印可以使用此函数 一般不能设置字体大小样式等

///

/// 端口或文件句柄。可以通过POS_Open来获取

/// 指向将要发送的数据缓冲区。

/// 指定将要发送的数据的字节数。

///

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

public static extern IntPtr POS_WriteFile(IntPtr hPort, byte[] pszData, uint nBytesToWrite);

///

/// 从串口,或USB端口或文件读数据到指定的缓冲区。

///

/// 端口或文件句柄。可以通过POS_Open来获取

/// 指向将要读取的数据缓冲区。

/// 数据的字节数

/// 可能是读取数据的间隔时间

///

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

public static extern IntPtr POS_ReadFile(IntPtr hPort, byte[] pszData, uint nBytesToRead, uint nTimeouts);

///

/// 打开打印设备的串口

///

/// 串口对象(需要先初始化并测试参数都有效的情况下,传进来)

/// 是否打开成功

public bool OpenComPort(ref SerialPort PrintSerialPort)

{

uint i_stopbits = 0;

if (PrintSerialPort.StopBits == StopBits.One)

i_stopbits = POS_COM_ONESTOPBIT;

if (PrintSerialPort.StopBits == StopBits.OnePointFive)

i_stopbits = POS_COM_ONE5STOPBITS;

if (PrintSerialPort.StopBits == StopBits.Two)

i_stopbits = POS_COM_TWOSTOPBITS;

uint i_nComParity = 0;

if (PrintSerialPort.Parity == Parity.None)

i_nComParity = POS_COM_NOPARITY;

if (PrintSerialPort.Parity == Parity.Even)

i_nComParity = POS_COM_EVENPARITY;

if (PrintSerialPort.Parity == Parity.Odd)

i_nComParity = POS_COM_ODDPARITY;

if (PrintSerialPort.Parity == Parity.Space)

i_nComParity = POS_COM_SPACEPARITY;

if (PrintSerialPort.Parity == Parity.Mark)

i_nComParity = POS_COM_MARKPARITY;

uint i_para = 0;

if (PrintSerialPort.Handshake == Handshake.None)

i_para = POS_COM_NO_HANDSHAKE;

if (PrintSerialPort.Handshake == Handshake.RequestToSend)

i_para = POS_COM_DTR_DSR;

if (PrintSerialPort.Handshake == Handshake.RequestToSendXOnXOff)

i_para = POS_COM_RTS_CTS;

if (PrintSerialPort.Handshake == Handshake.XOnXOff)

i_para = POS_COM_XON_XOFF;

POS_IntPtr = POS_Open(PrintSerialPort.PortName,

(uint)PrintSerialPort.BaudRate,

(uint)PrintSerialPort.DataBits,

i_stopbits, i_nComParity, i_para);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备并口

///

/// 并口名称

/// 是否打开成功

public bool OpenLPTPort(string LPTPortName)

{

POS_IntPtr = POS_Open(LPTPortName, 0, 0, 0, 0, POS_OPEN_PARALLEL_PORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备的网口

///

/// 设备的IP地址

/// 是否打开成功

public bool OpenNetPort(string IPAddress)

{

POS_IntPtr = POS_Open(IPAddress, 0, 0, 0, 0, POS_OPEN_NETPORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备的USB端口

///

/// “BYUSB-0”、“BYUSB-1”、“BYUSB-2”、“BYUSB-3”

/// 是否打开成功

public bool OpenUSBPort(string USBPortName)

{

POS_IntPtr = POS_Open(USBPortName, 0, 0, 0, 0, POS_OPEN_BYUSB_PORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 使用windows打印驱动程序来驱动OPOS设备

///

/// 打印驱动程序对应的打印机名称

/// 是否打开成功

public bool OpenPrinter(string PrintName)

{

POS_IntPtr = POS_Open(PrintName, 0, 0, 0, 0, POS_OPEN_PRINTNAME);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 关闭设备端口

///

/// 是否关闭成功

public bool ClosePrinterPort()

{

IntPtr tmpIntPtr = POS_Close();

return ((uint)tmpIntPtr == POS_SUCCESS);

}

///

/// 获取本机默认打印机名称

///

public static String DefaultPrinter

{

get

{

return fPrintDocument.PrinterSettings.PrinterName;

}

}

///

/// 获取本机的打印机列表。列表中的第一项就是默认打印机。

///

public static List GetLocalPrinters()

{

List fPrinters = new List();

fPrinters.Add(DefaultPrinter); // 默认打印机始终出现在列表的第一项

foreach (String fPrinterName in PrinterSettings.InstalledPrinters)

{

if (!fPrinters.Contains(fPrinterName))

fPrinters.Add(fPrinterName);

}

return fPrinters;

}

}

}

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Runtime.InteropServices;

using System.IO.Ports;

using System.Drawing.Printing;

namespace ××××××××××××××

{

///

/// 北洋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";

private static PrintDocument fPrintDocument = new PrintDocument();

///

/// 获取动态库版本号

///

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.K. 0x04 Denmark I 0x05 Sweden

/// 0x06 Italy 0x07 Spain I 0x08 Japan 0x09 Nonway 0x0A Denmark II 0x0B Spain II

/// 0x0C Latin America 0x0D Korea

///

/// 指定字符的代码页。不同的代码页对0x80到0xFF的ASCII码值对应的符号定义是不同的。

/// 0x00 PC437 [U.S.A. Standard Europe 0x01 Reserved 0x02 PC850 [Multilingual]

/// 0x03 PC860 [Portuguese] 0x04 PC863 [Canadian-French] 0x05 PC865 [Nordic]

/// 0x12 PC852 0x13 PC858

///

///

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

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

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

public static extern IntPtr POS_SetCharSetAndCodePage(uint nCharSet, uint nCodePage);

///

/// POS字体样式

///

///

public uint POS_FONT_TYPE_STANDARD = 0x00;// 标准 ASCII

public uint POS_FONT_TYPE_COMPRESSED = 0x01;// 压缩 ASCII

public uint POS_FONT_TYPE_UDC = 0x02; // 用户自定义字符

public uint POS_FONT_TYPE_CHINESE = 0x03; // 标准 “宋体”

public uint POS_FONT_STYLE_NORMAL = 0x00; // 正常

public uint POS_FONT_STYLE_BOLD = 0x08; // 加粗

public uint POS_FONT_STYLE_THIN_UNDERLINE = 0x80; // 1点粗的下划线

public uint POS_FONT_STYLE_THICK_UNDERLINE = 0x100; // 2点粗的下划线

public uint POS_FONT_STYLE_UPSIDEDOWN = 0x200; // 倒置(只在行首有效)

public uint POS_FONT_STYLE_REVERSE = 0x400; // 反显(黑底白字)

public uint POS_FONT_STYLE_SMOOTH = 0x800; // 平滑处理(用于放大时)

public uint POS_FONT_STYLE_CLOCKWISE_90 = 0x1000; // 每个字符顺时针旋转 90 度

///

/// 把将要打印的字符串数据发送到打印缓冲区中,并指定X 方向(水平)上的绝对起始点位置,

/// 指定每个字符宽度和高度方向上的放大倍数、类型和风格。

///

/// 指向以 null 结尾的字符串缓冲区

/// 指定 X 方向(水平)的起始点位置离左边界的点数。

/// 指定字符的宽度方向上的放大倍数。可以为 1到 6。

/// 指定字符高度方向上的放大倍数。可以为 1 到 6。

/// 指定字符的字体类型。

/// 指定字符的字体风格。

///

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

public static extern IntPtr POS_S_TextOut([MarshalAs(UnmanagedType.LPStr)]string pszString,

uint nOrgx, uint nWidthTimes, uint nHeightTimes,

uint nFontType, uint nFontStyle);

///

/// 设置POS的打印模式 (只有两种 页模式和标准模式)

///

///

/// POS_PRINT_MODE_STANDARD 0x00 标准模式(行模式)

/// POS_PRINT_MODE_PAGE 0x01 页模式

/// POS_PRINT_MODE_BLACK_MARK_LABEL 0x02 黑标记标签模式

/// POS_PRINT_MODE_WHITE_MARK_LABEL 0x03 白标记标签模式

///

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

public static extern IntPtr POS_SetMode(uint nPrintMode);

///

/// 设置字符的行高。

///

/// 指定行高点数。可以为 0 到 255。每点的距离与打印头分辨率相关。

///

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

public static extern IntPtr POS_SetLineSpacing(uint nDistance);

///

/// 设置字符的右间距(相邻两个字符的间隙距离)。

///

/// 指定右间距的点数。可以为 0 到 255。每点的距离与打印头分辨率相关。

///

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

public static extern IntPtr POS_SetRightSpacing(int nDistance);

///

/// 向前走纸。

/// 1.如果在标准打印模式(行模式)下打印文本,则打印缓冲区中的数据,且打印位置自动移动到下一行的行首。

/// 2.如果在标准打印模式(行模式)下打印位图,则在指定的位置打印位图,且打印位置自动移动到下一行的行首。

/// 3.如果在页模式或标签模式下,则把需要打印的数据设置在指定的位置,同时把打印位置移动到下一个行首,

/// 但是并不立即进纸并打印,而是一直到调用 POS_PL_Print 函数时才打印。

///

///

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

public static extern IntPtr POS_FeedLine();

///

/// 打印头换n行

///

///

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

public static extern IntPtr POS_FeedLines(uint nLines);

///

/// 切纸

///

/// 模式编号 半切或是全切

/// 走位的距离

///

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

public static extern IntPtr POS_CutPaper(uint nMode, uint nDistance);

///

/// 设置右边距

///

/// 右边距

///

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

public static extern IntPtr POS_SetRightSpacing(uint nDistance);

///

/// 预下载一幅位图到打印机的 RAM 中,同时指定此位图的 ID 号。

///

/// 指向以 null 结尾的表示位图路径及其文件名的字符串。

/// 指定将要下载的位图的 ID 号。可以为 0 到 7。

///

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

public static extern IntPtr POS_PreDownloadBmpToRAM([MarshalAs(UnmanagedType.LPStr)]string pszPath, uint nID);

///

/// 下载并打印位图

///

/// 指向以null 结尾的包含位图文件路径及其名称的字符串。

/// 指定将要打印的位图和左边界的距离点数。可以为 0到 65535 点。

/// 指定位图的打印模式。

///

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

public static extern IntPtr POS_S_DownloadAndPrintBmp([MarshalAs(UnmanagedType.LPStr)]string pszPath, uint nOrgx, uint nMode);

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

public static extern IntPtr POS_S_PrintBmpInRAM(uint nID, uint nOrgx, uint nMode);

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

public static extern IntPtr POS_S_PrintBmpInFlash(uint nID, uint nOrgx, uint nMode);

///

/// 通过串口返回当前打印机的状态。此函数是实时的。

///

///

///

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

public static extern IntPtr POS_RTQueryStatus(byte[] address);

///

/// 通过串口查询打印机当前的状态。此函数是非实时的。

///

///

/// 指向返回的状态数据的缓冲区,缓冲区大小为 1 个字节。

/// 0,1 0/1 容纸器中有纸 / 纸将用尽 2,3 0/1 打印头处有纸 / 无纸

/// 4,5 0/1 钱箱连接器引脚 3 的电平为低 / 高(表示打开或关闭)

/// 6,7 0 保留(固定为0)

///

/// 设置查询状态时大约的超时时间(毫秒)。

///

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

public static extern IntPtr POS_QueryStatus(byte[] pszStatus, int nTimeouts);

///

/// 通过网络接口查询返回当前打印机的状态。

///

/// 设备IP地址。如“192.168.10.251”。

///

/// 指向接收返回状态的缓冲区,缓冲区大小为 1 个字节。

/// 0 0/1 钱箱连接器引脚 3 的电平为低/高(表示打开或关闭)

/// 1 0/1 打印机联机/脱机

/// 2 0/1 上盖关闭/打开

/// 3 0/1 没有/正在由Feed键按下而进纸

/// 4 0/1 打印机没有/有出错

/// 5 0/1 切刀没有/有出错

/// 6 0/1 有纸/纸将尽(纸将尽传感器探测)

/// 7 0/1 有纸/纸用尽(纸传感器探测)

///

///

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

public static extern int POS_NETQueryStatus([MarshalAs(UnmanagedType.LPStr)]string ipAddress, out Byte pszStatus);

///

/// 设置并打印条码。

///

/// 指向以 null 结尾的字符串。每个字符允许的范围和格式与具体条码类型有关。

/// 指定将要打印的条码的水平起始点与左边界的距离点数。可以为 0 到65535。

///

/// 指定条码的类型。可以为以下列表中所列值之一。

/// POS_BARCODE_TYPE_UPC_A 0x41 UPC-A POS_BARCODE_TYPE_UPC_E 0x42 UPC-C

/// POS_BARCODE_TYPE_JAN13 0x43 JAN13(EAN13) POS_BARCODE_TYPE_JAN8 0x44 JAN8(EAN8)

/// POS_BARCODE_TYPE_CODE39 0x45 CODE39 POS_BARCODE_TYPE_ITF 0x46 INTERLEAVED 2 OF 5

/// POS_BARCODE_TYPE_CODEBAR 0x47 CODEBAR POS_BARCODE_TYPE_CODE93 0x48 25

/// POS_BARCODE_TYPE_CODE128 0x49 CODE 128

///

/// 指定条码的基本元素宽度。

/// 2 0.25mm 0.25mm 0.625mm 3 0.375mm 0.375mm 1.0mm 4 0.5mm 0.5mm 1.25mm

/// 5 0.625mm 0.625mm 1.625mm 6 0.75mm 0.75mm 1.875mm

///

/// 指定条码的高度点数。可以为 1 到 255 。默认值为162 点。

///

/// 指定 HRI(Human Readable Interpretation)字符的字体类型。可以为以下列表中所列值之一。

/// POS_FONT_TYPE_STANDARD 0x00 标准ASCII POS_FONT_TYPE_COMPRESSED 0x01 压缩ASCII

///

///

/// 指定HRI(Human Readable Interpretation)字符的位置。

/// POS_HRI_POSITION_NONE 0x00 不打印 POS_HRI_POSITION_ABOVE 0x01 只在条码上方打印

/// POS_HRI_POSITION_BELOW 0x02 只在条码下方打印 POS_HRI_POSITION_BOTH 0x03 条码上、下方都打印

///

/// 指定由参数 pszInfoBuffer指向的字符串个数,即将要发送给打印机的字符总数。具体值与条码类型有关。

///

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

public static extern IntPtr POS_S_SetBarcode([MarshalAs(UnmanagedType.LPStr)]string pszInfo,

uint nOrgx, uint nType, uint nWidthX, uint nheight,

uint nHriFontType, uint nHriFontPosition, uint nBytesOfInfo);

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

public static extern IntPtr POS_PL_SetArea(uint nOrgx, uint nOrgY, uint nWidth, uint nheight, uint nDirection);

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

public static extern IntPtr POS_PL_TextOut([MarshalAs(UnmanagedType.LPStr)]string pszString, uint nOrgx, uint nOrgY,

uint nWidthTimes, uint nHeightTimes, uint nFontType, uint nFontStyle);

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

public static extern IntPtr POS_PL_PrintBmpInRAM(uint nID, uint nOrgx, uint nOrgY, uint nMode);

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

public static extern IntPtr POS_PL_PrintBmpInFlash(uint nID, uint nOrgx, uint nOrgY, uint nMode);

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

public static extern IntPtr POS_PL_SetBarcode([MarshalAs(UnmanagedType.LPStr)]string pszInfo,

uint nOrgx, uint nOrgY, uint nType, uint nWidthX, uint nheight,

uint nHriFontType, uint nHriFontPosition, uint nBytesOfInfo);

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

public static extern IntPtr POS_PL_Clear();

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

public static extern IntPtr POS_PL_Print();

///

/// 往钱箱引脚发送脉冲以打开钱箱。

///

/// 指定钱箱的引脚。0x00 钱箱连接器引脚2 0x01 钱箱连接器引脚5

/// 指定往钱箱发送的高电平脉冲保持时间,即 nOnTimes × 2 毫秒。可以为1 到 255。

/// 指定往钱箱发送的低电平脉冲保持时间,即 nOffTimes × 2 毫秒。可以为1 到 255。

///

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

public static extern IntPtr POS_KickOutDrawer(uint nID, uint nOnTimes, uint nOffTimes);

///

/// 新建一个打印作业。

///

///

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

public static extern bool POS_StartDoc();

///

/// 结束一个打印作业。

///

///

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

public static extern bool POS_EndDoc();

///

/// 发送数据到端口或文件。通用端口打印可以使用此函数 一般不能设置字体大小样式等

///

/// 端口或文件句柄。可以通过POS_Open来获取

/// 指向将要发送的数据缓冲区。

/// 指定将要发送的数据的字节数。

///

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

public static extern IntPtr POS_WriteFile(IntPtr hPort, byte[] pszData, uint nBytesToWrite);

///

/// 从串口,或USB端口或文件读数据到指定的缓冲区。

///

/// 端口或文件句柄。可以通过POS_Open来获取

/// 指向将要读取的数据缓冲区。

/// 数据的字节数

/// 可能是读取数据的间隔时间

///

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

public static extern IntPtr POS_ReadFile(IntPtr hPort, byte[] pszData, uint nBytesToRead, uint nTimeouts);

///

/// 打开打印设备的串口

///

/// 串口对象(需要先初始化并测试参数都有效的情况下,传进来)

/// 是否打开成功

public bool OpenComPort(ref SerialPort PrintSerialPort)

{

uint i_stopbits = 0;

if (PrintSerialPort.StopBits == StopBits.One)

i_stopbits = POS_COM_ONESTOPBIT;

if (PrintSerialPort.StopBits == StopBits.OnePointFive)

i_stopbits = POS_COM_ONE5STOPBITS;

if (PrintSerialPort.StopBits == StopBits.Two)

i_stopbits = POS_COM_TWOSTOPBITS;

uint i_nComParity = 0;

if (PrintSerialPort.Parity == Parity.None)

i_nComParity = POS_COM_NOPARITY;

if (PrintSerialPort.Parity == Parity.Even)

i_nComParity = POS_COM_EVENPARITY;

if (PrintSerialPort.Parity == Parity.Odd)

i_nComParity = POS_COM_ODDPARITY;

if (PrintSerialPort.Parity == Parity.Space)

i_nComParity = POS_COM_SPACEPARITY;

if (PrintSerialPort.Parity == Parity.Mark)

i_nComParity = POS_COM_MARKPARITY;

uint i_para = 0;

if (PrintSerialPort.Handshake == Handshake.None)

i_para = POS_COM_NO_HANDSHAKE;

if (PrintSerialPort.Handshake == Handshake.RequestToSend)

i_para = POS_COM_DTR_DSR;

if (PrintSerialPort.Handshake == Handshake.RequestToSendXOnXOff)

i_para = POS_COM_RTS_CTS;

if (PrintSerialPort.Handshake == Handshake.XOnXOff)

i_para = POS_COM_XON_XOFF;

POS_IntPtr = POS_Open(PrintSerialPort.PortName,

(uint)PrintSerialPort.BaudRate,

(uint)PrintSerialPort.DataBits,

i_stopbits, i_nComParity, i_para);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备并口

///

/// 并口名称

/// 是否打开成功

public bool OpenLPTPort(string LPTPortName)

{

POS_IntPtr = POS_Open(LPTPortName, 0, 0, 0, 0, POS_OPEN_PARALLEL_PORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备的网口

///

/// 设备的IP地址

/// 是否打开成功

public bool OpenNetPort(string IPAddress)

{

POS_IntPtr = POS_Open(IPAddress, 0, 0, 0, 0, POS_OPEN_NETPORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 打开打印设备的USB端口

///

/// “BYUSB-0”、“BYUSB-1”、“BYUSB-2”、“BYUSB-3”

/// 是否打开成功

public bool OpenUSBPort(string USBPortName)

{

POS_IntPtr = POS_Open(USBPortName, 0, 0, 0, 0, POS_OPEN_BYUSB_PORT);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 使用windows打印驱动程序来驱动OPOS设备

///

/// 打印驱动程序对应的打印机名称

/// 是否打开成功

public bool OpenPrinter(string PrintName)

{

POS_IntPtr = POS_Open(PrintName, 0, 0, 0, 0, POS_OPEN_PRINTNAME);

if ((int)POS_IntPtr != -1)

return true;

else

return false;

}

///

/// 关闭设备端口

///

/// 是否关闭成功

public bool ClosePrinterPort()

{

IntPtr tmpIntPtr = POS_Close();

return ((uint)tmpIntPtr == POS_SUCCESS);

}

///

/// 获取本机默认打印机名称

///

public static String DefaultPrinter

{

get

{

return fPrintDocument.PrinterSettings.PrinterName;

}

}

///

/// 获取本机的打印机列表。列表中的第一项就是默认打印机。

///

public static List GetLocalPrinters()

{

List fPrinters = new List();

fPrinters.Add(DefaultPrinter); // 默认打印机始终出现在列表的第一项

foreach (String fPrinterName in PrinterSettings.InstalledPrinters)

{

if (!fPrinters.Contains(fPrinterName))

fPrinters.Add(fPrinterName);

}

return fPrinters;

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值