CC2530——点对点通信实现跑马灯

本文介绍了一种利用ZigBee自组网实现点对点通信的方法,通过按键触发发送指令到另一个节点,接收端根据指令开启跑马灯效果。详细展示了从硬件配置到软件编程的完整过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

点对点通信实现跑马灯

内容简介

ZIGBBE自组网方式,将两个ZIGBBE盒进行组网
按键按下A将数据发送给B
B判断是否有ZIGBBE信号,如果有就接收信息
如果接收到的数据为开启跑马灯,则开启跑马灯

代码解析

按键按下LED3亮并且A发送数据给B

 if(scan_key())   //有按键,则发送数据
       {           
            halLedToggle(3);       // 绿灯取反,发送指示  LED3
            basicRfSendPacket(SEND_ADDR,"ZIGBEE TEST\r\n",13);                                      
        } 

B节点判断是否有新的ZIGBBE信号,如果有就接收数据,并判断是否为需要的数据,如果是,则开启跑马灯

 if(basicRfPacketIsReady())   // 判断有无收到zigbee信号
        {
            //halLedToggle(1);
            len = basicRfReceive(pRxData, MAX_RECV_BUF_LEN, NULL);   // 接收数据
            if(pRxData[0]=='Z')
               LSD();
        } 

跑马灯实现代码

void LSD()
{
  uchar i;
  uchar stat[4]={0x20,0x01,0x10,0x08};
  P1DIR |= 0x39;  //LED定义为输出
  P1 &= ~0x39; //全部熄灭
  while(1)
  {
    for(i=0;i<4;i++)
    {
      P1=stat[i];
      Delay(10000);
    }
  } 
}

延迟函数实现

void Delay(uint n)
{
	uint tt;
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
}

全部代码

#include "hal_defs.h"
#include "hal_cc8051.h"
#include "hal_int.h"
#include "hal_mcu.h"
#include "hal_board.h"
#include "hal_led.h"
#include "hal_rf.h"
#include "basic_rf.h"
#include "hal_uart.h" 
#include <stdio.h>
#include <string.h>
#include	<stdarg.h>

#define uint unsigned int
#define uchar unsigned char
uint8   scan_key();
void LSD();
void Delay(uint);

#define MAX_SEND_BUF_LEN  128
#define MAX_RECV_BUF_LEN  128
static uint8 pTxData[MAX_SEND_BUF_LEN]; //定义无线发送缓冲区的大小
static uint8 pRxData[MAX_RECV_BUF_LEN]; //定义无线接收缓冲区的大小


#define MAX_UART_SEND_BUF_LEN  128
#define MAX_UART_RECV_BUF_LEN  128
uint8 uTxData[MAX_UART_SEND_BUF_LEN]; //定义串口发送缓冲区的大小
uint8 uRxData[MAX_UART_RECV_BUF_LEN]; //定义串口接收缓冲区的大小
uint16 uTxlen = 0;
uint16 uRxlen = 0;

/*****点对点通讯地址设置******/
#define RF_CHANNEL                20         // 频道 11~26
#define PAN_ID                    0x1A5B     //网络id 
//#define MY_ADDR                   0xAC3A     //本机模块地址
//#define SEND_ADDR                 0x1015     //发送地址

#define MY_ADDR                   0x1015     // 本机模块地址
#define SEND_ADDR                 0xAC3A     //发送地址
/**************************************************/
static basicRfCfg_t basicRfConfig;
// 无线RF初始化
void ConfigRf_Init(void)
{
    basicRfConfig.panId       =   PAN_ID;        //zigbee的ID号设置
    basicRfConfig.channel     =   RF_CHANNEL;    //zigbee的频道设置
    basicRfConfig.myAddr      =  MY_ADDR;        //设置本机地址
    basicRfConfig.ackRequest  =   TRUE;          //应答信号
    while(basicRfInit(&basicRfConfig) == FAILED); //检测zigbee的参数是否配置成功
    basicRfReceiveOn();                // 打开RF
}

/********************MAIN************************/
void main(void)
{
    uint16 len = 0;
    halBoardInit();  //模块相关资源的初始化
    ConfigRf_Init(); //无线收发参数的配置初始化 
    while(1)
    {
       if(scan_key())   //有按键,则发送数据
       {           
            halLedToggle(3);       // 绿灯取反,发送指示  LED3
            basicRfSendPacket(SEND_ADDR,"ZIGBEE TEST\r\n",13);                                      
        } 
    
        if(basicRfPacketIsReady())   // 判断有无收到zigbee信号
        {
            //halLedToggle(1);
            len = basicRfReceive(pRxData, MAX_RECV_BUF_LEN, NULL);   // 接收数据
            if(pRxData[0]=='Z')
               LSD();
        } 
    }
}
/************/

#define key_io P1_2

uint8   keysta=0;
uint16  KeyTime = 0;

uint8 scan_key()
{
    //按键新开
    if(key_io == 0)
    {       
        if(KeyTime<100)
        {
          KeyTime++;
          keysta=1;
        }
        else
        {
           keysta=0;
        }
        halMcuWaitMs(10);
        return 0;    
    }
    else
    {
      KeyTime = 0; 
      if(keysta==0)
          return 0;
      else
          keysta=0;
       return 1;     
    }
}

void LSD()
{
  uchar i;
  uchar stat[4]={0x20,0x01,0x10,0x08};
  P1DIR |= 0x39;  //LED定义为输出
  P1 &= ~0x39; //全部熄灭
  while(1)
  {
    for(i=0;i<4;i++)
    {
      P1=stat[i];
      Delay(10000);
    }
  } 
}

void Delay(uint n)
{
	uint tt;
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
	for(tt = 0;tt<n;tt++);
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FranzLiszt1847

嘟嘟嘟嘟嘟

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值