// 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
{
/// <summary>
/// 北洋OPOS指令集二次开发包DLL调用 
///
/// 备注:
/// 因为北洋的demo包里没有C#的,所以参考delphi包的代码转成了C#的.
/// 北洋的dll支持市面上所有的 支持ESC/ POS指令的小票打印机的打印(EPSON,佳博,中崎等)
/
//
/// 如果有任何修改请邮件通知本人,欢迎志同道合的朋友共同交流;
/// coder: 萧远峰  mail: 71008973@qq
///
/// POSDLL 动态库的出口函数是用来直接控制 POS 打印机工作的,
/// 分为四个部分:通用函数、标准模式打印函数、页模式打印函数、调试等函数。
/// </summary>
public class BeiYangOPOS
{
const string _DllVer = "1.4";
/// <summary>
/
// 获取动态库版本号
/// </summary>
public string GetDllVer
{
get { return _DllVer;}
}
/// <summary>
/// 设备打开后的句柄
/// </summary>
public IntPtr POS_IntPtr;
/// <summary>
/
// 函数返回值
/// </summary>
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; // 没有到指定的文件路径或名
/// <summary>
/
// 停止位
/// </summary>
public uint POS_COM_ONESTOPBIT = 0x00;//停止位为1
public uint POS_COM_ONE5STOPBITS = 0x01;//停止位为1.5
public uint POS_COM_TWOSTOPBITS = 0x02;//停止位为2
/// <summary>
/// 奇偶校验
/// </summary>
public uint POS_COM_NOPARITY = 0x00;//无校验
public uint POS_COM_ODDPARITY = 0x01;//奇校验
public uint POS_COM_EVENPARI
TY = 0x02;//偶校验
public uint POS_COM_MARKPARITY = 0x03;//标记校验
public uint POS_COM_SPACEPARITY = 0x04;//空格校验
/// <summary>
/// 其他COM口参数及端口类型定义
/// </summary>
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;// 半切
/// <summary>
/// 打开POS机的端口 开始会话
/// </summary>
/// <param name="lpName">
///指向以 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地址</param>
/// <param name="nComBaudrate">串口通信需要的波特率</param>
/// <param name="nComDataBits">串口通信需要的数据位</param>
/// <param name="nComStopBits">串口通信需要的停止位</param>
/// <param name="nComParity">串口通信需要的是否要奇偶校验</param>
/// <param name="nParam">指向以 null 结尾的打印机名称或端口名称。
/// 参数nParam的值为POS_COM_DTR_DSR、POS_COM_RTS_CTS、POS_COM_XON_XOFF或P
OS_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时,表示打开指定的打印机。</param>
/// <returns>如果函数调用成功,返回一个已打开的端口句柄。如果函数调用失败,返回值为 INVALID_HANDLE_VALUE (-1)。</returns>
[DllImport("POSDLL.dll", CharSe
t = CharSet.Ansi)]
public static extern IntPtr POS_Open([MarshalAs(UnmanagedType.LPStr)]string lpName,
uint nComBaudrate,
uint nComDataBits,
uint nComStopBits,
uint nComParity,
uint nParam);
/// <summary>
/// 关闭已经打开的并口或串口,USB端口,网络接口或打印机。
/// </summary>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_Close();
/// <summary>
/
// 复位打印机,把打印缓冲区中的数据清除,字符和行高的设置被清除,打印模式被恢复到上电时的缺省模式。
/// </summary>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_Reset();
/// <summary>
/// 设置打印机的移动单位。
/// </summary>
/// <param name="nHorizontalMU">把水平方向上的移动单位设置为 25.4 / nHorizontalMU 毫米。可以为0到255。</param>
/// <param name="nVerticalMU">把垂直方向上的移动单位设置为 25.4 / nVerticalMU 毫米。可以为0
到255。</param>
/// <returns>
/// 如果函数成功,则返回值为 POS_SUCCESS。
/// 如果函数失败,则返回值为以下值之一:POS_FAIL POS_ERROR_INVALID_HANDLE POS_ERROR_INVALID_PARAMETER </returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetMotionUnit(uint nHorizontalMU, uint nVerticalMU);
/// <summary>
/// 选择国际字符集和代码页
/// </summary>
/// <param name="nCharSet">
/// 指定国际字符集。不同的国际字符集对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 </param>
/// <param name="nCodePage">
/// 指定字符的代码页。不同的代码页对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
/// </param>
/// <returns>
/
// 如果函数成功,则返回值为 POS_SUCCESS。
/// 如果函数失败,则返回值为以下值之一:POS_FAIL POS_ERROR_INVALID_HANDLE POS_ERROR_INVALID_PARAMETER </returns>
[DllImp
ort("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetCharSetAndCodePage(uint nCharSet, uint nCodePage);
/// <summary>
/// POS字体样式
/// </summary>
///
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 度
/// <summary>
/
// 把将要打印的字符串数据发送到打印缓冲区中,并指定X 方向(水平)上的绝对起始点位置,
/// 指定每个字符宽度和高度方向上的放大倍数、类型和风格。
/// </summary>
/// <param name="pszString">指向以 null 结尾的字符串缓冲区</param>
/// <param name="nOrgx">指定 X 方向(水平)的起始点位置离左边界的点数。</param>
/// <param name="nWidthTimes">指定字符的宽度方向上的放大倍数。可以为 1到 6。</param>
/// <param name="nHeightTimes">指定字符高度方向上的放大倍数。可以为 1 到 6。</param>
/// <param name="nFontType">指定字符的字体类型。</param>
/// <param name="nFontStyle">指定字符的字体风格。</param>
/// <returns></returns>
[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);
/// <summary>
/// 设置POS的打印模式 (只有两种 页模式和标准模式)
/// </summary>
/// <param name="nPrintMode">
/// POS_PRINT_MODE_STANDARD 0x00 标准模式(行模式)
/// POS_PRINT_MODE_PAGE 0x01 页模式
/// POS_PRINT_MODE_BLACK_MARK_LABEL 0x02 黑标记标签模式
/// POS_PRINT_MODE_WHITE_MARK_LABEL 0x03 白标记标签模式 </param>
/
// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetMode(uint nPrintMode);
/// <summary>
/// 设置字符的行高。generic打印机
/// </summary>
/// <param name="nDistance">指定行高点数。可以为 0 到 255。每点的距离与打印头分辨率相关。</param>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetLineSpacing(uint nDistance);
/// <summary>
/// 设置字符的右间距(相邻两个字符的间隙距离)。
/// </summary>
/// <param name="nDistance">指定右间距的点数。可以为 0 到 255。每点的距离与打印头分辨率相关。</param>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetRightSpacing(int nDistance);
/// <summary>
/// 向前走纸。
/// 1.如果在标准打印模式(行模式)下打印文本,则打印缓冲区中的数据,且打印位置自动移动到下一行的行首。
/// 2.如果在标准打印模式(行模式)下打印位图,则在指定的位置打印位图,且打印位置自动移动到
下一行的行首。
/// 3.如果在页模式或标签模式下,则把需要打印的数据设置在指定的位置,同时把打印位置移动到下一个行首,
/// 但是并不立即进纸并打印,而是一直到调用 POS_PL_Print 函数时才打印。
/// </summary>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_FeedLine();
/// <summary>
/// 打印头换n行
/// </summary>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_FeedLines(uint nLines);
/// <summary>
/// 切纸
/// </summary>
/// <param name="nMode">模式编号 半切或是全切</param>
/// <param name="nDistance">走位的距离</param>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_CutPaper(uint nMode, uint nDistance);
/// <summary>
/
// 设置右边距
/// </summary>
/// <param name="nDistance">右边距</param>
/// <returns></returns>
[DllImport("POSDLL.dll", SetLastError = true)]
public static extern IntPtr POS_SetRightSpacing(uint nDistance);
/// <summary>
/// 预下载一幅位图到打印机的 RAM 中,同时指定此位图的 ID 号。
/// </summary>
/// <param name="pszPath">指向以 null 结尾的表示位图路径及其文件名的字符串。</param>
/// <param name="nID">指定将要下载的位图的 ID 号。可以为 0 到 7。</param>
/
// <returns></returns>
[DllImport("P

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。