日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

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

發布時間:2024/1/1 C# 58 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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;

}

}

}

總結

以上是生活随笔為你收集整理的c# 中崎_C# 打开钱箱支持北洋、佳博、爱普生的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。