1. 程式人生 > >基於51微控制器的NRF905收發程式

基於51微控制器的NRF905收發程式

程式簡介:該程式能同時進行接收和傳送功能,可以實現兩塊微控制器互相通訊。實現的效果:能控制P0口的4個燈,並簡單驅動蜂鳴器發聲。

#include <reg52.h>

#include <ABSACC.h>
#include <intrins.h>
#include <stdio.h>
//----------------------------------------------------------------------------------------------------------------
#define uint unsigned int
#define uchar unsigned char
//----------------------------------------------------------------------------------------------------------------
#define BYTE_BIT00x01
#define BYTE_BIT10x02
#define BYTE_BIT20x04
#define BYTE_BIT30x08
#define BYTE_BIT40x10
#define BYTE_BIT50x20
#define BYTE_BIT60x40
#define BYTE_BIT70x80
//----------------------------------------------------------------------------------------------------------------
bdata unsigned  char DATA_BUF;
#define DATA7((DATA_BUF&BYTE_BIT7) != 0)
#define DATA0   ((DATA_BUF&BYTE_BIT0) != 0)
sbitflag =DATA_BUF^7;
sbitflag1 =DATA_BUF^0;
//---------------------------------------------------傳送資料緩衝區-------------------------------------------------
#define TxRxBuf_Len 4
unsigned char TxRxBuf[TxRxBuf_Len]=
{
0x29,0x30,0x31,0x32,
};


//----------------------------------------------NRF905控制IO------------------------------------------------------
sbitTXEN=P2^4;
sbitTRX_CE=P2^0;
sbitPWR=P3^4;
//----------------------------------------------NRF905 SPI介面---------------------------------------------------
sbitMISO=P2^2;
sbitMOSI=P2^6;
sbitSCK=P2^3;
sbitCSN=P2^7;
//----------------------------------------nrf905狀態標誌---------------------------------------------------------
sbitAM=P2^1;
sbitDR=P3^5;
sbitCD=P2^5;
//---------------------------------------------------------------------------------------------------------------
sbitled3=P0^3;
sbitled2=P0^2;
sbitled1=P0^1;
sbitled0=P0^0;
//------------------------------------------按鍵定義--------------------------------------------------------------------
sbit    KEY0    =P3^2;
sbit    KEY1    =P3^3;
/*/----------------------------------------------NRF905控制IO------------------------------------------------------
sbitTXEN=P1^0;
sbitTRX_CE=P3^2;
sbitPWR=P1^1;
//----------------------------------------------NRF905 SPI介面---------------------------------------------------
sbitMISO=P1^6;
sbitMOSI=P1^5;
sbitSCK=P1^7;
sbitCSN=P1^3;
//----------------------------------------nrf905狀態標誌---------------------------------------------------------
sbitAM=P1^4;
sbitDR=P3^3;
sbitCD=P1^2;
//---------------------------------------------------------------------------------------------------------------
sbitled3=P2^0;
sbitled2=P2^1;
sbitled1=P2^2;
sbitled0=P2^3;
//--------------------------------------------------------------------------------------------------------------
sbitKEY0=P3^6;
sbitKEY1=P3^7;
//--------------------------------------------------------------------------------
*/
sbitBELL=P1^0; 
//-----------------------------------------------------------------------------------------------------------------
//uchar seg[10]={0xC0,0xCF,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};         //0~~9段碼
//-------------------------------------------------------nrf905控制指令-------------------------------------------
#define WC0x00
#define RC0x10
#define WTP0x20
#define RTP0x21
#define WTA0x22
#define RTA0x23
#define RRP0x24
//------------------------------------------------NRF905暫存器配置------------------------------------------------
unsigned char idata RFConf[11]=
{
  0x00,                             //配置命令//
  0x4c,                             //CH_NO,配置頻段在430MHZ
  0x0c,                             //輸出功率為10db,不重發,節電為正常模式
  0x44,                             //地址寬度設定,為4位元組
  0x04,0x04,                        //接收發送有效資料長度為4位元組
  0xCC,0xCC,0xCC,0xCC,              //接收地址
  0x58,                              //CRC充許,8位CRC校驗,外部時鐘訊號不使能,16M晶振
};
code TxAddress[4]={0xcc,0xcc,0xcc,0xcc};
char tf;


