头像-80239

辛迪可乐

  • 湖北省武汉市
  • 单片机 嵌入式
  • 通讯广播

个人成就

获得 0 次赞

帮助过543人

stm32f103如何驱动和使用AS608光学指纹识别模块

stm32f103如何驱动和使用AS608光学指纹识别模块

NanoPi NEO可以接入blynk吗

NanoPi NEO可以接入blynk吗

particle photon最多可以控制多少路继电器

particle photon最多可以控制多少路继电器

汽车胎压检测使用什么单片机比较好

汽车胎压检测使用什么单片机比较好

单片机制作四轴飞行器使用什么电机驱动模块性价比高

制作四轴飞行器使用什么电机驱动模块性价比高

下面机智云代码定时器部分存在什么问题

#include <stdio.h> #include <string.h> #include "gizwits_product.h" #include "driver/hal_key.h" /* LOCAL os_timer_t time_low_sz; ///< 用户定时器结构 //关闭定时器 //参数一:要关闭的定时器 os_timer_disarm(&time_low_sz); //设置定时器 //参数一:要设置的定时器;参数二:定时器到时间要执行的回调函数;参数三:回调函数的参数 os_timer_setfn(&time_low_sz (os_timer_func_t *)time_low NULL); //使能(启动)定时器 //参数一:要使能的定时器;参数二:定时时间(单位:ms);参数三:是否重复执行,即执行完1次 os_timer_arm(&time_low_sz 1000 1); //倒计时函数 void ICACHE_FLASH_ATTR time_low(void) { currentDataPoint.valuecountdown = time_data[2];//上报当前剩余时间 } */ /** 用户区域当前设备状态结构 */ dataPoint_t currentDataPoint; bool STA[5]={0}; //用于存储5个开关的状态 uint32_t time_data[5]={0};//用于存储定时数据 0.定时时 1.定时分 2.倒计时(分钟)3.定时开:ON 定时关关:OFF 4。需要定时的开关01234 _tm ntptimeStr;//时间结构体返回临时值 /**@name Gizwits 用户界面 * @{ */ /** * @brief 事件处理接口 * 描述: * 1. 用户可以自定义wifi模块状态的变化 * 2. 用户可以在事件处理逻辑中添加数据点,比如调用相关硬件外设操作界面。 * @param [in] info: 事件队列 * @param [in] data: 协议数据 * @param [in] len: 协议数据长度 * @return NULL * @ref gizwits_protocol.h */ int8_t ICACHE_FLASH_ATTR gizwitsEventProcess(eventInfo_t *info uint8_t *data uint32_t len) { uint8_t i = 0; dataPoint_t * dataPointPtr = (dataPoint_t *)data; moduleStatusInfo_t * wifiData = (moduleStatusInfo_t *)data; if((NULL == info) || (NULL == data)) { GIZWITS_LOG("!!! gizwitsEventProcess Error \n"); return -1; } for(i = 0; i < info->num; i++) { switch(info->event[i]) { case EVENT_sw1 : currentDataPoint.valuesw1 = dataPointPtr->valuesw1; GIZWITS_LOG("Evt: EVENT_sw1 %d \n" currentDataPoint.valuesw1); if(0x01 == currentDataPoint.valuesw1) { STA[0]=1;//用户处理 } else { STA[0]=0;//用户处理 } break; case EVENT_sw2 : currentDataPoint.valuesw2 = dataPointPtr->valuesw2; GIZWITS_LOG("Evt: EVENT_sw2 %d \n" currentDataPoint.valuesw2); if(0x01 == currentDataPoint.valuesw2) { STA[1]=1;//用户处理 } else { STA[1]=0;//用户处理 } break; case EVENT_sw3 : currentDataPoint.valuesw3 = dataPointPtr->valuesw3; GIZWITS_LOG("Evt: EVENT_sw3 %d \n" currentDataPoint.valuesw3); if(0x01 == currentDataPoint.valuesw3) { STA[2]=1;//用户处理 } else { STA[2]=0;//用户处理 } break; case EVENT_sw4 : currentDataPoint.valuesw4 = dataPointPtr->valuesw4; GIZWITS_LOG("Evt: EVENT_sw4 %d \n" currentDataPoint.valuesw4); if(0x01 == currentDataPoint.valuesw4) { STA[3]=1;//用户处理 } else { STA[3]=0;//用户处理 } break; case EVENT_ok : currentDataPoint.valueok = dataPointPtr->valueok; GIZWITS_LOG("Evt: EVENT_ok %d \n" currentDataPoint.valueok); if(0x01 == currentDataPoint.valueok) { STA[4]=0;//用户处理 } else { STA[4]=1;//用户处理 } break; case EVENT_sw: currentDataPoint.valuesw = dataPointPtr->valuesw; GIZWITS_LOG("Evt: EVENT_sw %d\n" currentDataPoint.valuesw); switch(currentDataPoint.valuesw) { case sw_VALUE0://开关1 time_data[4]=0;//用户处理 break; case sw_VALUE1://开关2 time_data[4]=1;//用户处理 break; case sw_VALUE2://开关3 time_data[4]=2;//用户处理 break; case sw_VALUE3://开关4 time_data[4]=3;//用户处理 break; case sw_VALUE4://所有开关 time_data[4]=4;//用户处理 break; default: break; } break; case EVENT_mode: currentDataPoint.valuemode = dataPointPtr->valuemode; GIZWITS_LOG("Evt: EVENT_mode %d\n" currentDataPoint.valuemode); switch(currentDataPoint.valuemode) { case mode_VALUE0: time_data[3]=1;//用户处理 break; case mode_VALUE1: time_data[3]=0;//用户处理 break; default: break; } break; case EVENT_hour: currentDataPoint.valuehour= dataPointPtr->valuehour; GIZWITS_LOG("Evt:EVENT_hour %d\n"currentDataPoint.valuehour); time_data[0]=currentDataPoint.valuehour;//用户处理 break; case EVENT_minute: currentDataPoint.valueminute= dataPointPtr->valueminute; GIZWITS_LOG("Evt:EVENT_minute %d\n"currentDataPoint.valueminute); time_data[1]=currentDataPoint.valueminute;//用户处理 break; case EVENT_countdown: currentDataPoint.valuecountdown= dataPointPtr->valuecountdown; GIZWITS_LOG("Evt:EVENT_countdown %d\n"currentDataPoint.valuecountdown); time_data[2]=currentDataPoint.valuecountdown * 60;//用户处理,转换成秒钟 break; case WIFI_SOFTAP://WIFI处于SOFTAP模式,热点模式,Access Point,提供无线接入服务,允许其它无线设备接入,提供数据访问,一般的无线路由/网桥工作在该模式下。AP和AP之间允许相互连接 Sta模式; break; case WIFI_AIRlink://WIFI处于AIRlink模式,广播模式 break; case WIFI_STATION://WIFI处于STATION模式,类似于无线终端,sta本身并不接受无线的接入,它可以连接到AP,一般无线网卡即工作在该模式。 break; case WIFI_CON_ROUTER://wifi连接路由器 GIZWITS_LOG("@@@@ connected router\n"); break; case WIFI_DISCON_ROUTER://WiFi断开路由器 GIZWITS_LOG("@@@@ disconnected router\n"); break; case WIFI_CON_M2M://WIFI连接M2M GIZWITS_LOG("@@@@ connected m2m\n"); setConnectM2MStatus(0x01); break; case WIFI_DISCON_M2M://WIFI断开M2M GIZWITS_LOG("@@@@ disconnected m2m\n"); setConnectM2MStatus(0x00); break; case WIFI_RSSI://wifi接收信号的强度 GIZWITS_LOG("@@@@ RSSI %d\n" wifiData->rssi); break; case TRANSPARENT_DATA://透明数据传输 GIZWITS_LOG("TRANSPARENT_DATA \n"); //用户处理 读取数据 [data] 大小 [len] break; case MODULE_INFO://模块信息 GIZWITS_LOG("MODULE INFO ...\n"); break; default: break; } } system_os_post(USER_TASK_PRIO_2 SIG_UPGRADE_DATA 0); return 0; } /** * 用户网络时间获取与数据处理 * 这里用户除了需要获取网络时间以外,还要创建相应的任务 * @参数 无 * @返回 无 */ void ICACHE_FLASH_ATTR getntpTimerFunc(void) { //倒计时缓存数据 bool swls1[2] = {0};//临时缓存倒计时 bool swls2[2] = {0};//临时缓存定时 uint32_t swls[4] = {0};//缓存需要设置的开关标志 /******************倒计时************************ ******倒计时处理定时器可以实现掉网情况下也能执行,还可****************** ******以通过网络时间判定,触发了之后保存现在时间,计算出****************** ******要相应的时间,然后判断当前时间是否达到了控制的时间****************** ******网络处理方法请自行参考上述流程写*************************/ if((time_data[2]!=0) && (STA[4]==1) && (swls1[0]==0)) { swls1[0]=1; swls1[1]=1; STA[4]=0;//确定开关也要进行清位上报 } if((time_data[2]!=0) && (swls1[0]==1))//如果倒计时值大于0而起OK开关按下,倒计时不创建多任务,创建多任务之后无法看到剩余时间 { if(swls1[1]==1) { swls[0]=time_data[4];//缓存要使用的开关标志 swls[1]=time_data[3];//缓存需要设置的开关标志 time_data[4]=0;//云端清位 time_data[3]=0;//云端清位 swls1[1]=0; } time_data[2]--;//由于此函数是1秒执行一次,所以每秒减1就行了 } else//倒计时结束了 { swls1[0]=0; //开关控制 switch(swls[0]) { case 0 : { if(swls[1]==0) STA[0]=0;//设置第一个开关的状态 else STA[0]=1;//设置第一个开关的状态 } break; case 1 : { if(swls[1]==0) STA[1]=0;//设置第二个开关的状态 else STA[1]=1;//设置第一个开关的状态 } break; case 2 : { if(swls[1]==0) STA[2]=0;//设置第三个开关的状态 else STA[2]=1;//设置第一个开关的状态 } break; case 3 : { if(swls[1]==0) STA[3]=0;//设置第四个开关的状态 else STA[3]=1;//设置第一个开关的状态 } break; case 4 : { if(swls[1]==0) //设置全部开关的状态 { STA[0]=0; STA[1]=0; STA[2]=0; STA[3]=0; } else { STA[0]=1; STA[1]=1; STA[2]=1; STA[3]=1; } } break; default: break; } } /******************倒计时处理结束************************/ /******************定时预约处理*************************/ /*currentDataPoint.valuehour = time_data[0]; currentDataPoint.valueminute = time_data[1];*/ gagentGetNTP(&ntptimeStr); os_printf("gagentntp secon: %d"ntptimeStr.second);//打印时间 if(((time_data[0] != 0) || (time_data[1] != 0)) && (STA[4]==1) && (swls2[0]==0)) { swls2[0]=1; swls2[1]=1; STA[4]=0;//确定开关也要进行清位上报 currentDataPoint.valuehour = 0;//云端清除 currentDataPoint.valueminute = 0;//云端清除 } if(((time_data[0] != 0) || (time_data[1] != 0)) && (swls2[0]==1) ) { if(swls2[1]==1) { swls[2]=time_data[4];//缓存要使用的开关标志 swls[3]=time_data[3];//缓存需要设置的开关标志 time_data[4]=0;//云端清位 time_data[3]=0;//云端清位 swls2[1]=0; } if(ntptimeStr.hour == time_data[0])//时 { if(ntptimeStr.minute == time_data[1])//分 { swls2[0]=0; //开关控制 switch(swls[0]) { case 0 : { if(swls[1]==0) STA[0]=0;//设置第一个开关的状态 else STA[0]=1;//设置第一个开关的状态 } break; case 1 : { if(swls[1]==0) STA[1]=0;//设置第二个开关的状态 else STA[1]=1;//设置第一个开关的状态 } break; case 2 : { if(swls[1]==0) STA[2]=0;//设置第三个开关的状态 else STA[2]=1;//设置第一个开关的状态 } break; case 3 : { if(swls[1]==0) STA[3]=0;//设置第四个开关的状态 else STA[3]=1;//设置第一个开关的状态 } break; case 4 : { if(swls[1]==0) //设置全部开关的状态 { STA[0]=0; STA[1]=0; STA[2]=0; STA[3]=0; } else { STA[0]=1; STA[1]=1; STA[2]=1; STA[3]=1; } } break; default: break; } } } } } /** * 用户数据采集 * 这里用户除了需要实现数据点采集以外的数据采集外,还可以自定义采集频率和设计数据滤波算法。 * @参数 无 * @返回 无 */ void ICACHE_FLASH_ATTR userHandle(void) { //GPIO开关控制,此处为低电平有效控制,若改为高电平,则不需要取反 GPIO_OUTPUT_SET(GPIO_ID_PIN(12) !STA[0]); GPIO_OUTPUT_SET(GPIO_ID_PIN(13) !STA[1]); GPIO_OUTPUT_SET(GPIO_ID_PIN(14) !STA[2]); GPIO_OUTPUT_SET(GPIO_ID_PIN(15) !STA[3]); //数据上报,可适当增加定时上报时间,节约芯片上传产生不必要的负荷 currentDataPoint.valuesw1 = STA[0]; currentDataPoint.valuesw2 = STA[1]; currentDataPoint.valuesw3 = STA[2]; currentDataPoint.valuesw4 = STA[3]; currentDataPoint.valueok = STA[4]; if(time_data[2]<60 && time_data[2]>0) currentDataPoint.valuecountdown =1;//不到1分钟按照1分钟计算 else currentDataPoint.valuecountdown = time_data[2]/60;//秒钟转换成分钟 system_os_post(USER_TASK_PRIO_2 SIG_UPGRADE_DATA 0); } /** * 数据点初始化功能 * 在函数中完成初始用户相关数据 * @参数 无 * @返回 无 * @note 开发人员可以在这个函数中添加一个数据点状态初始化值。 */ void ICACHE_FLASH_ATTR userInit(void) { gizMemset((uint8_t *)¤tDataPoint 0 sizeof(dataPoint_t)); /** 警告!!!因变量的初始化,必须在数据范围 **/ //以下数据点都不具备掉电存储的初始化 currentDataPoint.valuesw1 = 0; currentDataPoint.valuesw2 = 0; currentDataPoint.valuesw3 = 0; currentDataPoint.valuesw4 = 0; currentDataPoint.valueok = 0; currentDataPoint.valuesw = 0; currentDataPoint.valuemode = 0; currentDataPoint.valuehour = 0; currentDataPoint.valueminute = 0; }

家庭使用精度的TVOC传感器有哪些可选

最近家里感觉有点不明气体,想检测一下甲醛等有害气体的浓度,准备购买家庭使用精度的TVOC传感器,有哪些可选

想DIY个VS1053B解码板哪里可以找到应用电路

想DIY个VS1053B解码板哪里可以找到应用电路