成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一次小模塊的使用過程-LC12S無線模塊介紹

網絡 通信技術
最近幫人做了個小設備,使用了無線模塊、觸摸芯片,主要功能就是把觸摸按鍵的信號無線傳到控制繼電器輸出,MCU是STM8系列的芯片,其中使用過程中調試無線模塊LC21S覺得挺好用的,就寫了這篇文章。

[[380994]]

前言:

最近幫人做了個小設備,使用了無線模塊、觸摸芯片,主要功能就是把觸摸按鍵的信號無線傳到控制繼電器輸出,MCU是STM8系列的芯片,其中使用過程中調試無線模塊LC21S覺得挺好用的,就寫了這篇文章。

模塊介紹:

LC12S 采用最新 2.4G SOC 技術,特點是免開發,視距 120 米,收發一體無需切換,串口透明傳 輸,提供通信協議,可迅速調試成功。用戶只要了解串口通信,無需復雜的無線通訊知識,就能完成無 線通信產品的開發。沒有數據包大小限制,延時短,半雙工通訊,抗干擾能力強。

  • 2.4GHz ISM 頻段,使用無須申請
  • 最大輸出功率 12dBm
  • 接收靈敏度-95dBm
  • 發射工作電流 40mA@12dBm
  • 接收工作電流 24mA
  • 睡眠電流 3.5uA
  • 標準 TTL 電平 UART 串口
  • 工作頻率可設置,多個模塊頻分復用,互不干擾
  • 通訊協議轉換及射頻收發切換自動完成,用戶無須干預,簡單易用
  • 通訊速率 0.6kbps -38.4kbps,用戶可通過 AT 指令配置

引腳介紹:

引腳 引腳名稱 引腳功能 描述
1 VCC 電源 電源(接 2.2~3.6V)典型 3.3V
2 RXT 模塊數據輸出(TTL 電平) 串口通信數據接收
3 TXD 模塊數據輸入(TTL 電平) 串口通信數據發送
4 SET 設置位 配置參數使能(低電平使能參數配置,高電平進入透傳模式,其中懸空為高電平)
5 CS 休眠 引腳接低電平時工作,高電平進入休眠模式,其中懸空為高電平
6 GND 電源 接地

基本配置:

設置模式:

一旦進入設置狀態,SET 引腳配置必須是低電平,CS 引腳必須接低電平,且串口設置必須是數據位 8,波特率 9600,校驗位 N,停止位 1,空中速率 1Mbps。因為初始化默認設置就是如此,如果后續你設置了自己的波特率,這個時候你需要把串口設置按照你修改后的配置來設置。

透傳模式:

上電后,當 CS引腳接低電,進入工作模式,SET 腳是設置參數標志位,這個時候我們可以進行懸空或者拉高處理,讓模塊進入透傳數據模式。

設置模式數據的協議格式:

在官方的手冊里面有關于協議內容的說明,其中有一些數據是保留位,默認發0x00就可以。

如圖所示,我們可以看到數據長度是18個byte,其中包括設備ID(Self ID)、組網ID(Net ID )、發射功率(RF Power)、通訊波特率設置(Baud 1Byte)、無線通訊通道設置(RF CHN)、設置時的通訊數據長度(Lenght 1Byte)、累加校驗位(CheckSum);其中設置時的通訊數據長度是固定的18byte所以此處默認為0x12。

其他部分的設置參數,在手冊中各有體現,其中組網ID需要按照自己定義的ID區間進行設置,因為這個唯一性會影響到你的模塊組網情況。

其余的設置我設置參數我就不進行截圖表示了,大家可以看一下相應的手冊。

測試設置發送數據:

0xaa+0x5A+模塊 ID+組網 ID(ID 必須相同)+0x00+RF 發射功率+0x00+串口速率 +0x00+RF 信道選擇+0x00+0x00+0x12(字節長度)+0x00+和校驗字節 注意:和校驗字節=所有參數累加的字節

發送: AA 5A 22 33 11 22 00 01 00 04 00 64 00 00 00 12 00 07

--->

參考后面的數據表格,以上配置參數設置無線模塊為:RF 發射功率:10dbm 串口速率:9600bps RF 信道:100 模塊 ID:0x2233 組網 ID:0x1122 和校驗字節:07

接收: 設置完成后模塊會返回相應數據 AA 5B 47 00 11 22 00 01 00 04 00 64 00 00 00 12 00 FA

<---

串口調試助手的信息:

實際設備連接情況:

設置模式接線示意圖:

透傳模式接線示意圖:

代碼實現:

