AT89C52单片机芯片实现段距离无线传输
21ic 2024-12-12

在一些特殊的应用场合,单片机通信不能采用有线数据传输方式,而需要采用短距离的无线数据传输方式。短距离的无线传输具有抗干扰能力强、可靠性高、安全性好、受地理条件限制少、安装灵活等优点,可以利用单片机和专用无线传输芯片实现简单的短距离无线传输方案,硬件部分包括单片机端和PC机端,实现单片机和PC机间的数据传输。

主要器件:

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

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

试验流程图:


试验电路图:

单片机端:


PC端:


试验程序代码:

//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 ;

}

声明: 本文转载自其它媒体或授权刊载,目的在于信息传递,并不代表本站赞同其观点和对其真实性负责,如有新闻稿件和图片作品的内容、版权以及其它问题的,请联系我们及时删除。(联系我们,邮箱:evan.li@aspencore.com )
0
评论
  • 相关技术文库
  • C语言
  • 编程
  • 软件开发
  • 程序
  • C语言最全入门知识汇总

    C语言知识整理

    8小时前
  • 串行A/D芯片TLC1543 应用

    首先了解下串行A/D芯片TLC1543的参数   有6种工作模式:   本程序使用了2种工作模式来编程,具体看时序图:     源程序: uint Read_AD(uchar AD_Channel) //从TLC1543读取采样值,形参AD_Channel是采样的通道号...

    前天
  • AT89C52单片机芯片实现以太网接口-基于RTL8019

    随着互联网的迅速发展,网络用户飞速增长,在使用计算机进行网络互联的同时,各种家电设备、仪表设备及工业中数据采集与控制设备也在逐步走向网络化,基于此结合专用的以太网控制芯片RTL8019学习了利用单片机实现以...

    前天
  • AT89C52单片机芯片实现智能信号发生器

    单片机不仅在控制系统有很大的应用,在信号的产生方面也有独特的应用。在现代电子学的各个领域中,常常需要高精度切频率方便可调节的信号发生器,可以利用单片集成芯片实现函数信号发生器,这种信号发生器风产生多种...

    前天
  • 单片机实现接触式的IC卡读写控制

    从上高中开始,我们学校用的餐卡就为接触式的IC卡,在校园里还分布着很多的IC卡电话,上大学以后学校使用的校园一卡通,为非接触式是射频式IC卡,因此对IC卡有了兴趣,在学习单片机的过程中,了解到单片机可以实现IC...

    前天
  • DS12C887的日历时钟显示系统设计

    在银行或者其他的公共场合中,经常会看到显示实时信息的显示屏,其中包括年、月、日、星期、时间等,本例子的功能是在51单片机系统中设置、获取、记录实时的日历时钟信息并通过数码管显示,选用日历时钟芯片DS12C887...

    前天
  • MAX1898的智能充电器设计

    单片机在控制方面不仅可以在工业控制方面大展神通,如果用在控制一些很有意思的芯片方面也可以实现实用的功能。比如用单片机控制冲电芯片实现手机的智能充电器设计,基于次参考有关资料学习了基于MAX1898的智能充电...

    前天
  • 单片机控制步进电机系统

    学习了单片机在的基本输入输出和在数据采集领域的应用,接着学习了单片机在控制领域的应用。在控制系统中,通常要控制机械部件的平移和转动,这些机械部件的驱动大都采用交流电机、直流电机和步进电机等,其中步进电...

    前天
  • MPX4105数字气压计设计

    单片机不仅可以用于温度测量,也可以用来测量气压这类非电信号,就要用到气压传感器。气压传感器的原理是将气压信息转换为电流或者电压输出,转换后的电压或者电流常为模拟信号,因此还必须进行A/D转换,以满足单片...

    前天
下载排行榜
更多
评测报告
更多
广告