//------------------------------------------------延時------------------------
static void Delay(uchar n)
{
uint i;
while(n--)
for(i=0;i<80;i++);
}
//---------------------------------------------------SPI讀函式-----------------------------------------------------


//------------------------------------------------蜂鳴器------------------------------------------------------------
void fengmingqi(void)
{
int i;
for(i=20;i>0;i--)
{
BELL = 1;
Delay(10);
BELL = 0;
Delay(10);
}
}
unsigned char SpiRead(void)
{
unsigned char j;
for (j=0;j<8;j++)
{
        DATA_BUF=DATA_BUF<<1;
SCK=1;
if (MISO) //讀取最高位,儲存至最末尾,通過左移位完成整個位元組
{
DATA_BUF|=BYTE_BIT0;
}
else
{
DATA_BUF&=~BYTE_BIT0;
}
SCK=0;
}
return DATA_BUF;
}
//-------------------------------------------------SPI寫函式----------------------------------------------------------
void SpiWrite(unsigned char send)
{
unsigned char i;
DATA_BUF=send;
for (i=0;i<8;i++)
{
if (DATA7) //總是傳送最高位
{
MOSI=1;
}
else
{
MOSI=0;
}
SCK=1;
DATA_BUF=DATA_BUF<<1;
SCK=0;
}
}
//------------------------------------------------------初始化nRF905---------------------------------------------
void nRF905Init(void)
{
    CSN=1;// Spi disable
SCK=0; // Spi clock line init low
DR=0;// Init DR for input
AM=0;// Init AM for input
CD=0;// Init CD for input
PWR=1; // nRF905 power on
TRX_CE=0; // Set nRF905 in standby mode
TXEN=0; // set radio in Rx mode
}
//-----------------------------------------------------初始化暫存器-----------------------------------------------
void Config905(void)
{
uchar i;
CSN=0; // Spi enable for write a spi command
//SpiWrite(WC);// Write config command寫放配置命令
for (i=0;i<11;i++)// Write configration words  寫放配置字
{
  SpiWrite(RFConf[i]);
}
CSN=1; // Disable Spi
}
//-----------------------------------------------------傳送資料打包---------------------------------------------------
void TxPacket(uchar *TxRxBuf)
{
uchar i;
//Config905();
CSN=0;
SpiWrite(WTP);// Write payload command
for (i=0;i<4;i++)
{
SpiWrite(TxRxBuf[i]);// Write 32 bytes Tx data
}// Spi enable for write a spi command
CSN=1;
Delay(1); // Spi disable
CSN=0; // Spi enable for write a spi command
SpiWrite(WTA);// Write address command
for (i=0;i<4;i++)// Write 4 bytes address
{
SpiWrite(TxAddress[i]);
}
CSN=1; // Spi disable
TRX_CE=1; // Set TRX_CE high,start Tx data transmission
Delay(1); // while (DR!=1);
TRX_CE=0; // Set TRX_CE low
}
//----------------------------------------------------------設定傳送狀態---------------------------------------------
void SetTxMode(void)
{
TRX_CE=0;
TXEN=1;
Delay(1); // delay for mode change(>=650us)
}
//-----------------------------------------------設定傳送狀態---------------------------------------------------
void SetRxMode(void)
{
TXEN=0;
TRX_CE=1;
Delay(1); // delay for mode change(>=650us)
}
//-------------------------------------------------判斷資料接收狀態-----------------------------------------------------
unsigned char CheckDR(void)//檢查是否有新資料傳入 Data Ready
{
if (DR=1&&TRX_CE==1 && TXEN==0)
{
       // Delay(50)  ;
return 1;
}
else
{
return 0;
}
}
//----------------------------------------------------讀NRF905接收資料------------------------------------------------------------
void RxPacket(void)
{
uchar i;
    Delay(1);
//TRX_CE=0; // Set nRF905 in standby mode
    Delay(100);
    TRX_CE=0;
CSN=0; // Spi enable for write a spi command
    Delay(1);
SpiWrite(RRP);
for (i = 0 ;i < 4 ;i++)

TxRxBuf[i]=SpiRead();// Read data and save to buffer       
}
CSN=1;
    Delay(10);
