乐鑫esp8266的 基于Nonos移植红外线1883,实现遥控器控制

代码地址如下:
http://www.demodashi.com/demo/12613.html


一、前言。

距离上篇的8266进阶博文有那么一段时间了,那么本文带来的是基于Nonos的红外线H1838的NEC协议的移植小案例,浏览博文前,需要知道以下常识:

  • 1、 红外遥控的原理是什么?
  • 2、红外遥控的协议有哪些?NEC?
  • 3、红外遥控的电路组成?8266的最小系统搭搭建!


二、本博文实现的现象。


1. 实现的现象;


遥控器来控制三盏灯的亮灭情况,同时用遥控器进去配网模式,使8266进去一键配网模式!有些人问我的这个哪里买的,本文购买的红外线整套元器件,博文后面有某宝购买链接。

  • 三盏灯(红灯、绿灯、蓝灯),分别连接8266的 GPIO12、GPIO13、GPIO15;
  • 红外接收模块1883的输出端接8266的 GPIO14 ,其余看图接 !



2. 使用说明;




3. 遥控器对应的码值;


  • 下面仅仅列了本文所需的按键的键值,其他请自行查询;

按键 键值
1 0x45
2 0x46
3 0x47
9 0x09
# 0x0d

三、esp8266的GPIO口中断使用。


  • 接收短脚使用官方推荐的GPIO14 ,见下图;



  • GPIO14中断初始化 ;

    //中断停止
    ETS_GPIO_INTR_DISABLE();
    //设置中断回调函数
    ETS_GPIO_INTR_ATTACH(hongwai, NULL);
    //设置短脚14,低电平触发;
    gpio_pin_intr_state_set(GPIO_ID_PIN(14), GPIO_PIN_INTR_LOLEVEL);
    //中断使能
    ETS_GPIO_INTR_ENABLE();

四、中断回调函数。


  • 见下图可见 (图片来自网络), 当GPIO14为低电平时候,说明有信号过来了,所以我们上面代码设置为低电平触发中断回调,进一步的剖析电平状态:



    //开始判断是否为NEC波形引导码的前9MS和后4.5MS
    uint32 gpio_status = GPIO_REG_READ(GPIO_STATUS_ADDRESS);

    if (gpio_status & BIT(hwx)) {
        GPIO_REG_WRITE(GPIO_STATUS_W1TC_ADDRESS, gpio_status & BIT(hwx));
        gpio_pin_intr_state_set(GPIO_ID_PIN(hwx), GPIO_PIN_INTR_DISABLE);
    }

    //计数时间清0
    while (!GPIO_INPUT_GET(hwx)) {
        os_delay_us(100);
        ly_ct++;
    }
    if (ly_ct < 80 || ly_ct > 100) {
        gpio_pin_intr_state_set(GPIO_ID_PIN(hwx), 4);
        return;
    }

    //NEC引导码前9MS,ly_ct约等于90,给个误差值,用80-100之间来判断
    ly_ct = 0;
    while (GPIO_INPUT_GET(hwx)) {
        os_delay_us(100);
        ly_ct++;
    }
    if (ly_ct < 40 || ly_ct > 50) {
        gpio_pin_intr_state_set(GPIO_ID_PIN(hwx), 4);
        return;
    }

    //NEC引导码引导码的后4.5MS,ly_ct约45
    for (i = 0; i < 4; i++) {
        for (ia = 0; ia < 8; ia++) {

            while (!GPIO_INPUT_GET(hwx));
            ly_ct = 0;
            while (GPIO_INPUT_GET(hwx)) {
                os_delay_us(100);
                ly_ct++;
            }
            if (ly_ct > 20) {
                gpio_pin_intr_state_set(GPIO_ID_PIN(hwx), 4);
                return;
            }
            ly_lhj[i] >>= 1;
            if (ly_ct > 10)
                ly_lhj[i] |= 0x80; //时间量TH1高于10,即高于1MS判断为1
        }
    }

    //ly_lhj[2]就是我们要的数据,因为数组第3个就是上面的第三个数据码

    //重新设置中断
    gpio_pin_intr_state_set(GPIO_ID_PIN(hwx), GPIO_PIN_INTR_LOLEVEL);

