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
评论
  • 【7.24 深圳】2025国际AI+IoT生态发展大会/2025全球 MCU及嵌入式技术论坛


  • 相关技术文库
  • C语言
  • 编程
  • 软件开发
  • 程序
  • 光立方程序编写步骤

    基于51单片机的4*4*4光立方程序实现原理及程序代码。LED光立方的复位电路、时钟电路、每层LED灯电路控制逻辑,系统总原理图,工作流程及相关C语言源码实现。希望能够对你学习了解LED光立方程序编写及LED立方实体制...

    7小时前
  • 封装继承多态

    封装: 封装是实现面向对象程序设计的第一步,封装就是将数据或函数等集合在一个个的单元中(我们称之为类)。被封装的对象通常被称为抽象数据类型。 封装的意义: 封装的意义在于保护或者防止代码(数据)被我们无意中...

    7小时前
  • 封装是什么意思?

    即隐藏对象的属性和实现细节,仅对外公开接口,控制在程序中属性的读和修改的访问级别;将抽象得到的数据和行为(或功能)相结合,形成一个有机的整体,也就是将数据与操作数据的源代码进行有机的结合,形成“类”,其中...

    7小时前
  • 超声波模块测距51程序_单片机超声波测距c语言

    超声波检测原理 超声波测距的程序流程图 程序如下: //超声波模块程序 //超声波模块程序 //Trig = P2^0 //Echo = P3^2 #include #define uchar unsigned char #define uint unsigned int // void delay(uint z) {...

    07-01
  • 大佬带你看嵌入式系统,嵌入式系统该学习什么?

    嵌入式系统是当今的热门系统之一,在诸多领域,嵌入式系统都有所应用。为增进大家对嵌入式系统的认识,小编将为大家介绍嵌入式系统是一个什么样的专业,以及学习嵌入式系统该学习哪些内容。如果你对嵌入式系统具有...

    06-27
  • c51单片机编程要点总结

    c51单片机编程要点总结 1、头文件:#include (我用的是 STC 89C54RD+) 2、预定义:sbit LED = P1^0// 定义 P1 口的 0 位为 LED 注:“P1^0”这个写法,与 A51 不同(A51 是 P1.0),P1 是一组端口,端口号范围 0~7 注2...

    06-25
  • C语言基础知识点汇总

    总结C语言基础知识点

    06-23
  • Keil使用中的若干问题

      一、混合编程  1、模块内接口:  使用如下标志符:  #pragma asm  汇编语句  #pragma endasm  注意:如果在c51程序中使用了汇编语言,注意在keil编译器中需要激活Properties中的“Generate Assembler...

    06-23
  • ESP32-finsh

    esp32c2添加finsh实现了ping指令和AT指令解析

    06-13
  • 一文讲通C语言位域,快速掌握!

    在嵌入式系统的开发中,内存是最程序员非常需要关注的对象,尤其是MCU开发、网络协议解析、硬件寄存器操作等领域,能否对内存进行高效的利用和合理的管理,将直接影响程序的性能和硬件的稳定性。

    06-10
下载排行榜
更多
评测报告
更多
广告