TRX_CE=1;
}
//--------------------------------------------------------資料接收------------------------------------------------
void  RX(void)
{
          SetRxMode();// Set nRF905 in Rx mode
          while (CheckDR()==0);
 Delay(10);
  RxPacket();
 if(TxRxBuf[0]==0x29)
 {
 
led0=1;
led1=1;
led2=1;
led3=1;

 }
 if(TxRxBuf[0]==0x30)
 {
 
led0=0;
led1=0;
led2=0;
   led3=0;
fengmingqi();
 }
}
//-----------------------------------------------------------------------------------------------------------------
void main(void)
{
        nRF905Init();
     Config905();
led0=1;
led1=1;
led2=1;
led3=1;
        while(1)
{
RX();
  if(KEY0 ==0 )
{
tf = 1 ;
TxRxBuf[0]=0x29;
//TxRxBuf[1]=0x30;
//TxRxBuf[2]=0x31;
//TxRxBuf[3]=0x32;  

led0=0;
led1=1;
led2=0;
led3=1;
}
  if(KEY1 ==0 )
{tf = 1 ; 
TxRxBuf[0]=0x30;
//TxRxBuf[1]=0x31;
//TxRxBuf[2]=0x32;
//TxRxBuf[3]=0x29;  

led0=1;
led1=0;
led2=1;
led3=0;
}
      if (tf==1)
{
                SetTxMode();// Set nRF905 in Tx mode
   TxPacket(TxRxBuf);// Send data by nRF905
tf = 0;
}
}
}

相關推薦

基於51微控制器NRF905收發程式

程式簡介:該程式能同時進行接收和傳送功能,可以實現兩塊微控制器互相通訊。實現的效果:能控制P0口的4個燈,並簡單驅動蜂鳴器發聲。 #include <reg52.h> #include <ABSACC.h> #include <intrins.

基於51 微控制器的串列埠收發資料

在進行串列埠的收發資料過程中一定要注意波特率的問題。 大多數51微控制器用的都是11m晶振而只有少部分用的是奇葩的12m(樓主的就是),在12m晶振進行串列埠通訊時切忌要將波特率設定為4800以下,應為12m晶振的波特率在9600以上誤差很大容易丟失資料,動手能力強的可以折騰一下用定時器輸出96

基於51微控制器的液晶顯示屏LCD1602簡單計算器程式

/*     S16 S12 S8 S4分別是123+S15 S11 S7 S3分別是456-S14 S10 S6 S2分別是789*S13 S9 S5 S1分別是0 CE =/*//* 實現兩個數的運算,每個數的位數至少可以八位 (在液晶顯示屏LCD1602上顯示) */#

基於51微控制器控制的籃球比賽計時、計分系統設計與模擬(含設計圖和C語言程式原始碼)

1. 設計任務: 本次設計用由AT89C51程式設計控制LED七段數碼管作顯示的球賽計時計分系統。系統應具有賽程定時設定,賽程時間暫停,及時重新整理甲、乙雙方的成績以及賽後成績暫存等功能。 內容包括:顯示、鍵盤、時鐘等內容 2. 設計說明

基於51微控制器的矩陣計算器設計

      當初本科的畢業設計不是很完美,一直想把它完善一下,這學期剛開始有點時間,就以一個小專案的方式,綜合自己這一年多來的程式碼閱讀收穫,重寫了這個工程。 一,平臺的重新搭建 Ø  在win7上重新安裝了proteus7.8用於模擬階段的測試,並從以前

基於51微控制器的交通燈控制系統設計

第一章 硬體設計與原理 以AT89C51微控制器為核心,起著控制作用。系統包括數碼管顯示電路、復位電路、時鐘電路、發光二級管電路和按鍵電路。設計思路分為六個模組:復位電路、晶振電路模組、AT89C51、數碼管顯示電路、發光二級管電路和按鍵電路這六個模組。 1.2 硬體設計分析 1.

