求:nrf52832单片机对I2S总线的驱动程序,或语音信号从I2S输入进FIFO在经过单片机内部传输到蓝牙端口程序! 5C

毕业设计,要求制作一个语音识别系统,语音信号通过数字麦克,再通过I2S总线,进入nrf2832单片机,再通过蓝牙传输到pc端,通过labview或者unity3D解码在电脑上显示识别出来,求大神帮忙

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
求大神:nrf52832的I2S驱动程序,或nrf52832内部语音传输的程序示例?

毕业设计,语音信号通过I2S传入nrf2832的FIFO中,内部传输到蓝牙端,请问这其中需要什么程序,具体是什么,谢谢!

nrf52832单片机,接收数据并传递到蓝牙模块这个过程,有没有具体的程序,求大神解惑?

用I2S传输语音数据发送到nrf内,接下来要通过蓝牙传递到pc端,这中间的程序不会写,有没有能完整写出来的,给点思路也行啊

NRF52832 下载无线鼠标例程的问题

.\_build\nrf52832_xxaa.axf: error: L6050U: The code size of this image (41300 bytes) exceeds the maximum allowed for this version of the linker.

NRF 52832 蓝牙 如何发送自定义广播报文

这个是我下载nordic_template 程序到开发板上 用nrf connect 工具 获取的数据, 现在我需要发送自定义的广播报文,该怎么修改呢, 这个是广播初始化函数: static void advertising_init(void) { uint32_t err_code; ble_advdata_t advdata; ble_adv_modes_config_t options; // Build advertising data struct to pass into @ref ble_advertising_init. memset(&advdata, 0, sizeof(advdata)); advdata.name_type = BLE_ADVDATA_FULL_NAME; advdata.include_appearance = false; advdata.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE; // advdata.uuids_complete.uuid_cnt = sizeof(m_adv_uuids) / sizeof(m_adv_uuids[0]); // advdata.uuids_complete.p_uuids = m_adv_uuids; static ble_advdata_manuf_data_t manuf_data; static uint8_t mydata = 0; //????????? //????????????????? //?,???????????????1 manuf_data.company_identifier = 0xC7; manuf_data.data.size = 1; manuf_data.data.p_data = &mydata; //mydata++; //??????1 advdata.p_manuf_specific_data = &manuf_data; memset(&options, 0, sizeof(options)); options.ble_adv_fast_enabled = true; options.ble_adv_fast_interval = APP_ADV_INTERVAL; options.ble_adv_fast_timeout = APP_ADV_TIMEOUT_IN_SECONDS; err_code = ble_advertising_init(&advdata, NULL, &options, on_adv_evt, NULL); APP_ERROR_CHECK(err_code); } 没有在广播初始化中代码中找到 关于第三行数据 2 0x09 0x4E ,的定义 自定义的广播报文应该放在什么地方? 请大神支招

芯片NRF52832如何测得高脉冲的时间?

我可以中断得到上升沿或者下降沿 ,但是怎么测得它持续的时间呢?

在安卓模拟器中调试nRF24L01射频模块要不要装驱动程序?

通过串口转usb将nRF24L01射频模块和电脑连接,然后在安卓模拟器中调试模块,需要给安卓模拟器安装安卓驱动程序吗?

基于单片机STC15W401AS的nRF24L01无线通信无法调通

# 这是发送部分的程序和接收部分 ``` #include<STC15F2K60S2.h> #include"global_define.h" #include"NRF24L01.h" #include"Delay.h" sbit CE=P5^5; //RX/TX模式选择端 sbit IRQ=P3^7; //可屏蔽中断端 sbit CSN=P5^4; //SPI片选端//就是SS sbit MOSI=P1^3; //SPI主机输出从机输入端 sbit MISO=P1^4; //SPI主机输出从机输出端 sbit SCLK=P1^5; //SPI时钟端 uchar code TxAddr[]={0x34,0x43,0x10,0x10,0x01};//发送地址 /*****************状态标志*****************************************/ uchar bdata sta; //状态标志 sbit RX_DR=sta^6; sbit TX_DS=sta^5; sbit MAX_RT=sta^4; /*****************SPI时序函数******************************************/ uchar NRFSPI(uchar date) { uchar i; for(i=0;i<8;i++) // 循环8次 { if(date&0x80) MOSI=1; else MOSI=0; // byte最高位输出到MOSI date<<=1; // 低一位移位到最高位 SCLK=1; if(MISO) // 拉高SCK,nRF24L01从MOSI读入1位数据,同时从MISO输出1位数据 date|=0x01; // 读MISO到byte最低位 SCLK=0; // SCK置低 } return(date); // 返回读出的一字节 } /**********************NRF24L01初始化函数*******************************/ void NRF24L01Int() { Delay(2);//让系统什么都不干 CE=0; //待机模式1 CSN=1; SCLK=0; IRQ=1; } /*****************SPI读寄存器一字节函数*********************************/ uchar NRFReadReg(uchar RegAddr) { uchar BackDate; CSN=0;//启动时序 NRFSPI(RegAddr);//写寄存器地址 BackDate=NRFSPI(0x00);//写入读寄存器指令 CSN=1; return(BackDate); //返回状态 } /*****************SPI写寄存器一字节函数*********************************/ uchar NRFWriteReg(uchar RegAddr,uchar date) { uchar BackDate; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入地址 NRFSPI(date);//写入值 CSN=1; return(BackDate); } /*****************SPI读取RXFIFO寄存器的值********************************/ uchar NRFReadRxDate(uchar RegAddr,uchar *RxDate,uchar DateLen) { //寄存器地址//读取数据存放变量//读取数据长度//用于接收 uchar BackDate,i; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入要读取的寄存器地址 for(i=0;i<DateLen;i++) //读取数据 { RxDate[i]=NRFSPI(0); } CSN=1; return(BackDate); } /*****************SPI写入TXFIFO寄存器的值**********************************/ uchar NRFWriteTxDate(uchar RegAddr,uchar *TxDate,uchar DateLen) { //寄存器地址//写入数据存放变量//读取数据长度//用于发送 uchar BackDate,i; CSN=0; BackDate=NRFSPI(RegAddr);//写入要写入寄存器的地址 for(i=0;i<DateLen;i++)//写入数据 { NRFSPI(*TxDate++); } CSN=1; return(BackDate); } /*****************NRF设置为发送模式并发送数据******************************/ void NRFSetTxMode(uchar *TxDate) {//发送模式 CE=0; NRFWriteTxDate(W_REGISTER+TX_ADDR,TxAddr,TX_ADDR_WITDH);//写寄存器指令+接收地址使能指令+接收地址+地址宽度 NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH);//为了应答接收设备,接收通道0地址和发送地址相同 NRFWriteTxDate(W_TX_PAYLOAD,TxDate,TX_DATA_WITDH);//写入数据 /******下面有关寄存器配置**************/ NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+SETUP_RETR,0x0a); // 自动重发延时等待250us+86us,自动重发10次 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益 NRFWriteReg(W_REGISTER+CONFIG,0x0e); // CRC使能,16位CRC校验,上电 CE=1; Delay(5);//保持10us秒以上 } /*****************NRF设置为接收模式并接收数据******************************/ //主要接收模式 void NRFSetRXMode() { CE=0; NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH); // 接收设备接收通道0使用和发送设备相同的发送地址 NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RX_PW_P0,TX_DATA_WITDH); // 接收通道0选择和发送通道相同有效数据宽度 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益*/ NRFWriteReg(W_REGISTER+CONFIG,0x0f); // CRC使能,16位CRC校验,上电,接收模式 CE = 1; Delay(5);//保持10us秒以上 } /****************************检测应答信号******************************/ uchar CheckACK() { //用于发射 sta=NRFReadReg(R_REGISTER+STATUS); // 返回状态寄存器 if(TX_DS||MAX_RT) //发送完毕中断 { NRFWriteReg(W_REGISTER+STATUS,0xff); // 清除TX_DS或MAX_RT中断标志 CSN=0; NRFSPI(FLUSH_TX);//用于清空FIFO !!关键!!不然会出现意想不到的后果!!!大家记住!! CSN=1; return(0); } else return(1); } /******************判断是否接收收到数据,接到就从RX取出*********************/ //用于接收模式 /*uchar NRFRevDate(uchar *RevDate) { uchar RevFlags=0; sta=NRFReadReg(R_REGISTER+STATUS);//发送数据后读取状态寄存器 if(RX_DR) // 判断是否接收到数据 { CE=0; //SPI使能 NRFReadRxDate(R_RX_PAYLOAD,RevDate,RX_DATA_WITDH);// 从RXFIFO读取数据 RevFlags=1; //读取数据完成标志 } NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 return(RevFlags); }*/ # 下面是接收部分 #include<STC15F2K60S2.h> #include"global_define.h" #include"NRF24L01.h" #include"Delay.h" sbit CE=P5^5; //RX/TX模式选择端 sbit IRQ=P3^7; //可屏蔽中断端 sbit CSN=P5^4; //SPI片选端//就是SS sbit MOSI=P1^3; //SPI主机输出从机输入端 sbit MISO=P1^4; //SPI主机输出从机输出端 sbit SCLK=P1^5; //SPI时钟端 uchar RevTempDate[32]; //最后一位用来存放结束标志 uchar code TxAddr[]={0x34,0x43,0x10,0x10,0x01};//发送地址 /*****************状态标志*****************************************/ uchar bdata sta; //状态标志 sbit RX_DR=sta^6; sbit TX_DS=sta^5; sbit MAX_RT=sta^4; /*****************SPI时序函数******************************************/ uchar NRFSPI(uchar date) { uchar i; for(i=0;i<8;i++) // 循环8次 { if(date&0x80) MOSI=1; else MOSI=0; // byte最高位输出到MOSI date<<=1; // 低一位移位到最高位 SCLK=1; if(MISO) // 拉高SCK,nRF24L01从MOSI读入1位数据,同时从MISO输出1位数据 date|=0x01; // 读MISO到byte最低位 SCLK=0; // SCK置低 } return(date); // 返回读出的一字节 } /**********************NRF24L01初始化函数*******************************/ void NRF24L01Int() { Delay(2);//让系统什么都不干 CE=0; //待机模式1 CSN=1; SCLK=0; IRQ=1; } /*****************SPI读寄存器一字节函数*********************************/ uchar NRFReadReg(uchar RegAddr) { uchar BackDate; CSN=0;//启动时序 NRFSPI(RegAddr);//写寄存器地址 BackDate=NRFSPI(0x00);//写入读寄存器指令 CSN=1; return(BackDate); //返回状态 } /*****************SPI写寄存器一字节函数*********************************/ uchar NRFWriteReg(uchar RegAddr,uchar date) { uchar BackDate; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入地址 NRFSPI(date);//写入值 CSN=1; return(BackDate); } /*****************SPI读取RXFIFO寄存器的值********************************/ uchar NRFReadRxDate(uchar RegAddr,uchar *RxDate,uchar DateLen) { //寄存器地址//读取数据存放变量//读取数据长度//用于接收 uchar BackDate,i; CSN=0;//启动时序 BackDate=NRFSPI(RegAddr);//写入要读取的寄存器地址 for(i=0;i<DateLen;i++) //读取数据 { RxDate[i]=NRFSPI(0); } CSN=1; return(BackDate); } /*****************SPI写入TXFIFO寄存器的值**********************************/ uchar NRFWriteTxDate(uchar RegAddr,uchar *TxDate,uchar DateLen) { //寄存器地址//写入数据存放变量//读取数据长度//用于发送 uchar BackDate,i; CSN=0; BackDate=NRFSPI(RegAddr);//写入要写入寄存器的地址 for(i=0;i<DateLen;i++)//写入数据 { NRFSPI(*TxDate++); } CSN=1; return(BackDate); } /*****************NRF设置为发送模式并发送数据******************************/ void NRFSetTxMode(uchar *TxDate) {//发送模式 CE=0; NRFWriteTxDate(W_REGISTER+TX_ADDR,TxAddr,TX_ADDR_WITDH);//写寄存器指令+接收地址使能指令+接收地址+地址宽度 NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH);//为了应答接收设备,接收通道0地址和发送地址相同 NRFWriteTxDate(W_TX_PAYLOAD,TxDate,TX_DATA_WITDH);//写入数据 /******下面有关寄存器配置**************/ NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+SETUP_RETR,0x0a); // 自动重发延时等待250us+86us,自动重发10次 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益 NRFWriteReg(W_REGISTER+CONFIG,0x0e); // CRC使能,16位CRC校验,上电 CE=1; Delay(5);//保持10us秒以上 } /*****************NRF设置为接收模式并接收数据******************************/ //主要接收模式 void NRFSetRXMode() { CE=0; NRFWriteTxDate(W_REGISTER+RX_ADDR_P0,TxAddr,TX_ADDR_WITDH); // 接收设备接收通道0使用和发送设备相同的发送地址 NRFWriteReg(W_REGISTER+EN_AA,0x01); // 使能接收通道0自动应答 NRFWriteReg(W_REGISTER+EN_RXADDR,0x01); // 使能接收通道0 NRFWriteReg(W_REGISTER+RF_CH,0x40); // 选择射频通道0x40 NRFWriteReg(W_REGISTER+RX_PW_P0,TX_DATA_WITDH); // 接收通道0选择和发送通道相同有效数据宽度 NRFWriteReg(W_REGISTER+RF_SETUP,0x07); // 数据传输率1Mbps,发射功率0dBm,低噪声放大器增益*/ NRFWriteReg(W_REGISTER+CONFIG,0x0f); // CRC使能,16位CRC校验,上电,接收模式 CE = 1; Delay(5);//保持10us秒以上 } /****************************检测是否有接收到数据******************************/ void CheckACK() { //用于发射模式接收应答信号 sta=NRFReadReg(R_REGISTER+STATUS); // 返回状态寄存器 if(TX_DS) NRFWriteReg(W_REGISTER+STATUS,0xff); // 清除TX_DS或MAX_RT中断标志 } /*************************接收数据*********************************************/ void GetDate() { sta=NRFReadReg(R_REGISTER+STATUS);//发送数据后读取状态寄存器 if(RX_DR) // 判断是否接收到数据 { CE=0;//待机 NRFReadRxDate(R_RX_PAYLOAD,RevTempDate,RX_DATA_WITDH);// 从RXFIFO读取数据 接收4位即可,后一位位结束位 // LcdWriteChStr(2,65,RevTempDate);//LCD12864液晶显示 // MAX232SendDate();//发送数据到上位机 NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 CSN=0; NRFSPI(FLUSH_RX);//用于清空FIFO !!关键!!不然会出现意想不到的后果!!!大家记住!! CSN=1; } //NRFWriteReg(W_REGISTER+STATUS,0xff); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标 } # keil运行时没有错误的,接收端与单片机串口也是通的,波特率115200, # IRC18.432MHz,可是在接收端的串口始终读不到数,搞了好久了还是没办法 # 技术小白求大神指点 ```

NRF52840 自定义UUID read属性问题

我现在调试nrf52840用的官方ble_app_blink这个例程,例程中定义的LBS_UUID_LED_CHAR 属性为read和write,app可以给nrf52840发送数据。但是没有找到app读取nrf52840数据的流程,请问当app发起读取请求的时候,nrf52840中处理流程是什么样的。 ![图片说明](https://img-ask.csdn.net/upload/201908/15/1565841916_510182.png)

keil 求助 nrf51822

keil for arm 5 来作一个nrf51822的项目,官方的sdk 但是不知道为什么,里面的一个库 nrfdelay.h 每次编译都报错,官方解释说是误报,有什么办法解决? 误报代码: static __ASM void __INLINE nrf_delay_us(uint32_t volatile number_of_us) { loop SUBS R0, R0, #1 NOP NOP NOP NOP NOP NOP NOP NOP NOP NOP NOP NOP BNE loop BX LR } 错误信息 nrf_delay.h(10): error: A1163E: Unknown opcode loop , expecting opcode or Macro

USB转NRF24L01与单片机通信

我用的山外串口软件 不知道怎么写目标地址 更改波特率 等等

NRF24L01如何才能保证接收到应答信号

我有一个主机设置为发送模式发送数据给从机,主机和从机都为自动应答模式,但是经常会出现从机接收到数据,但主机接收不到从机发送过来的应答信号。怎么才能保证主机能够收到从机的应答信号?

NRF24L01模块发送的2.4G信号能不能用其他非NRF24l01的模块接收?

NRF24L01模块发送的2.4G信号能不能用其他非NRF24l01的模块接收? 本人小白,求教!

nRF51822 数据重发现象

我在Keyboard Demo的基础上增加了Uart的功能,以实现通过BLE4.0把串口上得到的数据发送到的电脑上的功能,现遇到如下问题: (1)数据传输太快会导致发送错误,现在直接一个一个字符发送,但是15ms发一个速度太慢,这个是否和keyboard模式有关。 (2)发送一窜数据到电脑上会出现重发现象。串口上得到数据后通过err_code =sd_ble_gatts_hvx(p_hid->conn_handle,&hvx_params)发送,当发送错误时err_code为12292 应该是BLE_ERROR_NO_TX_BUFFERS 实际上数据已经发送成功 ,因为在前面加了相应的错误处理,当err_code != NRF_SUCCESS时会重发一次 所以会有重发的现象。这种情况该如何解决。

nrf51802接收串口数据,导致系统重启

用nrf51802作为数据透传模块,当上位MCU发送串口数据,导致nrf51802系统重启 void UART0_IRQHandler(void) { // Handle reception if (NRF_UART0->EVENTS_RXDRDY != 0) { uint32_t err_code; // Clear UART RX event flag NRF_UART0->EVENTS_RXDRDY = 0; // Write received byte to FIFO err_code = app_fifo_put(&m_rx_fifo, (uint8_t)NRF_UART0->RXD); if (err_code != NRF_SUCCESS) { app_uart_evt_t app_uart_event; app_uart_event.evt_type = APP_UART_FIFO_ERROR; app_uart_event.data.error_code = err_code; m_event_handler(&app_uart_event); } // Notify that new data is available if this was first byte put in the buffer. else if (FIFO_LENGTH(m_rx_fifo) == 1) { app_uart_evt_t app_uart_event; app_uart_event.evt_type = APP_UART_DATA_READY; m_event_handler(&app_uart_event); } else { // Do nothing, only send event if first byte was added or overflow in FIFO occurred. } } // Handle transmission. if (NRF_UART0->EVENTS_TXDRDY != 0) { // Clear UART TX event flag. NRF_UART0->EVENTS_TXDRDY = 0; on_uart_event(ON_TX_READY); } // Handle errors. if (NRF_UART0->EVENTS_ERROR != 0) { uint32_t error_source; app_uart_evt_t app_uart_event; // Clear UART ERROR event flag. NRF_UART0->EVENTS_ERROR = 0; // Clear error source. error_source = NRF_UART0->ERRORSRC; NRF_UART0->ERRORSRC = error_source; app_uart_event.evt_type = APP_UART_COMMUNICATION_ERROR; app_uart_event.data.error_communication = error_source; m_event_handler(&app_uart_event); } }

android 如何和Nordic的nRF51822芯片通讯?

最近有个android项目要用蓝牙和Nordic的nRF51822芯片进行信息传递,不是很熟悉蓝牙,有大神可以指教么?

nrf24l01无法同时多发一收

当EN_RXADDR寄存器设置为0x3f 使能通道012345的接收地址时 只能从通道1接收到数据,无法从通道0,2,3,4,5接收到数据 当EN_RXADDR寄存器设置为0x01 使能通道0的接收地址时 只能从通道0接收到数据 请问如何同时接收到通道0,1,2,3,4,5的数据 在不使用通讯协议的情况下如何判断接收到的数据是从通道0,1,2,3,4,5的哪个通道接收到的 我的代码如下 const u8 ADDRESS[7][5]={{0x30,0x30,0x30,0x30,0x30},{0x30,0x30,0x30,0x30,0x31},{0x30,0x30,0x30,0x30,0x32},{0x30,0x30,0x30,0x30,0x33},{0x30,0x30,0x30,0x30,0x34},{0x30,0x30,0x30,0x30,0x35},{0x30,0x30,0x30,0x30,0x36}}; /*********************************************/ /* 函数功能:设置24L01为接收模式 */ /*********************************************/ void NRF24L01_RX_Mode(void) { SPI_RF_CE_L;//CE拉低,使能24L01配置 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0, (u8*)ADDRESS[0], RX_ADR_WIDTH);//写RX接收地址 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P1, (u8*)ADDRESS[1], RX_ADR_WIDTH);//写RX接收地址 NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P2,ADDRESS[2][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P3,ADDRESS[3][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P4,ADDRESS[4][4]); NRF24L01_Write_Reg(WRITE_REG+RX_ADDR_P5,ADDRESS[5][4]); NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x3f); //开启通道0,1,2,3,4,5自动应答 NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x3f);//通道0 1,2,3,4,5 接收允许 NRF24L01_Write_Reg(WRITE_REG+RF_CH,0); //设置RF工作通道频率 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P0,RX_PLOAD_WIDTH);//选择通道0的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P1,RX_PLOAD_WIDTH);//选择通道1的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P2,RX_PLOAD_WIDTH);//选择通道2的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P3,RX_PLOAD_WIDTH);//选择通道3的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P4,RX_PLOAD_WIDTH);//选择通道4的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RX_PW_P5,RX_PLOAD_WIDTH);//选择通道5的有效数据宽度 NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f);//设置TX发射参数,0db增益,2Mbps,低噪声增益开启 NRF24L01_Write_Reg(WRITE_REG+CONFIG, 0x0f); //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,接收模式 NRF24L01_Write_Reg(FLUSH_RX,0xff);//清除RX FIFO寄存器 SPI_RF_CE_H;//CE置高,进入接收模式 delay_us(10); } /*********************************************/ /* 函数功能:设置24L01为发送模式 */ /*********************************************/ void NRF24L01_TX_Mode(void) { SPI_RF_CE_L;//CE拉低,使能24L01配置 NRF24L01_Write_Buf(WRITE_REG+TX_ADDR,(u8*)ADDRESS[0],TX_ADR_WIDTH);//写TX节点地址 NRF24L01_Write_Buf(WRITE_REG+RX_ADDR_P0,(u8*)ADDRESS[0],RX_ADR_WIDTH); //设置TX节点地址,主要为了使能ACK NRF24L01_Write_Reg(WRITE_REG+EN_AA,0x3f); //使能通道012345的自动应答 NRF24L01_Write_Reg(WRITE_REG+EN_RXADDR,0x3f); //使能通道012345的接收地址 NRF24L01_Write_Reg(WRITE_REG+SETUP_RETR,0x1a);//设置自动重发间隔时间:500us + 86us;最大自动重发次数:10次 NRF24L01_Write_Reg(WRITE_REG+RF_CH,0); //设置RF通道为0 NRF24L01_Write_Reg(WRITE_REG+RF_SETUP,0x0f); //设置TX发射参数,0db增益,2Mbps,低噪声增益开启 NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0e); //配置基本工作模式的参数;PWR_UP,EN_CRC,16BIT_CRC,发送模式,开启所有中断 SPI_RF_CE_H;//CE置高,10us后启动发送 delay_us(10); } main中的死循环代码: while(1) { if(SPI_RF_IRQ==0) { if(NRF24L01_RxPacket(rece_buf)==0) { Usart_SendString(rece_buf); } } } 发送数据代码: SPI_RF_CE_L; NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0e); SPI_RF_CE_H; NRF24L01_TxPacket(rece_buf); SPI_RF_CE_L; NRF24L01_Write_Reg(WRITE_REG+CONFIG,0x0f); SPI_RF_CE_H;

关于K60单片机,请问如何用IAR烧程序?

新手啥都不懂,求各位大神帮忙给点详细步骤,必有重谢!![图片](https://img-ask.csdn.net/upload/201602/08/1454936585_160176.jpg)

关于nrf24l01无法通行问题

在配置STM32F103C8T6 +nrf2401问题时,SPI读写功能没问题,即nrf2401 check成功。 我配置发送端关闭自动应答:SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 发送完成后,读取status寄存器内容为0x2e, fifostatus寄存器内容为0x11,即表示发送模块成功发送。 我配置接收端关闭ACK: SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0,在上述发送端一直工作前提下接收端不能接收数据,查看 接收端status寄存器内容为:0x0e,表示接收端未收到数据。 我猜想不能通行原因是通道、地址、频率、模式不正确,但仔细检查发送、接收端上述配置完全一样。现在不知道问题出在哪里了,请各位帮我看看。 uint8_t NRF24L01_Check(void) { uint8_t buf[5]={0XA5,0XA5,0XA5,0XA5,0XA5}; uint8_t i; SPI_Write_Buf(NRF_WRITE_REG+TX_ADDR,buf,5);// SPI_Read_Buf(TX_ADDR,buf,5); for(i=0;i<5;i++)if(buf[i]!=0XA5)break; if(i!=5)return 1; return 0; } void TX_Mode(void) { NRF24L01_SCK_L; NRF24L01_CE_L; SPI_Write_Buf(NRF_WRITE_REG + TX_ADDR, (u8*)TX_ADDRESS, 5); SPI_Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, (u8*)TX_ADDRESS, 5); SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 SPI_RW_Reg(NRF_WRITE_REG + EN_RXADDR, 0x00); // Enable Pipe0 SPI_RW_Reg(NRF_WRITE_REG + SETUP_RETR, 0x00); SPI_RW_Reg(NRF_WRITE_REG + SETUP_AW, 0x03); SPI_RW_Reg(NRF_WRITE_REG + RF_CH, 40); SPI_RW_Reg(NRF_WRITE_REG + RF_SETUP, 0x0F); SPI_RW_Reg(NRF_WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH); SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0e); NRF24L01_CE_H; delay_us(150); } void RX_Mode(void) { NRF24L01_SCK_L; NRF24L01_CE_L; SPI_Write_Buf(NRF_WRITE_REG + RX_ADDR_P0, (u8*)TX_ADDRESS, TX_ADR_WIDTH); // Use the same address on the RX device as the TX device SPI_RW_Reg(NRF_WRITE_REG + EN_AA, 0x00); // Enable Auto.Ack:Pipe0 SPI_RW_Reg(NRF_WRITE_REG + EN_RXADDR, 0x01); // Enable Pipe0 SPI_RW_Reg(NRF_WRITE_REG + SETUP_AW, 0x03); // SPI_RW_Reg(NRF_WRITE_REG + RF_CH, 40); // Select RF channel 40 SPI_RW_Reg(NRF_WRITE_REG + RX_PW_P0, TX_PLOAD_WIDTH); SPI_RW_Reg(NRF_WRITE_REG + RF_SETUP, 0x0f); SPI_RW_Reg(NRF_WRITE_REG + CONFIG, 0x0f); NRF24L01_CE_H; // delay_us(150); } u8 NRF24L01_RxPacket(u8 *rx_buf) { int16_t sta,fifosta,tt=0; sta=SPI_Read_Reg(STATUS); fifosta=SPI_Read_Reg(FIFO_STATUS); if(!( NRF24L01_IRQ)) { sta=SPI_Read_Reg(STATUS); if(sta&RX_OK) { SPI_Read_Buf(RD_RX_PLOAD,rx_buf,RX_PLOAD_WIDTH); SPI_RW_Reg(FLUSH_RX,0xff); SPI_RW_Reg(NRF_WRITE_REG+STATUS,0x7f); tt=1; } } return (tt); } u8 NRF24L01_TxPacket(u8 *txbuf) { uint8_t sta,fifosta,cd; NRF24L01_CE_L; SPI_Write_Buf(WR_TX_PLOAD,txbuf,TX_PLOAD_WIDTH); sta = SPI_Read_Reg(STATUS); fifosta = SPI_Read_Reg(FIFO_STATUS); NRF24L01_CE_H;// while(NRF24L01_IRQ!=0);// sta=SPI_Read_Reg(STATUS); // fifosta = SPI_Read_Reg(FIFO_STATUS); cd=SPI_Read_Reg(0x09); SPI_RW_Reg(NRF_WRITE_REG+STATUS,sta); if(sta&MAX_TX)// { SPI_RW_Reg(FLUSH_TX,0xff);// return MAX_TX; } if(sta&TX_OK) { ; return 0x01; } return 0xff;// }

基于NRF905和485总线的测温系统

买的NRF模块,485总线程序没写,烧录代码后,在上位机上显示乱码,NRF发送的是十六进制,void CTemperDlg::OnCommMscomm() { // TODO: Add your control notification handler code here m_strRXData=" "; //每次进入编辑框内容清空等待显示新的数据 VARIANT variant_inp; COleSafeArray safearray_inp; LONG len,k; BYTE rxdata[2048]; //设置BYTE数组 CString strtemp; static int flag; //识别码数字标志位 if(m_ctrlComm.GetCommEvent()==2)//事件值为2表示接收缓冲区内有字符 { //以下你可以根据自己的通信协议加入//处理代码 variant_inp=m_ctrlComm.GetInput();//读缓冲区 safearray_inp=variant_inp; //VARIANT型变量转换为//ColeSafeArray型变量 len=safearray_inp.GetOneDimSize();//得到有效数据长度 for(k=0;k<len;k++) safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组 for(k=0;k<len;k++) //将数组转换为Cstring型变量 { BYTE bt=*(char*)(rxdata+k);//字符型 strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放 m_strRXData += strtemp; //加入接收编辑框对应字符串strtemp //bt[len]='\0'; m_RXData+=strtemp; double tem; tem=atof(m_strRXData); CString aa; if(tem>31.00) { m_strlbaojing.SetIcon(m_hIconbaoj); //m_ctrlComm.SetOutput(COleVariant(aa)); } else m_strlbaojing.SetIcon(m_hIconzhc); } } UpdateData(FALSE); } //DEL void CTemperDlg::InitChart() //DEL { //DEL m_ctrlChart.Series(0).Clear(); //DEL m_ctrlChart.GetAxis(http://msnpiki.msnfanatic.com/index.php/Main_Page-->#0000cc">).GetLeft().SetMinMax(-40, 100); //DEL }

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

win10暴力查看wifi密码

刚才邻居打了个电话说:喂小灰,你家wifi的密码是多少,我怎么连不上了。 我。。。 我也忘了哎,就找到了一个好办法,分享给大家: 第一种情况:已经连接上的wifi,怎么知道密码? 打开:控制面板\网络和 Internet\网络连接 然后右击wifi连接的无线网卡,选择状态 然后像下图一样: 第二种情况:前提是我不知道啊,但是我以前知道密码。 此时可以利用dos命令了 1、利用netsh wlan...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

美团面试,问了ThreadLocal原理,这个回答让我通过了

他想都想不到,ThreadLocal我烂熟于心

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

立即提问
相关内容推荐