五、LED初始化以及回调函数。


    //LED初始化,默认全部灭

    PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15);
    GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);

    PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13);
    GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);

    PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDI_U, FUNC_GPIO12);
    GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);

    //因为指示灯是连接到GPIO2,所以把其灭掉,否则会常亮;我也不知道为啥会常亮
    PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_GPIO2);
    GPIO_OUTPUT_SET(GPIO_ID_PIN(2), 1);

  • 回调函数:
  • 特别强调的是:1-9-1-9-1 才进去一键配网等待,我这利用一个标志位scFlag自加来做,当进去配网模式,全部灯会先亮再灭再亮!

static int scFlag = 0;

    char tempData[8];
    os_sprintf(tempData, "%s", data);
    os_printf("redCallBackFun  : %s\n", tempData);
    os_printf("redCallBackFun scFlag : %d\n", scFlag);

    //键值判断
    if (os_strcmp(tempData, "45") == 0) {
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);
        scFlag++;
        if (scFlag == 2 || scFlag == 4) {
            scFlag = 0;
        }
    } else if (os_strcmp(tempData, "46") == 0) {
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);
        scFlag = 0;
    } else if (os_strcmp(tempData, "47") == 0) {
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);
        scFlag = 0;
    } else if (os_strcmp(tempData, "9") == 0) {
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);
        scFlag++;
        if (scFlag == 1 || scFlag == 3 || scFlag == 5) {
            scFlag = 0;
        }
    } else if (os_strcmp(tempData, "d") == 0) {
        scFlag = 0;
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 0);
    }

    //标志位为5,说明进去一键配网等待,灯光闪烁
    if (scFlag == 5) {
        scFlag = 0;

        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);
        os_delay_us(60000);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 0);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 0);
        os_delay_us(60000);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(12), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(13), 1);
        GPIO_OUTPUT_SET(GPIO_ID_PIN(15), 1);

        os_printf("----------开始进去SmartConfig配网 \n\n-----");
        smartconfig_init();
    }

六、编译烧录固件。


  • 编译成功;



  • 烧录,注意我使用的是4M flash的8266-12f ,也就是4*8 =32Mbit的size;



  • 串口打印:


七、项目文件目录截图;

### 八、后记;

  • 头文件使用;
    //注册红外线使能
    comhwx_init();
    //注册红外线回调函数
    funRedInfra_CallBack(redCallBackFun);



乐鑫esp8266的 基于Nonos移植红外线1883,实现遥控器控制

代码地址如下:
http://www.demodashi.com/demo/12613.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

原文地址:https://www.cnblogs.com/demodashi/p/9436479.html

时间: 2024-10-30 10:23:18

乐鑫esp8266的 基于Nonos移植红外线1883,实现遥控器控制的相关文章

基于STM32F4移植W5500官方驱动库ioLibrary_Driver(转)

源: 基于STM32F4移植W5500官方驱动库ioLibrary_Driver 参考: 基于STM32+W5500 的Ethernet和Internet移植 Upgrade W5500 Throughput on Nucleo STM32F401RE Using SPI DMA 原文地址:https://www.cnblogs.com/LittleTiger/p/10142827.html

在Spring中基于JDBC进行数据访问时如何控制超时

超时分类 超时根据作用域可做如下层级划分: Transaction Timeout > Statement Timeout > JDBC Driver Socket Timeout Transaction Timeout指一组SQL操作执行时应在设定的时间内完成(提交或回滚),否则将引发超时.它的值应大于 N(语句数) * Statement Timeout Statement Timeout指完成单条SQL语句执行的最大允许时间.它的值应小于JDBC Driver Socket Timeou

Xendesktop 可基于物理机及虚拟机的桌面控制交付

