www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導讀]1.nRF24L01.h文件#include typedef unsigned char uchar;typedef unsigned char uint;//****************************************IO端口定義***************************************//sbitCE =P1^4;//3//sbitCSN=P

1.nRF24L01.h文件

#include

typedef unsigned char uchar;

typedef unsigned char uint;

//****************************************IO端口定義***************************************

//sbitCE =P1^4;//3

//sbitCSN=P1^0;//4

//sbitSCK =P1^3;//5

//sbitMOSI=P1^1;//6

//sbitMISO=P3^3;//7

//sbitIRQ=P1^2;//8

sbitCE =P2^1;//3

sbitCSN=P2^2;//4

sbitSCK =P2^3;//5

sbitMOSI=P2^4;//6

sbitMISO=P2^5;//7

sbitIRQ=P2^6;//8

//sbitCE =P1^0;//3

//sbitCSN=P1^1;//4

//sbitSCK =P1^2;//5

//sbitMOSI=P1^3;//6

//sbitMISO=P1^4;//7

//sbitIRQ=P1^5;//8

//***********************************數碼管0-9編碼*******************************************

//uchar Disp_Tab[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90}; //0~~9共陽段碼

char TxBuf[]=

{

0x01,0x02,0x03,0x4,0x05,0x06,0x07,0x08,

0x09,0x10,0x11,0x12,0x13,0x14,0x15,0x16,

0x17,0x18,0x19,0x20};

//*********************************************NRF24L01*************************************

#define TX_ADR_WIDTH 5 // 5 uints TX address width

#define RX_ADR_WIDTH 5 // 5 uints RX address width

#define TX_PLOAD_WIDTH 20 // 20 uints TX payload

#define RX_PLOAD_WIDTH 20 // 20 uints TX payload

uint const TX_ADDRESS[TX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};//本地地址

uint const RX_ADDRESS[RX_ADR_WIDTH]= {0x34,0x43,0x10,0x10,0x01};//接收地址

//***************************************NRF24L01寄存器指令*******************************************************

#define READ_REG 0x00 // 讀寄存器指令

#define WRITE_REG 0x20// 寫寄存器指令

#define RD_RX_PLOAD 0x61 // 讀取接收數據指令

#define WR_TX_PLOAD 0xA0 // 寫待發(fā)數據指令

#define FLUSH_TX 0xE1// 沖洗發(fā)送 FIFO指令

#define FLUSH_RX 0xE2 // 沖洗接收 FIFO指令

#define REUSE_TX_PL 0xE3 // 定義重復裝載數據指令

#define NOP 0xFF // 保留

//*************************************SPI(nRF24L01)寄存器地址****************************************************

#define CONFIG 0x00 // 配置收發(fā)狀態(tài),CRC校驗模式以及收發(fā)狀態(tài)響應方式Config' register address

#define EN_AA 0x01 // 自動應答功能設置

#define EN_RXADDR 0x02 // 可用信道設置

#define SETUP_AW 0x03 // 收發(fā)地址寬度設置

#define SETUP_RETR 0x04 // 自動重發(fā)功能設置

#define RF_CH 0x05 // 工作頻率設置

#define RF_SETUP 0x06 // 發(fā)射速率、功耗功能設置

#define STATUS 0x07 // 狀態(tài)寄存器

#define OBSERVE_TX 0x08 // 發(fā)送監(jiān)測功能

#define CD 0x09 // 地址檢測

#define RX_ADDR_P0 0x0A // 頻道0接收數據地址'RX address pipe0' register address

#define RX_ADDR_P1 0x0B // 頻道1接收數據地址

#define RX_ADDR_P2 0x0C // 頻道2接收數據地址

#define RX_ADDR_P3 0x0D // 頻道3接收數據地址

#define RX_ADDR_P4 0x0E // 頻道4接收數據地址

#define RX_ADDR_P5 0x0F // 頻道5接收數據地址

#define TX_ADDR 0x10 // 發(fā)送地址寄存器

#define RX_PW_P0 0x11 // 接收頻道0接收數據長度 'RX payload width, pipe0' register address

