您的位置 首页 IC

AT89C52单片机完成短距离无线传输的规划

AT89C52单片机实现短距离无线传输的设计-短距离的无线传输具有抗干扰能力强、可靠性高、安全性好、受地理条件限制少、安装灵活等优点,可以利用单片机和专用无线传输芯片实现简单的短距离无线传输方案,硬件部分包括单片机端和PC机端,实现单片机和PC机间的数据传输。

在一些特别的使用场合,单片机通讯不能选用有线数据传输方法,而需求选用短距离的无线数据传输方法。短距离的无线传输具有抗干扰能力强、可靠性高、安全性好、受地舆条件约束少、装置灵敏等长处,能够使用单片机和专用无线传输芯片完成简略的短距离无线传输计划,硬件部分包含单片机端和PC机端,完成单片机和PC机间的数据传输。

首要器材:

1、单片机端:AT89C52单片机芯片,用于操控无线模块的发射和承受;PTR2000无线数据传输模块,使用了433MHz IGM频段,是真实的单片UHF无线收发一体芯片,能够和单片机的串口直接相连。

2、 PC端:PTR2000无线数据传输模块;TTL电平转化RS-232电平芯片MAX202。

实验流程图:

AT89C52单片机完成短距离无线传输的规划

实验电路图:

单片机端:

AT89C52单片机完成短距离无线传输的规划

PC端:

AT89C52单片机完成短距离无线传输的规划

实验程序代码:

//wireless.h程序

#ifndef _WIRELESS_H // 避免wireless.h被重复引证

#define _WIRELESS_H

#include // 引证规范库的头文件

#include

#define uchar unsigned char

#define uint unsigned int

#define REQ_SEND 0x33

#define REQ_RESEND 0x66

#define SEND_OVER 0x99

//为简化起见,假设了7位固定的收集数据

#define DATA0 0x10

#define DATA1 0x20

#define DATA2 0x30

#define DATA3 0x40

#define DATA4 0x50

#define DATA5 0x60

#define DATA6 0x70

sbit TXEN = P2^0;

sbit CS = P2^1;

sbit PWR = P2^2;

void ClearT_buf(); // 铲除t_buf函数

void ClearR_buf(); // 铲除r_buf函数

void Delay5ms(); // 延时5ms

void GetData(); // 收集数据

void Send(); // 收集并发送函数

void SendOver(); // 告诉PC机发送完毕函数

xdata uchar Flag_StartRec = 0 ; //开端承受数据标志位

xdata uchar Flag_ReqSend = 0 ; //恳求发送标志位

xdata uchar Flag_ReqReSend = 0 ; //恳求重发标志位

xdata uchar Flag_Delay5ms = 1 ; //延时5ms标志

xdata uchar Data[7]; //收集的7个字节数据

xdata uchar tCount = 0 ;

xdata uchar t_buf[11]; // 1开端字节”$”,1长度字节LEN,

// 7字节数据,1校验和字节,

// 1 完毕字节”*”

xdata uchar rCount = 0 ;

xdata uchar r_buf[5]; // 1开端字节”$”,1长度字节LEN,

// 1字节指令,1校验和字节,

// 1 完毕字节”*”

#endif

//wireless.c程序

#include “wireless.h”

/* 定时器0中止服务子程序 */

void TImer() interrupt 1 using 2

{

Flag_Delay5ms = 0;

TH0 = -5000/256;

TL0 = -5000%256;

}

void main(void)