我们在部署xendesktop虚拟桌面的时候,很多时候是利用xendesktop的底层机制复制相应的摸板生成虚拟桌面,但也有时候想接管已经设置好相应应用的物理机和虚拟机,这个时候可以采用xendesktop安装的时候部署remoteaccess 功能,直接将物理机和虚拟机被xendesktop进行接管 分为两个阶段: 1 在物理机或者虚拟机安装VDA如下安装的时候: 2 在DDC服务器中进行部署交付桌面的相关设置: 1 在物理机或者虚拟机安装VDA如下安装的时候:如果是xen的虚拟机需要安装xs

基于Android移植IIC设备驱动笔记

我是从2015.7.23开始移植这个驱动程序的,经过在网上查找资料,决定利用linux下I2C驱动体系结构来完成驱动移植 整个步骤是根据http://blog.csdn.net/rickbeyond/article/details/7838313这个大神的博客开始的,于是我的苦逼坑死我之路从此开始.... 第一天下午就卡在了第三步,即对Android.mk的编译上,刚开始是报如下错误 make: *** No rule to make target `/iic.c', needed by `ou

第七篇:基于物联网/WIFI/单片机的室内灯光控制系统设计论文、开题报告、原理图(全套毕业设计资料,绝对干货,内附下载链接)

首先打个广告:如果需要做毕设以及嵌入式项目合作,欢迎进入我们工作室:创想嵌入式设计工作室 以下时本人独立开发设计的毕设项目课题:<基于WIFI的室内灯光控制系统设计与实现>,现在共享出来供大家参阅,可用于做项目时借鉴,博尾附有下载链接.(内附本人联系方式,可一起交流探讨,交朋友). 针对本课题,本次共享的资料包几乎涵盖毕业设计所需的全部资料:设计方案,开题报告,程序源码,原理图,模块资料,论文,答辩PPT,模块学习资料,等等.本资料包不仅仅适用于"室内灯光控制系统设计与实现"

Apache2.4版本环境下基于虚拟主机、ssl、用户控制

环境说明:此篇博客是基于编译安装httpd2.4博客基础上进行的 一.虚拟主机: 1.1基于host [[email protected] apache]# vim/etc/httpd24/httpd.conf Include/etc/httpd24/extra/httpd-vhosts.conf   #开启虚拟主机 #DocumentRoot"/www/htdocs"    #将中心主机注释掉 [[email protected] apache]# cd/etc/httpd24/ex

【转载】基于平均法线实现顶点网格变形控制的总结

原文链接:http://blog.csdn.net/haohan_meng/article/details/22640991 顶点网格的变形功能,这在Unity官方商店的技术展示Demo中有一个案例.自己就是在这个案例的基础上进行的学习.案例中的功能全部都是用JS实现的,自己依样画葫芦,改成了C#,并对其中一些核心代码的工作原理进行了分析与学习,最终形成了这篇总结.其中的不正之处欢迎大家批评指出. 看到文章的标题,我们可能会想,要完成网格模型的变形,需要哪几个要素? 简单来说,就是两个:顶点与法

基于arm开发板四个按键控制四个灯亮

基于s5pv2410,cortex a8的四个按键每一个按键点了对应的灯 对于用汇编来编程的话不难,重点在于数据手册,电路图,管脚的看懂 直接上代码 .globl _start_start: ldr r0,=0xe0200c40 @按键控制寄存器的地址 ldr r1,[r0] bic r1,r1,#0xff @bic一次只能清8为每四位控制一个按键 bic r1,r1,#0xff<<8 @把16位清为零控制四个按键为输入方式 str r1,[r0] @配置按键为输入方式 ldr r0,=0xe

3:基于乐观锁(两种)控制并发: version、external锁

ES是基于乐观锁进行并发控制的. 如果有并发的业务场景,可以直接使用ES内置乐观锁机制. 使用的时候,java程序需要先Get指定的记录,获取到版本号,然后Put的时候,带着该版本号,请求更新. ES只有判断到 该记录的 version = 请求中的version值 时,才能进行更新.如果不相等,则舍弃. 下面演示如何使用乐观锁: 1. 先创建一条记录,此时ES返回信息中会有标识: version=1 PUT  /test_index/test_type/1 { "f1":"