VB 通过MSComm控件取得打印机的状态:正常、缺纸、卡纸等

本文介绍了一种使用VB中的MSComm控件通过串口通信来检测StarSP500系列打印机状态的方法。通过发送特定指令并读取返回的状态值,可以判断打印机是否正常工作、缺纸或卡纸等问题。

此方法使用VB中的串口通信控件MSComm给打印机发送指令,然后打印机自动返回其状态值,根据不同的返回值
就可以判断打印机是正常、缺纸、卡纸等状态。其中的指令适用于Star SP500系列。注意在使用此方法时不要安装打印机的驱动,或者在驱动中设置的串口端口与此程序中的要不能相同,否则程序会提示参数设置错误,其实就是端口已经被占用的原因。 

Option Explicit

Dim Status As String
Dim StatusString As String
Dim TimeUp As Boolean

Private Sub Command1_Click()Sub Command1_Click()
On Error Resume Next
    
Dim i As Long
    Status 
= ""               '状态返回值
    StatusString = ""      
    
    MSComm1.CommPort 
= 1         'COM端口号:如果是COM1则为1,以此类推;
    MSComm1.Settings = "38400,N,8,1"      '参数设置:波特率,奇偶校验,数据位,停止位;
    MSComm1.InputLen = 0

    MSComm1.PortOpen 
= True        '打开端口
    
    
'给Star打印机发送“ENQ”指令或“ESC ACK SOH”指令,打印机自动返回状态值
    MSComm1.Output = Chr$(5+ Chr$(&HA) + Chr$(0)                    
    
'MSComm1.Output = Chr$(&H1B) + Chr$(&H6) + Chr$(&H1)                 
    
    
' Poll for 8 byte status
    Do While Len(Status) < 8
        DoEvents
        Status 
= MSComm1.Input
    
Loop
    
    
For i = 1 To 9
        StatusString 
= StatusString & Right("00" & " " & Hex(Asc(Mid$(Status, i, 1))), 2)
        
'StatusString = StatusString & Hex(Asc(Mid$(Status, i, 1))) & " "
    Next i
    
    Text1.Text 
= StatusString
    MSComm1.PortOpen 
= False
End Sub


Private Sub Form_Unload()Sub Form_Unload(Cancel As Integer)
    Close
End Sub


Private Sub Wait()Sub Wait(Interval As Long)
    Timer1.Interval 
= Interval
    Timer1.Enabled 
= True
    TimeUp 
= False
    
    
Do
        DoEvents
    
Loop While Not TimeUp
End Sub


Private Sub Timer1_Timer()Sub Timer1_Timer()
    Timer1.Interval 
= 0
    Timer1.Enabled 
= False
    TimeUp 
= True
End Sub

 

 

有过编程经验的人都知道,编写打印模块是非常头疼的事,本组件针对上述情况,作者根据自已在软件开发过程中积累的经验编制了一个通用的打印组件(ActiveX DLL),这个组件可用于软件开发中的打印模块的二次开发,它可实现1毫米精度的定位打印,可以完成各种类型报表的设计并打印,支持表格打印、多页打印、资料发票套打等。组件提供的接口允许程序员控制设计的打印模板中的各个对象的属性,在程序中就可以完成所在的数据处理,支持数据的合计值、平均值等操作。提供了打印定位微调等接口控制(软件用户自己就可以不同的打印机设置微调值,避免了常规要由程序员上门调试打印位置,有时还要根据不同的打印机更改源码的麻烦),实现对各种张及票据的精确定位打印,支持的打印对象除了文本文字以外,还支持直线、矩形、圆、填充矩形、填充圆、图象等的打印。 该组件库内嵌的打印预览功能,随时可以将程序对报表处理的情况进行实时预览。组件库内嵌的报表模板设计器,可以方便快速的设计出各种类型报表的模板,设计过程采用先进的所见即所得的方式,让您使用起来更加得心应手,报表可以由程序员设计也可以交由用户自己设计, 该组件支持VB、VC等开发工具,并提供了相关的示例工程源代码。 作者:罗伟 Email:mr_luowei@163.com
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值