{

ClearT_buf();

ClearR_buf();

TXEN = 0; //初始为接纳状况

PWR = 1; //正常作业形式

CS = 0; //挑选频道0

EA=0;

/* 11.0592MHz下,设置串行口9600波特率,作业方法1

8位数据位,1位中止位,无奇偶校验,*/

TMOD = 0x21; //定时器1作业形式1,定时器0作业形式2

SCON = 0x50; //串行口作业方法1,REN=1

PCON = 0x00; //SMOD=0

TL1 = 0xfd;

TH1 = 0xfd;

TR1=1; //定时器1开端计时

PT0 = 1; //定时器0高优先级

TH0 = -5000/256; //5ms

TL0 = -5000%256;

IE = 0x90; //EA=1,ES=1:翻开串口中止

while (1)

{

if (Flag_ReqSend) //收到“恳求发送”指令

{

TXEN = 1; //改变为发射状况

Delay5ms(); //延时5ms

GetData(); //收集数据

Send(); //发送

Flag_ReqSend = 0;

SendOver(); //告诉PC机发送完毕

TXEN = 0; //重设为接纳状况

}

else if (Flag_ReqReSend) //收到“恳求重发”指令

{

TXEN = 1; //改变为发射状况

Delay5ms(); //延时5ms

Send(); //重发

Flag_ReqReSend = 0;

SendOver(); //告诉PC机发送完毕

TXEN = 0; //重设为接纳状况

}

}

}

接上篇程序:

/* 串口中止服务子程序 */

void serial ( ) interrupt 4 using 1

{

RI = 0 ;

/* 判别是否收到字符'$',其数值为0x24,置开端接纳标志位*/

if ((!Flag_StartRec) && (SBUF == 0x24))

{

Flag_StartRec = 1;

}

if (Flag_StartRec)

{

if (rCount<5)

{

r_buf[rCount] = SBUF;

rCount ++;

}

/* 判别是否收到字符'*',其数值为0x2A,依据接纳的指令设置相应标志位*/

if ((r_buf[rCount -1] == 0x2A)||(rCount == 5))

{

rCount = 0;

Flag_StartRec = 0;

if (r_buf[2] == REQ_SEND) //收到“恳求发送”指令

{

Flag_ReqSend = 1;

}

if (r_buf[2] == REQ_RESEND) //收到“恳求重发”指令

{

Flag_ReqReSend = 1;

}

}

else

ClearR_buf();

}

}

void ClearT_buf(void)

{

uchar xdata k ;

for (k=0;k++;k<11)

{

t_buf[k] = 0;

}

}

void ClearR_buf(void)

{

uchar xdata k ;

for (k=0;k++;k<5)

{

r_buf[k] = 0;

}

}

void Delay5ms(void)

{

TR0=1;

ET0=1;

while( Flag_Delay5ms);

ET0 = 0;

TR0 = 0;

Flag_Delay5ms = 1;

}

//收集数据函数通过简化处理,取固定的7个字节数据

void GetData(void)

{

Data[0]=DATA0;

Data[1]=DATA1;

Data[2]=DATA2;

Data[3]=DATA3;

Data[4]=DATA4;

Data[5]=DATA5;

Data[6]=DATA6;

}

//单片机端发送数据函数

void Send(void)

{

uchar xdata j = 0;

uchar xdata len = 0;

uchar xdata CheckSum = 0 ;

t_buf[0]=0x24; //开始位

t_buf[1]=0x07; //7个数据字节

len=t_buf[1];

CheckSum = CheckSum + len;

for ( j=0;j++;j

{

t_buf[j+2] = Data[j];

CheckSum = CheckSum + t_buf[j+2];

}

t_buf[9] = CheckSum; //校验和字节

t_buf[10] = 0x2A; //中止位

for (j=0;j++;j<11)

{

TI =0 ;

SBUF = t_buf[j];

while ( TI ==0 );

TI =0 ;

}

}

//告诉PC机端发送完毕函数

void SendOver(void)

{

TI =0 ;

SBUF = 0x24;

while ( TI ==0 );

TI =0 ;

SBUF = 0x01;

while ( TI ==0 );

TI =0 ;

SBUF = SEND_OVER; //告诉PC机端“发送完毕”

while ( TI ==0 );

TI =0 ;

SBUF = 0x99; //校验和字节

while ( TI ==0 );

TI =0 ;

SBUF = 0x2A;

while ( TI ==0 );

TI =0 ;

}
责任编辑;zl

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/bandaoti/343147.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部