Chinaunix首页 | 论坛 | 博客
  • 博客访问: 283234
  • 博文数量: 66
  • 博客积分: 2636
  • 博客等级: 少校
  • 技术积分: 762
  • 用 户 组: 普通用户
  • 注册时间: 2009-09-25 16:40
文章存档

2013年(1)

2012年(2)

2011年(8)

2010年(15)

2009年(40)

我的朋友

分类:

2009-09-28 11:51:51

VB进行串口的关键在于MScomm控件,下面小厮先就MScomm控件进行介绍。

每个MSComm控件对应于一个串行端口。使用多个串行口时,要使用多个MSComm控件。MSComm控件的主要属性及说明如下。

属性 说明
CommPort 设置并返回通信端口号
Settings 以字符串的形式设置并返回波特率、奇偶校验、数据位、停止位
PortOpen 设置并返回通信端口的状态。也可以打开和关闭端口
Input 从接收缓冲区返回字符
Output 向传输缓冲区写一个字符

“工程”——“部件”,选中Microsoft Comm control 6.0,“确定”,完成MSComm控件的添加。

有两种处理通信的方式:

  (1)事件驱动。利用OnComm事件捕获并处理通信事件,所有的通信事件和通信错误列表都包含在控件的CommEvent属性中。

  (2)查询方式。在程序关键功能之后,通过检查CommEvent的值来查询事件和错误。

  下面小厮就自己编写的一简单程序展开讲解。

1.添加MScomm控件,并在窗体装入时进行初始化

Private Sub Form_Load()
Timer1.Enabled = False
MSComm1.InBufferSize = 40                        '初始化串口
MSComm1.InBufferCount = 0
MSComm1.InputMode = comInputModeBinary           '二进制方式
MSComm1.CommPort = 1
MSComm1.Settings = "9600,N,8,1"
MSComm1.RThreshold = 1
MSComm1.InputLen =                             '每次读入缓冲区所有字符
If MSComm1.PortOpen = False Then
MSComm1.PortOpen = True                          '打开串口
End If
End Sub

2.添加8个Check并分别命名为LED1——LED8 ,用于控制单片机的8个灯的状态

  添加一个命令按钮Command“应用”用于确认信息无误后发送。

Private Sub Command1_Click()

Dim A,B
A =Check1(0).Value + Check1(1).Value * 2 + Check1(2).Value * 4 + Check1(3).Value * 8

B = Check1(4).Value + Check1(5).Value * 2 + Check1(6).Value * 4 + Check1(7).Value * 8

If MSComm1.PortOpen = False Then
MSComm1.PortOpen = True          '打开串口
End If
MSComm1.OutBufferCount = 0
MSComm1.Output = Chr(CInt(B))              '向单片机发送数据
MSComm1.OutBufferCount = 0
MSComm1.Output = Chr(CInt(A))
End Sub

本程序用了二进制方式传送数据,但传送的数据不能大于128,否则就会出错,所以小厮通过两次发送数据来实现(先发高四位,后发低四位),单片机接收到数字之后再进行相应的处理,转化为8位码控制灯的状态。

3.添加Text,用于显示单片机返回的数据(在此只是为了演示接收)

Private Sub MSComm1_OnComm()

If MSComm1.CommEvent = comEvReceive Then
Text1.Text = AscB(MSComm1.Input)
             End If
MSComm1.InBufferCount = 0

End Sub

写好单片机程序后,连接串口,运行即可。

阅读(910) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~