VFP 愛用者社區 首頁 VFP 愛用者社區
本討論區為 Visual Foxpro 愛用者經驗交流的地方, 請多多利用"搜尋"的功能, 先查看看有無前例可循, 如果還有不懂的再發問. 部份主題有附加檔案, 須先註冊成為社區居民才可以下載.
 
 常見問題常見問題   搜尋搜尋   會員列表會員列表   會員群組會員群組   會員註冊會員註冊 
 個人資料個人資料   登入檢查您的私人訊息登入檢查您的私人訊息   登入登入

印表機控制模組--VB(轉貼)

 
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> VFP 討論區
上一篇主題 :: 下一篇主題  
發表人 內容
Ruey



註冊時間: 2003-03-12
文章: 1698
來自: tunglo

第 1 樓

發表發表於: 星期三 十一月 19, 2003 11:54 pm    文章主題: 印表機控制模組--VB(轉貼) 引言回覆

來源:程式設計師俱樂部 Clark

http://programmer.eforum2000.net/pc2020v5/forum/ShowSameTitle.asp?URL=N&board_pc2020=vb&index=94&id=12543&mode=&type_pc2020=sametitleLevel-2

'+----------------------------------------------------------------------------
'
' Function: OpenPrinter
'
' Description: 開啟印表機通道
'
' Arguments: iPortName : 連接埠名稱
'
' Returns: 印表機代碼(-1代表開啟失敗)
'
'-----------------------------------------------------------------------------

Public Function OpenPrinter(ByVal iPortName As String) As Integer
Dim PrinterID As Integer

PrinterID = FreeFile
OpenPrinter = PrinterID

On Error Resume Next
Open iPortName For Binary Access Write Shared As #PrinterID
If Err.Number <> 0 Then
MsgBox Err.Number & " " & Err.Description, vbExclamation, "印表機錯誤"
OpenPrinter = -1
Else
Call PrinterInit(PrinterID)
End If
End Function


'+----------------------------------------------------------------------------
'
' Function: ClosePrinter
'
' Description: 關閉印表機通道
'
' Arguments: PrinterID : 印表機代碼
'
' Returns: 是否正常關閉(Boolean)
'
'-----------------------------------------------------------------------------

'關掉Printer
Public Function ClosePrinter(ByVal PrinterID As Integer) As Boolean
ClosePrinter = True
On Error Resume Next
Close PrinterID
If Err.Number <> 0 Then
MsgBox Err.Number & " " & Err.Description, vbExclamation, "印表機錯誤"
ClosePrinter = False
End If
End Function


'+----------------------------------------------------------------------------
'
' Function: PrintCode
'
' Description: 列印控制碼
'
' Arguments: PrinterID : 印表機代碼
' CodeArr : 控制碼陣列
'
' Returns: 是否正常(Boolean)
'
'-----------------------------------------------------------------------------

Public Function PrintCode(ByVal PrinterID As Integer, ByRef CodeArr() As Byte) As Boolean
PrintCode = True
On Error Resume Next
Put #PrinterID, , CodeArr
If Err.Number <> 0 Then
MsgBox Err.Number & " " & Err.Description, vbExclamation, "印表機錯誤"
PrintCode = False
Exit Function
End If
End Function


'+----------------------------------------------------------------------------
'
' Function: PrintString
'
' Description: 列印字串
'
' Arguments: PrinterID : 印表機代碼
' iString : 待列印字串(只能印ASCII)
'
' Returns: 是否正常(Boolean)
'
'-----------------------------------------------------------------------------

Public Function PrintString(ByVal PrinterID As Integer, ByVal iString As String) As Boolean
PrintString = True
On Error Resume Next
Put #PrinterID, , iString
If Err.Number <> 0 Then
MsgBox Err.Number & " " & Err.Description, vbExclamation, "印表機錯誤"
PrintString = False
Exit Function
End If
End Function


'+----------------------------------------------------------------------------
' 印表機--控制碼
'-----------------------------------------------------------------------------


'+----------------------------------------------------------------------------
'
' Function: PrinterInit
'
' Description: 初始化印表機(ESC @)
'
' Arguments: PrinterID : 印表機代碼
'
' Returns: nothing
'
'-----------------------------------------------------------------------------

Public Sub PrinterInit(ByVal PrinterID As Integer)
Dim CodeArr(1) As Byte
CodeArr(0) = &H1B
CodeArr(1) = &H40
Call PrintCode(PrinterID, CodeArr)
End Sub


'+----------------------------------------------------------------------------
'
' Function: PrinterLineFree
'
' Description: 列印+換行(LF)
'
' Arguments: PrinterID : 印表機代碼
'
' Returns: nothing
'
'-----------------------------------------------------------------------------

Public Sub PrinterLineFree(ByVal PrinterID As Integer)
Dim CodeArr(0) As Byte
CodeArr(0) = &HA
Call PrintCode(PrinterID, CodeArr)
End Sub


'+----------------------------------------------------------------------------
'
' Function: PrinterXPosition
'
' Description: 印表機水平軸位置(ESC $)
'
' Arguments: PrinterID : 印表機代碼
' HorizontalPosition : 水平軸位置
'
' Returns: nothing
'
'-----------------------------------------------------------------------------

Public Sub PrinterXPosition(ByVal PrinterID As Integer, ByVal HorizontalPosition As Integer)
Dim CodeArr(3) As Byte
CodeArr(0) = &H1B
CodeArr(1) = &H24
CodeArr(2) = HorizontalPosition Mod 256
CodeArr(3) = CByte(HorizontalPosition / 256)
Call PrintCode(PrinterID, CodeArr)
End Sub

_________________
#############################
快樂媽咪系列幸福宅配,喝十全雞湯~原來幸福那麼簡單!!

學會VFP使用者社區的搜尋,Code才會更有趣~
#############################


Ruey 在 星期三 十一月 19, 2003 11:55 pm 作了第 1 次修改
回頂端
檢視會員個人資料 發送私人訊息
Ruey



註冊時間: 2003-03-12
文章: 1698
來自: tunglo

第 2 樓

發表發表於: 星期三 十一月 19, 2003 11:55 pm    文章主題: 引言回覆

Private Sub Command1_Click()
Dim PrinterID As Integer
PrinterID = OpenPrinter("LPT1")

PrinterXPosition PrinterID, 50
PrintString PrinterID, "Clark"
PrinterLineFree PrinterID

ClosePrinter PrinterID
End Sub

_________________
#############################
快樂媽咪系列幸福宅配,喝十全雞湯~原來幸福那麼簡單!!

學會VFP使用者社區的搜尋,Code才會更有趣~
#############################
回頂端
檢視會員個人資料 發送私人訊息
從之前的文章開始顯示:   
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> VFP 討論區 所有的時間均為 台北時間 (GMT + 8 小時)
1頁(共1頁)

 
前往:  
無法 在這個版面發表文章
無法 在這個版面回覆文章
無法 在這個版面編輯文章
無法 在這個版面刪除文章
無法 在這個版面進行投票
無法 在這個版面附加檔案
無法 在這個版面下載檔案


Powered by phpBB © 2001, 2005 phpBB Group
正體中文語系由 phpbb-tw 維護製作