因為模式使用比較簡單,初始化好設備串口外設,再把CS引腳和SET配置一下,就可以開始使用了,如果你只是簡單測試,那你可能只需要使用默認設置,只是進行數據的透傳,那你可以直接忽略這部分設置的代碼部分,直接看nrf_send_normal_data()函數。

設置模式下的代碼:

定義一個設置協議的結構體:

  1. typedef struct __attribute__((__packed__)){ 
  2.     u16 head;                 // 
  3.     u16 self_id;                 // 
  4.     u16 net_id;                 // 
  5.     u8 nc1;               // 
  6.     u8 rf_power;          // 
  7.     u8 nc2;               // 
  8.     u8 rf_baud;          // 
  9.     u8 nc3;               // 
  10.     u8 rf_chn;          // 
  11.     u16 nc4;               // 
  12.     u8 nc5;               // 
  13.     u8 length;               // 
  14.     u8 nc6;               // 
  15. }SetSend;  

拉低SET引腳,進入設置模式:

  1. u8 SetNrf(void)// 
  2.        GPIO_ResetBits(SET_PORT, SET_PIN); 
  3.        GPIO_ResetBits(CS_PORT, CS_PIN); 
  4.  
  5.       u8 *p1 = malloc(18); 
  6.       memset(p1,0x00,18); 
  7.  
  8.       SetSend *p = (SetSend*)p1; 
  9.  
  10.       p->head= 0xaa5A; 
  11.       p->self_id = 0x2233; 
  12.       p->net_id = 0x1122; 
  13.       p->rf_power = 0x00; 
  14.       p->rf_baud = 0x04; 
  15.       p->rf_chn = 0x64; 
  16.       p->length = 0x12;       
  17.       p1[sizeof(SetSend)] = CheckSum((u8*)p, sizeof(SetSend)); 
  18.       USART_Transmit_String( sizeof(SetSend)+1,p1); 
  19.  
  20. #if DEBUG_DPRINT 
  21.       u8 *str = malloc(20); 
  22.       hex_str((u8*)p, sizeof(SetSend)+1, str); 
  23.       USART_Transmit_String(20,str); 
  24. //      printf("--->:%s\r\n", str); 
  25.       free(str); 
  26. #endif 
  27.  
  28.       free(p1); 
  29.       return 1; 
  30.        

數據透傳的函數,這個時候SET引腳拉高,這個函數部分是我自己寫的一個簡單的3byte的sta狀態發送。大家可以按照自己的實際使用情況進行修改。

  1. void nrf_send_normal_data(u16 sta) 
  2.       GPIO_SetBits(SET_PORT, SET_PIN); 
  3.       u8 *p1 = malloc(3); 
  4.       memset(p1,0x00,3); 
  5.       memset(p1,0xAA,1);       
  6.       memcpy(p1+1,&sta,2); 
  7.       USART_Transmit_String(3,p1); 
  8.       free(p1); 
  9.  

芯片初始化之后不能立即使用,需要等待幾十ms才能正常工作,所以需要稍微等待一下。

