基本信息
源码名称:无线开关量控制(基于LORA)
源码大小:0.01M
文件格式:.c
开发语言:C/C++
更新时间:2021-07-12
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍

通过LORA实现主机对从机开关状态的检测及控制

*项目名称:开关量无线控制模块
*程序名称:发射端程序
*程序版本:1.0  
*编程日期:2001.1.14                 			  	
*说明:烧写程序之前需确定并改写分组地址和自身地址,自身地址每5个为一个系统,如(0x00~0x04)是一个收发系统,其中00~03是发送终端,04是接收终端,以此类推

void Uartrcv_handle(void) //串口接收数据处理
{
u8 i;
if (Uartflag == 2)              //收到lora反馈,表示设置成功
{
Uartflag = 0;
for(i = 0; i < 15; i )
{
printf("Uartrcv[%02x]=%02x\n", i, Uartrcv[i]);
}
Uartrcv_len = 0; //清零串口接收指针
memset(Uartrcv, 0, sizeof(Uartrcv)); //清空串口接收数组
}
else if (Uartflag == 1)        //收到开关数据
{
Uartflag = 0;
switch (Location)
{
case 1:
senddata[3]=Uartrcv[3];
if (GPIO_ReadInputDataBit(GPIOA, GPIO_check1) == 0)
{
senddata[4]=0x00;
sendDataByLora(senddata, 7);
}
else
{
senddata[4]=0x01;
sendDataByLora(senddata, 7);
}
for(i=0;i<7;i )
{
printf("senddata[%02x]=%02x\n",i,senddata[i]);
}
break;
case 2:
senddata[3]=Uartrcv[3];
senddata[4]=Uartrcv[4];
if (GPIO_ReadInputDataBit(GPIOA, GPIO_check1) == 0)
{
senddata[5]=0x00;
sendDataByLora(senddata, 8);
}
else
{
senddata[5]=0x01;
sendDataByLora(senddata, 8);
}
for(i=0;i<8;i )
{
printf("senddata[%02x]=%02x\n",i,senddata[i]);
}
break;
case 3:
senddata[3]=Uartrcv[3];
senddata[4]=Uartrcv[4];
senddata[5]=Uartrcv[5];
if (GPIO_ReadInputDataBit(GPIOA, GPIO_check1) == 0)
{
senddata[6]=0x00;
sendDataByLora(senddata, 9);
}
else
{
senddata[6]=0x01;
sendDataByLora(senddata, 9);
}
for(i=0;i<9;i )
{
printf("senddata[%02x]=%02x\n",i,senddata[i]);
}
break;
case 4:
if(Uartrcv[3]==0x00)
{
GPIO_ResetBits(GPIOB,GPIO_control1);
}
else if(Uartrcv[3]==0x01)
{
GPIO_SetBits(GPIOB,GPIO_control1);
}
if(Uartrcv[4]==0x00)
{
GPIO_ResetBits(GPIOB,GPIO_control2);
}
else if(Uartrcv[4]==0x01)
{
GPIO_SetBits(GPIOB,GPIO_control2);
}
if(Uartrcv[5]==0x00)
{
GPIO_ResetBits(GPIOB,GPIO_control3);
}
else if(Uartrcv[5]==0x01)
{
GPIO_SetBits(GPIOB,GPIO_control3);
}
if(Uartrcv[6]==0x00)
{
GPIO_ResetBits(GPIOB,GPIO_control4);
}
else if(Uartrcv[6]==0x01)
{
GPIO_SetBits(GPIOB,GPIO_control4);
}
break;
}
for(i=0;i<9;i )
{
printf("Uartrcv[%02x]=%02x\n",i,Uartrcv[i]);
}
Uartrcv_len = 0; //清零串口接收指针
memset(Uartrcv, 0, sizeof(Uartrcv)); //清空串口接收数组
}
}