基於51微控制器的簡易電子琴設計

轉載地址: https://blog.csdn.net/zy010101/article/details/80538312                   

基於51微控制器的科學計算器

科學計算器1.任務 設計製作一個科學計算器。 2. 要求 (1)按數字 0-9 時應發出蜂鳴器聲音,數越大,頻率越高。 (20 分) (2) 完成任意兩位數(範圍 0-99)的加減乘除運算,結果只需顯示整數部分,但如果結果為負數應顯示負號。 (20 分) (3) 完成任意兩位數(範圍 0-

IIC協議解讀——基於51微控制器

#include<reg52.h> #define uchar unsigned char sbit sda=P2^0; sbit scl=P2^1; uchar a; void delay() {     ;; } void start() &

基於51微控制器的秒錶設計

  #include<reg52.h>   #define uchar unsigned char   #define uint unsigned int   void init();//hanshushengming   void de

基於51微控制器的巡線小車

#include <reg52.h> #define uint unsigned int #define uchar unsigned char uint time,left, right,pwm0,pwm1,pwm2,pwm3; sbit IN1 = P1^0; sbit IN

基於51微控制器的簡易計算器

 //S4:+    S8:-   S12:*   S16:/   S15: =   S13:  REMOVE // #include<reg51.h

基於51微控制器的簡易密碼鎖

一個基於51微控制器的簡易密碼鎖,廢話不多說,直接貼圖貼程式碼 1.電路圖 電路組成:5V電源+51微控制器最小系統+LCD1602顯示屏+4*4矩陣鍵盤 2.程式分析 (1)LCD1602驅動程式 #include "1602.h" #include "delay.h" #

基於51微控制器的LCD1602電子時鐘

摘要: 51系列微控制器是各微控制器中最為典型和最有代表性的一種。由RAM ,ROM,CPU構成,定時,計數和多種介面於一體的微控制器。本次設計的數位電子時鐘採用了STC89C52晶片進行控制,使用DS1302時鐘晶片產生時鐘資料,通過LCD1602液晶顯示屏進行重新整理顯示。同時,使用4*

超聲波測距模組(LCD顯示)—基於51微控制器

#include <reg52.h> #define uint unsigned int #define uchar unsigned char sbit Trig = P1^0; //控制端 sbit Echo = P1^1; //接收端

基於51微控制器的溫度控制系統畢設

基於51微控制器的溫度控制系統畢設 分享一下微控制器畢設課程計參考資料33個,獻給大四的朋友,畢業設計就不用愁了,如果有什麼不懂的地方可以加群大家一起交流:813238832資料下載的地址:https://bbs.usoftchina.com/thread-208012-1-1.html 1、CDMA通訊

基於51微控制器的LCD液晶屏

``` #include"reg52.h" sbit lcden=P1^0; sbit lcdrs=P1^1; sbit lcdrw=P1^2; void delay_ms(unsigned int t); void lcd_write_com(unsign

基於51微控制器的簡單計算器

在上一篇中,我們已經說過了基於51微控制器的簡單撥號器,在下邊,我們將寫一個計算器程式,原理很簡單,只需要在撥號器的基礎上,算出撥號器所表示的數字,並進行計算即可。 程式碼如下; #include"reg51.h" #include<intrins

【轉】51微控制器精確延遲程式

51微控制器精確延時程式(晶振12MHz,一個機器週期1us.) 幾個精確延時程式:在精確延時的計算當中,最容易讓人忽略的是計算迴圈外的那部分延時,在對時間要求不高的場合,這部分對程式不會造成影響. 一. 500ms延時子程式:(晶振12MHz,一個機器週期1us.)   

基於51微控制器的步進電機的控制

前面筆者分享過基於51微控制器的兩種小車製作,我們利用的是L298N驅動控制電機轉動,那麼接下來,筆者給大家介紹兩種利用51微控制器控制步進電機的小程式。 首先我們要如何使電機轉動呢,源程式如下: #include <reg52.h> u