串口接收解析部分,這部分代碼就仁者見仁智者見智了,大家可以用很多種方法實現,我只是貼了一下我寫的代碼部分,僅供參考。其中NRF_RestTime()函數是在定時器中計時,用來區分不同的數據幀。

  1. u8  USART_RX_BUF[USART_MAX_RECV_LEN]; 
  2. u16 USART_RX_STA=0; 
  3.  
  4. u8 NRF_RecvdData(void) 
  5.  u8 ret = 0; 
  6.  if((USART_RX_STA&(1<<15)) != 0) 
  7.   ret = 1; 
  8.  return ret; 
  9. u16 NRF_RcvLen(void) 
  10.  return (USART_RX_STA & 0x7FFF); 
  11. u8* NRF_RcvBuff(void) 
  12.  return USART_RX_BUF; 
  13.  
  14. void NRF_ClsRecvd(void) 
  15.  USART_RX_STA = 0; 
  16.  
  17.  
  18. typedef struct  __attribute__((__packed__)) 
  19.   u32 stat    :1; 
  20.   u32 timOut  :1; 
  21.   u32 cunt    :15; 
  22.   u32 des     :15; 
  23. }TboxTimTypeDef; 
  24. TboxTimTypeDef gNRFTimeManage; 
  25. #define TON   (1) 
  26. #define TOFF  (0) 
  27.  
  28. void TimerManageInit(TboxTimTypeDef *t,u8 stat,u16 destim) 
  29.   t->des  = destim; 
  30.   t->stat = stat; 
  31.   t->cunt = 0; 
  32.   t->timOut = 0; 
  33. void NRF_RestTime(void) 
  34.       if(gNRFTimeManage.stat == TON) 
  35.       { 
  36.               (gNRFTimeManage.cunt < gNRFTimeManage.des)?(gNRFTimeManage.cunt++):\ 
  37.                       (TimerManageInit(&gNRFTimeManage,TOFF,0),USART_RX_STA |=1<<15); 
  38.       }  
  39.  
  40. void NRF_Irq(void) 
  41.    u8 res;        
  42.  if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) 
  43.  {   
  44.   res =USART_ReceiveData8(USART1); 
  45.                 #if 0 
  46.   USART_SendData8(USART1,res); 
  47.   #endif 
  48.  
  49.        
  50.                 if((USART_RX_STA & ~(1<<15))<USART_MAX_RECV_LEN) 
  51.                 { 
  52.                       TimerManageInit(&gNRFTimeManage,TON,5); 
  53.                       USART_RX_BUF[USART_RX_STA++]=res;    
  54.                 }else  
  55.                 { 
  56.                         USART_RX_STA|=1<<15;     
  57.                 }  
  58.           } 
  59.  USART_ClearITPendingBit(USART1,USART_IT_RXNE); 
  60.  
  61. void Parse_NRF(void) 
  62.    
  63.     if(NRF_RcvLen()>2) 
  64.     { 
  65.       u16 len = NRF_RcvLen();  
  66.       u8 *p = NRF_RcvBuff(); 
  67.       u8 pos = 0; 
  68.       u16 *sta = (u16*)(p+1); 
  69.       while(pos < len){ 
  70.         if(*p == 0xAA) 
  71.         { 
  72.            
  73.           relay_ctrl(*sta); 
  74.           p += 3; 
  75.           pos +=3; 
  76.         } 
  77.         else
  78.           p++; 
  79.           pos++; 
  80.         } 
  81.       } 
  82.       USART_RX_STA = 0; 
  83.     } 
  84.    

設備展示

主機端:

從機端:

結語

這就是我分享的LC12S模塊的使用,如果大家有更好的想法和需求,也歡迎大家分享交流哈。

本文轉載自微信公眾號「羽林君」,可以通過以下二維碼關注。轉載本文請聯系羽林君公眾號。

 

責任編輯:武曉燕 來源: 羽林君
相關推薦

2012-01-12 10:01:28

模塊

2022-11-22 13:00:38

2015-08-27 09:15:35

2009-03-20 10:58:47

2023-12-05 08:33:44

滴滴故障k8s

2014-08-01 14:06:45

2022-09-14 15:40:03

接口解決

2010-09-07 11:16:14

SQL語句

2022-09-15 10:02:58

測試軟件

2010-04-12 16:28:41

無線通信模塊

2011-06-28 10:41:50

DBA

2010-03-23 08:56:38

Python隨機數模塊

2023-10-10 12:05:45

2017-12-19 14:00:16

數據庫MySQL死鎖排查

2019-08-26 09:50:09

2018-04-04 13:59:22

天線無線通信

2021-11-23 21:21:07

線上排查服務

2020-04-08 10:30:19

Linux 攻擊 安全

2018-07-20 08:44:21

Redis內存排查

2021-08-19 09:50:53

Java內存泄漏
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲综合在线播放 | 黄色a三级 | 在线看黄免费 | 黄色成人av | 日本a视频 | 国产美女一区二区 | 久久久一区二区三区四区 | 欧美一级片在线看 | 国产精品区一区二区三区 | 99久久影院 | 国产区第一页 | 欧美激情一区二区三区 | 久久激情视频 | 成人av一区 | 国产东北一级毛片 | 日韩高清国产一区在线 | 自拍偷拍欧美 | 国产精品亚洲视频 | 欧美日韩视频在线播放 | 精品国产一区二区三区观看不卡 | 成人在线精品视频 | 99只有精品 | 99久久国产综合精品麻豆 | 亚洲欧美一区二区三区在线 | 91色视频在线观看 | 国产精品国产三级国产aⅴ中文 | 成人黄视频在线观看 | 亚洲国产精品久久久久久 | 视频二区国产 | 欧美日韩三级 | 男女羞羞视频免费 | 国产xxxx搡xxxxx搡麻豆 | 精品一区二区久久 | 精品国产一区二区三区久久影院 | 337p日本欧洲亚洲大胆精蜜臀 | 国产一区二区三区在线 | 国产婷婷精品av在线 | 91 在线| 看黄在线 | 亚洲精品二区 | 黄色操视频 |