基于SOC方案的嵌入式开发-远程定时设备
Soc方案实现简单的定时开关灯
http://club.gizwits.com/forum.php?mod=viewthread&tid=7787&highlight=%E5%AE%9A%E6%97%B6
<ignore_js_op>
步骤②:定义三个数据点:
灯的总开关 (lightOpenOff): 布尔值类型 可写
定时器的总开关(isTimerOpen):布尔值 可写
定时开的时间(timerOpen):数值 0~3660 单位:秒
<ignore_js_op>
步骤③:选择MCU开发,选择硬件平台:esp8266-32M Product Secret不用我多说了。
<ignore_js_op>
二:电路图的设计与程序编写。
电路图:
按键S1长按就是进入airlink配网模式了
按键S2按下接通时候就是烧录模式了
LED是接在GPIO12和VCC之间的。
<ignore_js_op>
程序篇:
步骤一:先搭建8266的开发环境,我这使用的是安信可的集成环境,并且导入工程。如果有不懂的,可以看这篇:http://blog.csdn.net/xh870189248/article/details/77985541
步骤二:我们先修改我们程序的进入 “配网模式”的按键程序,首先我们打开工程的 app --> user --> user_main.c 文件,修改过程如下:
修改第①处:
我们先把按键定义改下,我们这个是只有一个按键,所以key的数量为1,见下面的修改。
修改前:
- #define GPIO_KEY_NUM 2 ///< Defines the total number of key members
- #define KEY_0_IO_MUX PERIPHS_IO_MUX_GPIO0_U ///< ESP8266 GPIO function
- #define KEY_0_IO_NUM 0 ///< ESP8266 GPIO number
- #define KEY_0_IO_FUNC FUNC_GPIO0 ///< ESP8266 GPIO name
- #define KEY_1_IO_MUX PERIPHS_IO_MUX_MTMS_U ///< ESP8266 GPIO function
- #define KEY_1_IO_NUM 14 ///< ESP8266 GPIO number
- #define KEY_1_IO_FUNC FUNC_GPIO14 ///< ESP8266 GPIO name
- LOCAL key_typedef_t * singleKey[GPIO_KEY_NUM]; ///< Defines a single key member array pointer
- LOCAL keys_typedef_t keys; ///< Defines the overall key module structure pointer
复制代码
修改后: (我们在电路图看到是GPIO4触发配网模式,所以该为GPIO4)
- #define GPIO_KEY_NUM 1 ///< Defines the total number of key members
- #define KEY_0_IO_MUX PERIPHS_IO_MUX_GPIO4_U ///< ESP8266 GPIO function
- #define KEY_0_IO_NUM 4 ///< ESP8266 GPIO number
- #define KEY_0_IO_FUNC FUNC_GPIO4 ///< ESP8266 GPIO name
复制代码
修改第②处:
把以下的代码删除:
- **
- * Key2 key to short press processing
- * @param none
- * @return none
- */
- LOCAL void ICACHE_FLASH_ATTR key2ShortPress(void)
- {</p><p>GIZWITS_LOG("#### key2 short press, soft ap mode \n");
- gizwitsSetMode(WIFI_SOFTAP_MODE);
- }
- /**
- * Key2 button long press
- * @param none
- * @return none
- */
- LOCAL void ICACHE_FLASH_ATTR key2LongPress(void)
- {
- GIZWITS_LOG("#### key2 long press, airlink mode\n");
- gizwitsSetMode(WIFI_AIRLINK_MODE);
- }
复制代码
同时把 ICACHE_FLASH_ATTR 函数里面以下代码去掉:
singleKey[1] = keyInitOne(KEY_1_IO_NUM, KEY_1_IO_MUX, KEY_1_IO_FUNC, key2LongPress, key2ShortPress);
最后得到的按键初始化函数 ICACHE_FLASH_ATTR 如下代码:
- /**
- * Key to initialize
- * @param none
- * @return none
- */
- LOCAL void ICACHE_FLASH_ATTR keyInit(void)
- {
- singleKey[0] = keyInitOne(KEY_0_IO_NUM, KEY_0_IO_MUX, KEY_0_IO_FUNC,
- key1LongPress, key1ShortPress); //key1LongPress方法回调对应上面的,key1shortPress同样也是
- keys.singleKey = singleKey;
- keyParaInit(&keys);
- <strong><font color="seagreen">}</font></strong>
复制代码
修改第③处:
我们把按键短按和长按的方法修改下,让按键短按进入 AirLink配网模式,长按进入softAP配网模式,修改如下:
- /**
- * Key1 key short press processing
- * @param none
- * @return none
- */
- LOCAL void ICACHE_FLASH_ATTR key1ShortPress(void)
- {
- gizwitsSetMode(WIFI_SOFTAP_MODE);
- }
- /**
- * Key1 key presses a long press
- * @param none
- * @return none
- */
- LOCAL void ICACHE_FLASH_ATTR key1LongPress(void)
- {
- gizwitsSetMode(WIFI_AIRLINK_MODE);
- }
复制代码
修改第④处: 因为我们是只有一个功能,并且只有使用到一个GPIO口,所以我们仅仅初始化一个就好了,我这在user_init()主函数直接加入以下代码:
- PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDI_U, FUNC_GPIO12); //GPIO12初始化
- GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 0);//GPIO12 低电平输出
复制代码
修改第五处:我们现在把目标转到 app --->Gizwits_product.c 文件(下同),修改我们8266收到指令后作出动作的代码:
修改前:
- case EVENT_lightOnOff :
- currentDataPoint.valuelightOnOff = dataPointPtr->valuelightOnOff;
- GIZWITS_LOG("Evt: EVENT_lightOnOff %d \n", currentDataPoint.valuelightOnOff);
- if(0x01 == currentDataPoint.valuelightOnOff)
- {
- //user handle
- }
- else
- {
- //user handle
- }
- break;
复制代码
修改后: 收到0x01(true)开灯,0x00(false)关灯,因为8266的内部GPIO是默认上拉,所以选择高电平输出,反而灯会亮!!博主也是从这篇文章了解到的:http://blog.csdn.net/jackhuang2015/article/details/50839401
- case EVENT_lightOnOff :
- currentDataPoint.valuelightOnOff = dataPointPtr->valuelightOnOff;
- GIZWITS_LOG("Evt: EVENT_lightOnOff %d \n", currentDataPoint.valuelightOnOff);
- if(0x01 == currentDataPoint.valuelightOnOff)
- {
- GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1); //开灯
- }
- else
- {
- GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 0); //关灯
- }
- break;
复制代码
修改第⑥处:
我们在文件新增一个定时器使能的bool类型、一个软件定时器结构体和一个定时时间。
- //布尔值,定时器开关的状态
- bool isTimer ;
- //定时时间
- uint16_t timer_timers;
- /** 定时器结构体 */
- static os_timer_t os_timer;
复制代码
我们在收到app发来的 isTimerOpen数据点(开关定时器的指令)的方法处理这样做:
- <p> case EVENT_isTimerOpen :
- currentDataPoint.valueisTimerOpen = dataPointPtr->valueisTimerOpen;
- if(0x01 == currentDataPoint.valueisTimerOpen)
- {
- isTimer=true;
- } else {
- /** 关闭该定时器 */
- os_timer_disarm( &os_timer ); </p><p> /** 定时器使能为false */
- isTimer=false;
- }
- break;</p>
复制代码
我们在收到app发来的 TimerOpen数据点(定时时间)的方法处理这样做: 注意,每次开启定时器,要先把其关闭掉,再重新初始化使能。
- case EVENT_timerOpen:
- currentDataPoint.valuetimerOpen= dataPointPtr->valuetimerOpen; </p><p> //只有当使能状态为true就可以开启定时器
- if(isTimer){
- /** 关闭该定时器 */
- os_timer_disarm( &os_timer );
- // 配置该定时器回调函数,指定的执行方法是: Led_Task_Run (),下面会提供代码
- os_timer_setfn( &os_timer, (ETSTimerFunc *) (<font color="red"> Led_Task_Run</font> ), NULL );
- /** 开启该定时器 :下发的是秒数,这里的单位是毫秒,要乘1000* ,后面false表示仅仅执行一次**/
- os_timer_arm( &os_timer, currentDataPoint.valuetimerOpen*1000, false );
- /**赋值给timer_timers,方便会调用 */
- timer_timers=currentDataPoint.valuetimerOpen;
- }
- break;
复制代码
定时任务函数这样做:
- /**
- * 定时任务函数
- */
- void Led_Task_Run(void){
- //开灯
- GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
- //执行完毕,我们要把定时时间设置0 ,定时使能状态为false
- timer_timers=0;
- isTimer=false;
- }
复制代码
修改⑦:改变上报数据的方法:
- void ICACHE_FLASH_ATTR userHandle(void)
- {
- //获取GPIO12的高低电平,因为高电平是触发开灯,所以ture就是开灯
- currentDataPoint.valuelightOnOff = GPIO_INPUT_GET(12) ;
- //是否开启定时器的回调
- currentDataPoint.valueisTimerOpen =isTimer ;
- //定时时间回调,如果用戶設置了定時器关闭,那么我们返回0,否则返回定时时间,注意这个定时时间是固定的。不是倒计时时间。
- if(isTimer){
- currentDataPoint.valuetimerOpen =timer_timers ;
- }else{
- currentDataPoint.valuetimerOpen =0;
- }
- system_os_post(USER_TASK_PRIO_2, SIG_UPGRADE_DATA, 0);
- }
复制代码
基于SOC方案的嵌入式开发-远程定时设备的更多相关文章
- Mac下搭建基于PlatformIO的嵌入式开发环境(STM32开发)
PlatformIO简介 PlatformIO是开源的物联网开发生态系统.提供跨平台的代码构建器.集成开发环境(IDE),兼容 Arduino,ESP8266和mbed等 支持在Windows.Lin ...
- 【嵌入式开发】嵌入式 开发环境 (远程登录 | 文件共享 | NFS TFTP 服务器 | 串口连接 | Win8.1 + RedHat Enterprise 6.3 + Vmware11)
作者 : 万境绝尘 博客地址 : http://blog.csdn.net/shulianghan/article/details/42254237 一. 相关工具下载 嵌入式开发工具包 : -- 下 ...
- 【推荐图书】+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等
[推荐图书]+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等 3赞 发表于 2016/7/4 21:14:12 阅读(1921) 评论(3) 初次接触FPGA,到 ...
- 基于Vivado的嵌入式开发 ——PS+PL实践
基于Vivado的嵌入式开发 ——PS走起 硬件平台:ZedBoard 开发工具:Vivado 2014.2 1.规划 废话不多说,依然是流水灯,这次是采用PS+PL实现. 功能依旧简单,目标是为了学 ...
- CLion远程调试嵌入式开发板程序
CLion远程调试嵌入式开发板程序 目录 CLion远程调试嵌入式开发板程序 1. 目的 2. 前提条件 3. CLion设置 3.1 设置一个Deployment 3.2 上传需要的目录到目标板子 ...
- 基于IAP和Keil MDK的远程升级设计
写在前面:三个周之前,我突然想写一个远程升级的程序.那个时候我只是大概知道IAP的意思是在应用编程,但怎么编,我还一无所知.我给自己定下一个个阶段目标,从最基础的代码一点点写起,解决一个又一个的问题. ...
- 【嵌入式开发】写入开发板Linux系统-模型S3C6410
笔者 : 万境绝尘 转载请著名出处 最终拿到板子了, 嵌入式开发正式开启. 板子型号 : 三星 S3C6410 基于ARM11, 指令集基于arm6指令集; 为毛不是 Cortext A9的板子; 烧 ...
- 应聘linux/ARM嵌入式开发岗位
**************************************************************** 因为发在中华英才和智联招聘没有人采我所以我 在这里发布我的个人简历希望 ...
- 【嵌入式开发】向开发板中烧写Linux系统-型号S3C6410
作者 : 万境绝尘 转载请著名出处 终于拿到板子了, 嵌入式开发正式开启. 板子型号 : 三星 S3C6410 基于ARM11, 指令集基于arm6指令集; 为毛不是 Cortext A9的板子; 烧 ...
随机推荐
- TensorFlow-GPU环境配置之四——配置和编译TensorFlow
首先,使用configure进行配置 配置完成后,使用bazel编译retrain命令,编译命令中加入--config=cuda即为启用GPU 编译进行中... 编译完成 编译完成后,调用retrai ...
- TextView设置成仅仅读
TextView设置成仅仅读 方法一:代理 - (BOOL)textViewShouldBeginEditing:(UITextView *)textView { return NO; } 方法二:设 ...
- yarn-cli 添加
添加依赖包 当你想使用另一个包时,你要先把它添加到依赖列表中.也就是执行 yarn add [package-name] 命令将它安装到你的项目中. 这也将同时更新你的 package.json 和 ...
- linux netlink套接字实现相似ss命令 ,统计套接字以及TCP信息
參考了 ss的源码 以及 netlink相关资料:http://blog.csdn.net/scdxmoe/article/details/27711205 实现结果为: gcc netlink_di ...
- 转:js点击事件在ios中失效的3种解决方案
ios中不允许将点击事件绑定在document或者body上,如果绑定上的话将会失效.解决方案: 例如: $(document).on('click', '#generate', function ...
- [NOI2015Day1]解题报告
今天一起做NOI的题. 我仅仅想说SunshinAK了好神啊. T3数据好坑啊,打表竟然被编译环境卡掉了... T1:程序自己主动分析 (http://www.lydsy.com/JudgeOnlin ...
- 12.解决CCScale9Sprite或者CCControlButton无法使用的问题。
问题: 使用CCScale9Sprite或者CCControlButton等控件的时候,会出现无法识别的情况. 解决方式: 1.include对应的头部,即#include "cocos-e ...
- MySQLi 和 PDO 连接 MySQL
PHP 连接 MySQL PHP 5 及以上版本建议使用以下方式连接 MySQL : MySQLi extension ("i" 意为 improved) PDO (PHP Dat ...
- ibatis 取消查询动态列的缓存
ibatis在查询结果列不确定(或是动态变化)的情况下,会因为列缓存的原因导致变化后的列数据查不出来 解决方法是: select标签有个属性remapResults,该属性默认值为false,设置成r ...
- 2016/1/22 3,将id为005的对象从集合中移除
package shuzu; public class Emp { private String id; private String name; public Emp(String id, Stri ...