#define RX_PW_P1 0x12 // 接收頻道1接收數據長度'RX payload width, pipe1' register address

#define RX_PW_P2 0x13 // 接收頻道2接收數據長度 'RX payload width, pipe2' register address

#define RX_PW_P3 0x14 // 接收頻道3接收數據長度 'RX payload width, pipe3' register address

#define RX_PW_P4 0x15 // 接收頻道4接收數據長度 'RX payload width, pipe4' register address

#define RX_PW_P5 0x16 // 接收頻道5接收數據長度 'RX payload width, pipe5' register address

#define FIFO_STATUS 0x17 // FIFO棧入棧出狀態(tài)寄存器設置'FIFO Status Register' register address

//**************************************************************************************

void Delay(unsigned int s);

void inerDelay_us(unsigned char n);

void init_NRF24L01(void);

uint SPI_RW(uint byte);

uchar SPI_Read(uchar reg);

void SetRX_Mode(void);

uint SPI_RW_Reg(uchar reg, uchar value);

uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars);

uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars);

unsigned char nRF24L01_RxPacket(unsigned char* rx_buf);

void nRF24L01_TxPacket(unsigned char * tx_buf);

//*****************************************長延時*****************************************

void Delay(unsigned int s)

{

unsigned int i;

for(i=0; i

for(i=0; i

}

//******************************************************************************************

uintbdata sta; //狀態(tài)標志

sbitRX_DR=sta^6;

sbitTX_DS=sta^5;

sbitMAX_RT=sta^4;

/******************************************************************************************

/*延時函數

/******************************************************************************************/

void inerDelay_us(unsigned char n)

{

for(;n>0;n--)

_nop_();

}

//****************************************************************************************

/*NRF24L01初始化

//***************************************************************************************/

void init_NRF24L01(void)

{

inerDelay_us(100);

CE=0; // chip enable

CSN=1; // Spi disable

SCK=0; // Spi clock line init high

SPI_Write_Buf(WRITE_REG + TX_ADDR, TX_ADDRESS, TX_ADR_WIDTH); // 寫本地地址

SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, RX_ADDRESS, RX_ADR_WIDTH); // 寫接收端地址

SPI_RW_Reg(WRITE_REG + EN_AA, 0x01); // 頻道0自動ACK應答允許

SPI_RW_Reg(WRITE_REG + EN_RXADDR, 0x01); // 允許接收地址只有頻道0,如果需要多頻道可以參考Page21

SPI_RW_Reg(WRITE_REG + RF_CH, 0); // 設置信道工作為2.4GHZ,收發(fā)必須一致

SPI_RW_Reg(WRITE_REG + RX_PW_P0, RX_PLOAD_WIDTH); //設置接收數據長度,本次設置為32字節(jié)

SPI_RW_Reg(WRITE_REG + RF_SETUP, 0x07); //設置發(fā)射速率為2MHZ,發(fā)射功率為最大值0dB TX_PWR:0dBm, Datarate:2Mbps, LNA:HCURR

SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQ收發(fā)完成中斷響應,16位CRC,主發(fā)送

}

/****************************************************************************************************

/*函數:uint SPI_RW(uint uchar)

/*功能:NRF24L01的SPI寫時序Writes one byte to nRF24L01, and return the byte read from nRF24L01

during write, according to SPI protocol

最基本的函數,完成GPIO 模擬SPI的功能。將輸出字節(jié)(MOSI)從MSB 循環(huán)輸出,同時將輸入字節(jié)(MISO )

從LSB 循環(huán)移入。上升沿讀入,下降沿輸出。(從SCK 被初始化為低電平可以判斷出)。

/****************************************************************************************************/

uint SPI_RW(uint byte)

{

uint bit_ctr;

for(bit_ctr=0;bit_ctr<8;bit_ctr++) // output 8-bit

{

MOSI = (byte & 0x80); // output 'byte', MSB to MOSI

byte = (byte << 1); // shift next bit into MSB..

SCK = 1; // Set SCK high..

byte |= MISO; // capture current MISO bit

SCK = 0; // ..then set SCK low again

}

return(byte); // return read byte

}

/****************************************************************************************************

/*函數:uchar SPI_Read(uchar reg)

/*功能:NRF24L01的SPI時序。讀取寄存器值的函數:基本思路就是通過READ_REG 命令(也就是0x00+寄存器地址),

把寄存器中的值讀出來。對于函數來說也就是把reg 寄存器的值讀到reg_val 中去。

/****************************************************************************************************/

uchar SPI_Read(uchar reg)

{

uchar reg_val;

CSN = 0; // CSN low, initialize SPI communication...

SPI_RW(reg); // Select register to read from..

reg_val = SPI_RW(0); // ..then read registervalue

CSN = 1; // CSN high, terminate SPI communication

return(reg_val); // return register value

}

/****************************************************************************************************/

/*功能:NRF24L01讀寫寄存器函數

寄存器訪問函數:用來設置24L01 的寄存器的值?;舅悸肪褪峭ㄟ^WRITE_REG 命令(也就是0x20+寄存器地址)把要

設定的值寫到相應的寄存器地址里面去,并讀取返回值。對于函數來說也就是把value 值寫到reg 寄存器中。

需要注意的是,訪問NRF24L01 之前首先要enable 芯片(CSN=0;),訪問完了以后再disable芯片(CSN=1;)。

/****************************************************************************************************/

uint SPI_RW_Reg(uchar reg, uchar value)

{

uint status;

CSN = 0; // CSN low, init SPI transaction

status = SPI_RW(reg); // select register

//check_status(status);//SPI_Read_Buf(WRITE_REG+CONFIG,test,1));

SPI_RW(value); // ..and write value to it..

//******************test************************

//{

//int i=0;

////test0 = SPI_Read_Buf(WRITE_REG +FIFO_STATUS,test,1);

//i = status/16;

//if(i<10){LCD_write_char(0,1,i+'0');}

//else{LCD_write_char(0,1,i-10+'A');}

//i = status%16;

//if(i<10){LCD_write_char(1,1,i+'0');}

//else{LCD_write_char(1,1,i-10+'A');}

//while(1);

//}

//******************end************************

CSN = 1; // CSN high again

return(status); // return nRF24L01 status byte

}

/****************************************************************************************************/

/*函數:uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)

/*功能: 用于讀數據,reg:為寄存器地址,pBuf:為待讀出數據地址,uchars:讀出數據的個數

接收緩沖區(qū)訪問函數:主要用來在接收時讀取FIFO緩沖區(qū)中的值?;舅悸肪褪峭ㄟ^READ_REG 命令把數據從接

收 FIFO(RD_RX_PLOAD)中讀出并存到數組里面去。

/****************************************************************************************************/

uint SPI_Read_Buf(uchar reg, uchar *pBuf, uchar uchars)

{

uint status,uchar_ctr;

CSN = 0; // Set CSN low, init SPI tranaction

status = SPI_RW(reg); // Select register to write to and read status uchar

for(uchar_ctr=0;uchar_ctr

pBuf[uchar_ctr] = SPI_RW(0); // Perform SPI_RW to read byte from nRF24L01

CSN = 1; // Set CSN high again

return(status); // return nRF24L01 status uchar

}

/*********************************************************************************************************

/*函數:uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)

/*功能: 用于寫數據:為寄存器地址,pBuf:為待寫入數據地址,uchars:寫入數據的個數

發(fā)射緩沖區(qū)訪問函數:主要用來把數組里的數放到發(fā)射 FIFO 緩沖區(qū)中?;舅悸肪褪峭ㄟ^WRITE_REG 命令把

數據存到發(fā)射 FIFO(WR_TX_PLOAD)中去。

/*********************************************************************************************************/

uint SPI_Write_Buf(uchar reg, uchar *pBuf, uchar uchars)

{

uint status,uchar_ctr;

CSN = 0; //SPI使能 // Set CSN low, init SPI tranaction

status = SPI_RW(reg); // Select register to write to and read status byte

for(uchar_ctr=0; uchar_ctr

SPI_RW(*pBuf++);

/* {

Display(*pBuf);//顯示程序

Delay(400) ;

SPI_RW(*pBuf);

Delay(2000) ;

pBuf++;

}*/

CSN = 1; // // Set CSN high again ,關閉SPI

return(status); //// return nRF24L01 status byte

}

/****************************************************************************************************/

/*函數:void SetRX_Mode(void)

/*功能:數據接收配置

This function initializes one nRF24L01 device to RX Mode, set RX address, writes RX payload width,

select RF channel, datarate & LNA HCURR. After init, CE is toggled high, which means that this

device is now ready to receive a datapacket.

/****************************************************************************************************/

void SetRX_Mode(void)

{

CE=0;

SPI_RW_Reg(WRITE_REG + CONFIG, 0x0f); // IRQ收發(fā)完成中斷響應,16位CRC,主接收,???????接收沒有

CE = 1;

inerDelay_us(130);

}

/******************************************************************************************************/

/*函數:unsigned char nRF24L01_RxPacket(unsigned char* rx_buf)

/*功能:數據讀取后放如rx_buf接收緩沖區(qū)中

/******************************************************************************************************/

unsigned char nRF24L01_RxPacket(unsigned char* rx_buf) //接收函數,返回1表示有數據收到,否則沒有數據接受到

{

unsigned char revale=0;

sta=SPI_Read(STATUS);// 讀取狀態(tài)寄存其來判斷數據接收狀況// read register STATUS's value

if(RX_DR)// 判斷是否接收到數據// ifreceive data ready (RX_DR) interrupt

{

CE = 0;//SPI使能

SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer

revale =1;//讀取數據完成標志

}

SPI_RW_Reg(WRITE_REG+STATUS,sta); //接收到數據后RX_DR,TX_DS,MAX_PT都置高為1,通過寫1來清楚中斷標志.

//clear RX_DR or TX_DS or MAX_RT interrupt flag

return revale;

}

/***********************************************************************************************************

/*函數:void nRF24L01_TxPacket(unsigned char * tx_buf)

/*功能:發(fā)送 tx_buf中數據

/**********************************************************************************************************/

void nRF24L01_TxPacket(unsigned char * tx_buf)

{

int dat;

CE=0;//StandBy I模式

SPI_Write_Buf(WRITE_REG + RX_ADDR_P0, TX_ADDRESS, TX_ADR_WIDTH); // 裝載接收端地址

SPI_Write_Buf(WR_TX_PLOAD, tx_buf, TX_PLOAD_WIDTH); // 裝載數據// Writes data to TX payload

SPI_RW_Reg(WRITE_REG + CONFIG, 0x0e); // IRQ收發(fā)完成中斷響應,16位CRC,主接收???????????發(fā)送中被屏蔽,而接收中沒有屏蔽!

// Set PWR_UP bit, enable CRC(2 bytes) & Prim:TX. MAX_RT & TX_DS enabled..

CE=1;//置高CE,激發(fā)數據發(fā)送

inerDelay_us(10);

//CE=0;

}

2、1602.c文件

#include

sbit RS = P3^4; //定義端口

sbit RW = P3^5;

sbit EN = P3^6;

#define RS_CLR RS=0

#define RS_SET RS=1

#define RW_CLR RW=0

#define RW_SET RW=1

#define EN_CLR EN=0

#define EN_SET EN=1

/******************************************************************/

/* 微秒延時函數 */

/******************************************************************/

void delay_us(unsigned int n) //延時 如果需要高精度延時 請嵌入匯編

{

if (n == 0)

{

return ;

}

while (--n);

}

/******************************************************************/

/* 毫秒函數聲明 */

/******************************************************************/

void delay_ms(unsigned char i)

{

unsigned char a, b;

for (a = 1; a < i; a++)

{

for (b = 1; b; b++)

{ ; }

}

}

/******************************************************************/

/* 寫入命令函數 */

/******************************************************************/

void LCD_write_com(unsigned char com)

{

RS_CLR;

RW_CLR;

EN_SET;

P0 = com;

delay_us(5);

EN_CLR;

}

/******************************************************************/

/* 寫入數據函數 */

/******************************************************************/

void LCD_write_Data(unsigned char Data)

{

RS_SET;

RW_CLR;

EN_SET;

P0 = Data;

delay_us(5);

EN_CLR;

}

/******************************************************************/

/* 清屏函數 */

/******************************************************************/

void LCD_clear(void)

{

LCD_write_com(0x01);

delay_ms(5);}

/******************************************************************/

/* 寫入字符串函數 */

/******************************************************************/

void LCD_write_str(unsigned char x,unsigned char y,unsigned char *s)

{

if (y == 0)

{

LCD_write_com(0x80 + x);

}

else

{

LCD_write_com(0xC0 + x);

}

while (*s)

{

LCD_write_Data( *s);

s ++;

}

}

/******************************************************************/

/* 寫入字節(jié)函數 */

/******************************************************************/

void LCD_write_char(unsigned char x,unsigned char y,unsigned char Data)

{

if (y == 0)

{

LCD_write_com(0x80 + x);

}

else

{

LCD_write_com(0xC0 + x);

}

LCD_write_Data( Data);

}

/******************************************************************/

/* 初始化函數 */

/******************************************************************/

void LCD_init(void)

{

LCD_write_com(0x38); /*顯示模式設置*/

delay_ms(5);

LCD_write_com(0x38);

delay_ms(5);

LCD_write_com(0x38);

delay_ms(5);

LCD_write_com(0x38);

LCD_write_com(0x08); /*顯示關閉*/

LCD_write_com(0x01); /*顯示清屏*/

LCD_write_com(0x06); /*顯示光標移動設置*/

delay_ms(5);

LCD_write_com(0x0C); /*顯示開及光標設置*/

}

3、test.h文件

char test[]={0x00,0x00};

//unsigned char test0=0xff;

//*****************************************

void check_status(unsigned char test0)

{

int i=0;

//test0 = SPI_Read_Buf(WRITE_REG +FIFO_STATUS,test,1);

i = test0/16;

if(i<10){LCD_write_char(0,1,i+'0');}

else{LCD_write_char(0,1,i-10+'A');}

i = test0%16;

if(i<10){LCD_write_char(1,1,i+'0');}

else{LCD_write_char(1,1,i-10+'A');}

}

//*************************************

4、send.c文件

#include

#include"1602.h"

#include"test.h"

#include"nrf24l01.h"


//************************************主函數************************************************************

void main(void)

{

LCD_init();

init_NRF24L01() ;

nRF24L01_TxPacket(TxBuf);// Transmit Tx buffer data

Delay(6000);

LCD_write_str(0,0,"TX starting...");


while(1)

{

nRF24L01_TxPacket(TxBuf);// Transmit Tx buffer data

//******************************************

//while(1)

//{

//SPI_Read_Buf(READ_REG+FIFO_STATUS,test,1);//

//check_status(test[0]);

//}

//******************************************

Delay(6000);

SPI_RW_Reg(WRITE_REG+STATUS,0XFF);

LCD_write_char(0,1,TxBuf[0]+0x30);

LCD_write_char(1,1,TxBuf[1]+0x30);

LCD_write_char(2,1,TxBuf[2]+0x30);

LCD_write_char(3,1,TxBuf[3]+0x30);

LCD_write_char(4,1,TxBuf[4]+0x30);

TxBuf[4]=0x00; TxBuf[3]=0x01;TxBuf[2]=0x02;TxBuf[1]=0x03;TxBuf[0]=0x04;

nRF24L01_TxPacket(TxBuf);// Transmit Tx buffer data

//******************************************

//while(1)

//{

//SPI_Read_Buf(READ_REG+FIFO_STATUS,test,1);//

//check_status(test[0]);

//}

//******************************************

Delay(6000);

SPI_RW_Reg(WRITE_REG+STATUS,0XFF);

LCD_write_char(0,1,TxBuf[0]+0x30);

LCD_write_char(1,1,TxBuf[1]+0x30);

LCD_write_char(2,1,TxBuf[2]+0x30);

LCD_write_char(3,1,TxBuf[3]+0x30);

LCD_write_char(4,1,TxBuf[4]+0x30);

TxBuf[4]=0x04; TxBuf[3]=0x03;TxBuf[2]=0x02;TxBuf[1]=0x01;TxBuf[0]=0x00;

}

}


本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