- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于Proteus仿真软件实现单片机及PC机多字节串行通信
基于Proteus仿真软件实现单片机及PC机多字节串行通信 摘要:Proteus电路设计仿真软件是世界上著名的EDA开发工具,在单片机中嵌入串行通信软件,利用仿真串口COMPIM与PC机通信。本论文主要利用Proteus仿真软件制作单片机串行通信仿真电路,经过虚拟串口可以实现在同一台计算机上实现下位单片机与上位计算机仿真串行通信,上位计算机采用VB语言编辑界面,在单片机教学和电子产品开发中具有一定的参考价值
关键词: Proteus;COMPIM;虚拟串口;MSComm
中图分类号:TP311 文献标识码:A 文章编号:1009-3044(2016)36-0261-02
在单片机串行教学及电子产品开发时,通常涉及单片机(下位机)与计算机(上位机)的串行通信,利用串行通信上位机发送命令给下位机,下位机将待显示数据传到上位机上显示,本论文设计收发帧定长21个字节的串行通信,一帧包括2字节同步头、2字节结束字、1字节命令字、16字节数据。上下位机通过一对虚拟串口进行连接实现双机通信
1 Proteus仿真软件绘制串行通信电路(如图1)
2 利用kile c51软件编写下位机程序代码
#include
#define uchar unsigned char
sbit P1_1=P1;
uchar Fhead=0xA5,Fend=0x5A,shead=0,send=0; //头尾字节,找到头尾标志
uchar x,uartbuf,rdata[20]; //接收变量,接收缓冲21字节
uchar temp,tdata[21]={0xa5,0xa5,16,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0x5a,0x5a};
uchar scount; //接收有效数据
main()
{ TMOD=0x20; PCON=0x00; SCON=0x50; //设置波特率为9600b/s,10位异步收发,启动定时器1
TH1=0xfd; TL1=0xfd; TR1=1;
EA=1; ES=1; //开启中断
while(1)
{ if(send==1||P1_1==0) //接收到正确数据或按键按下时下位机发送数据到上位机
{ tdata[0]=0xa5;tdata[1]=0xa5;tdata[19]=0x5a;tdata[20]=0x5a;
for(temp=0;temp For i = 3 To 18
shuju(i) = “H” Mid(txtSend.Text, 2 * (i - 3) + 1, 2)
Next i
shuju(19) = H5A:shuju(20) = H5A
MSComm1.Output = shuju
End Sub
Private Sub MSComm1_OnComm() ‘接收数据
Dim RX_lins As Integer, i As Integer, temp As Byte
fnum = 0
If MSComm1.CommEvent = comEvReceive Then
RX_lins = MSComm1.InBufferCount
ReDim lt(RX_lins) As Byte
lt = MSComm1.Input
For i = 0 To RX_lins - 1 ‘查找同步头A5
If i = 1 Then
If lt(i) = HA5 And lt(i - 1) = HA5 Then
fnum = i + 1: TOU = True
End If
End If
Next i
If TOU = True Then
For i = fnum To RX_lins - 1
shuzu(i - fnum) = lt(i) ‘导入数据
Next i
counter = RX_lins - fnum ‘累加接收到的数据
End If
If TOU = True And counter = 3 Then ‘找到头尾时数据有效
If shuzu(counter - 2) = H5A And shuzu(counter - 1) = H5A Then
For i = 0 To counter - 1 ‘接收数据送至接收文本框显示
txtRcv.Text = txtRcv.Text Hex(shuzu(i)) “ “
Next i
counter = 0: TOU = False:
您可能关注的文档
最近下载
- 《风景谈》精品课件.ppt VIP
- T11长轨列车卸轨作业指导书.pdf VIP
- 城市轨道交通交流供电系统的保护方式1城市轨道交通交流供电系.pptx VIP
- 《极简项目管理》读书笔记.pdf VIP
- 北京-绅宝D70-产品使用说明书-绅宝D70 2.3T-C7230C7G-绅宝产品使用说明书.pdf VIP
- 《地下工程防水技术规范》(GB50108-2008).pdf
- 2023 【小升初分班】小升初数学分班测试卷 (通用版,含答案).pdf VIP
- DLT 1253-2013 电力电缆线路运行规程.pdf VIP
- 商务谈判毕思勇课程教案.pdf VIP
- 信息处理技术员教程(第三版)第6章 演示文稿基础知识.pptx VIP
文档评论(0)