- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
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 = FalseMSComm1.InBufferSize = 40 初始化串口MSComm1.InBufferCount = 0MSComm1.InputMode = comInputModeBinary 二进制方式MSComm1.CommPort = 1MSComm1.Settings = 9600,N,8,1MSComm1.RThreshold = 1MSComm1.InputLen =?0???????????????????????????????? 每次读入缓冲区所有字符If MSComm1.PortOpen = False ThenMSComm1.PortOpen = True????????????????????????? 打开串口End IfEnd Sub
2.添加8个Check并分别命名为LED1——LED8 ,用于控制单片机的8个灯的状态
? 添加一个命令按钮Command“应用”用于确认信息无误后发送。
Private Sub Command1_Click()
Dim A,BA =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 * 8If MSComm1.PortOpen = False ThenMSComm1.PortOpen = True????????? 打开串口End IfMSComm1.OutBufferCount = 0MSComm1.Output = Chr(CInt(B))????????????? 向单片机发送数据MSComm1.OutBufferCount = 0MSComm1.Output = Chr(CInt(A))End Sub
本程序用了二进制方式传送数据,但传送的数据不能大于128,否则就会出错,所以小厮通过两次发送数据来实现(先发高四位,后发低四位),单片机接收到数字之后再进行相应的处理,转化为8位码控制灯的状态。
3.添加Text,用于显示单片机返回的数据(在此只是为了演示接收)
Private Sub MSComm1_OnComm()
If MSComm1.CommEvent = comEvReceive ThenText1.Text = AscB(MSComm1.Input)?????????????End IfMSComm1.InBufferCount = 0
End Sub
写好单片机程序后,连接串口,运行即可。
文档评论(0)