【stm32单片机基础】红外NEC协议解码

这篇具有很好参考价值的文章主要介绍了【stm32单片机基础】红外NEC协议解码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【stm32单片机基础】红外NEC协议解码


前言

红外通信协议是一种基于红外线的传输技术,广泛使用的家电遥控器几乎都是采用的红外线传输技术,由于红外线为不可见光,对环境影响很小,红外线遥控不会影响其他家用电器,也不会影响临近的无线电设备。红外遥控的编码方式目前广泛使用的是: PWM(脉冲宽度调制)的 NEC 协议和 PhilipsPPM(脉冲位置调制) 的 RC-5 协议的。本文分享NEC协议接收端的解码程序。

红外NEC协议

通信协议分为发送端和接收端,接收端的波形与发射端刚好相反。
NEC IR 协议使用 32 位帧格式对密钥进行编码,如下所示

1、NEC 帧格式

地址码0 地址码1 命令码 命令码反码
LSB-MSB(0-7) LSB-MSB(8-15) LSB-MSB(16-23) LSB-MSB(24-31)

在标准的NEC协议中,地址码1为地址码0的反码,而在许多遥控器中,地址码0和地址码1共同作为红外遥控器的编码值。

2、发射端的波形

【stm32单片机基础】红外NEC协议解码
每个位都使用如图所示的脉冲距离进行传输。
逻辑“0”:562.5μs高电平,562.5μs低电平,总时长为1.125ms
逻辑“1”:562.5μs高电平,1.6875ms低电平,总时长为2.25ms

在遥控器上按某个键时,传输的消息将按顺序包含以下内容:

引导码:持续9ms 高电平,4.5ms低电平,作为启动信号;
紧接着是32bit的数据,按照上述的NEC帧格式的顺序;最后以562.5μs脉冲高电平结尾,表示一帧消息传输结束。
数据位的四个字节首先发送最低有效位
下图示例展示了NEC 红外传输帧的格式,以地址为 00h (00000000b) 和 ADh (10101101b) 的命令码为例。
传输一个消息帧总共需要 67.5ms。它需要27ms来传输16位地址(地址+地址反码)和16位命令(命令+命令反码)。
【stm32单片机基础】红外NEC协议解码
重复码
如果遥控器上的键保持按下状态,则会发射重复码,通常在完整的一帧消息结束后约40ms后发送;重复码将继续以 108 ms的间隔发出,直到红外遥控按键被释放。
重复码按顺序包含以下内容:

  • 9ms 前导高电平
  • 2.25ms的低电平
  • 562.5μs的高电平来标记一帧重复码的结束。

波形如下图所示:

【stm32单片机基础】红外NEC协议解码

3、接收端程序解码

由于接收端的波形与发射端的波形刚好相反,在下述程序中,只需要一个定时器即可解码红外NEC协议,包含了红外重复码的检测,可区别红外遥控长按和短按事件。文章来源地址https://www.toymoban.com/news/detail-428466.html


#define IR_IN  GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_1)   // PA1 红外接收DQ引脚
unsigned char ir_code[4];      // 解码值保存变量
unsigned char ir_decode_ok_flag = RESET;    // 解码成功标志位

/*
    NEC红外编码: 引导码 + 地址码 + 地址码(取反) + 数据 + 数据(取反)
      引导吗:0.56ms(低电平) + 2.25ms(高电平)
       数据1: 0.56ms(低电平) + 1.12ms(高电平)
*/
// 红外解码程序,100us定期执行就可以,将该函数放在100us的定时器中即可。
void Ir_Decode(void)
{
    static unsigned int l_cnt = 0;                            // 低电平时间计数
    static unsigned int h_cnt = 0;                            // 高电平时间计数
    static unsigned int l_cnt_save = 0;                       // 保存低电平时长
    static unsigned int h_cnt_save = 0;                       // 保存高电平时长
    static unsigned char falling_edge_valid_flag = RESET;      // IR电平由高变低标志位
    static unsigned char rcv_sync_ok_flag = RESET;             // 同步码接收成功标志位
    static unsigned char bit_value = 0;                        // 位解码值
    static unsigned char bit_rcv_cnt = 0;                      // 位接收个数变量
    if( RESET == IR_IN )
    {
        if( 0 == l_cnt )    // IR由高变低后立马记录上次测得的高电平时长
        {
            h_cnt_save = h_cnt;
            falling_edge_valid_flag = SET;
        }
        
        
        l_cnt ++;
        if( l_cnt > 1600 )    // 防止计数溢出
        {
            l_cnt = 1600;
        }
        h_cnt = 0;  // 计数清零
				
    }
    else
    {
        if( 0 == h_cnt )   // IR由低变高后立马记录上次测得的低电平时长
        {
            l_cnt_save = l_cnt;
        }
        
        h_cnt ++;
        if( h_cnt > 1600 )   // 防止计数溢出
        {
            h_cnt = 1600;
        }
				
        l_cnt = 0;  // 计数清零
				
				
		if(ir_decode_ok_flag == 1)
		{
				if(h_cnt > 1200)
				ir_decode_ok_flag = 2;		//  短按
		}
       
    }
    
    if( SET == falling_edge_valid_flag )
    {
        falling_edge_valid_flag = RESET;
        
        /* 位解码 */
        if( ((l_cnt_save >= 3)&&(l_cnt_save <= 9)) &&          // 560us低电平, 560us高电平
            ((h_cnt_save >= 3)&&(h_cnt_save <= 9)) )
        {
            bit_value = 0;
        }
        else if( ((l_cnt_save >= 3)&&(l_cnt_save <= 9)) &&    // 560us低电平,1680us高电平
                  ((h_cnt_save >= 14)&&(h_cnt_save <= 20)) )
        {
            bit_value = 1;
        }
        else
        {                    
            bit_value = 2;
        }
        
        if( SET == rcv_sync_ok_flag )
        {
            if((1 == bit_value) || (0 == bit_value) )
            {
                if( bit_rcv_cnt < 8 )
                {
                    ir_code[0] |= (bit_value<< (bit_rcv_cnt%8));
                }
                else if( bit_rcv_cnt < 16 )
                {
                    ir_code[1] |= (bit_value<< (bit_rcv_cnt%8));
                }
                else if( bit_rcv_cnt < 24 )
                {
                    ir_code[2] |= (bit_value<< (bit_rcv_cnt%8));
                }
                else if( bit_rcv_cnt < 32 )
                {
                    ir_code[3] |= (bit_value<< (bit_rcv_cnt%8));
                }
                
                if( bit_rcv_cnt >= 31 )
                {
                    ir_decode_ok_flag = SET;
                    rcv_sync_ok_flag = RESET; 
                }
                
                bit_rcv_cnt ++;
            }
            else
            {
                rcv_sync_ok_flag = RESET;                 // 位接收错误,重新解码
            }
        } 
				
        if( ((l_cnt_save >= 87)&&(l_cnt_save <= 93))  &&
            ((h_cnt_save >= 42)&&(h_cnt_save <= 48)) )            // 同步码,9ms低电平,4.5ms高电平
        { 
            rcv_sync_ok_flag = SET;
            bit_rcv_cnt = 0;
            ir_code[0] = 0;
            ir_code[1] = 0;
            ir_code[2] = 0;
            ir_code[3] = 0;
        } 
		else if(((l_cnt_save >= 87)&&(l_cnt_save <= 93))  &&
			((h_cnt_save >= 20)&&(h_cnt_save <= 25)) )
		{
				printf("repeate code\r\n");
				ir_decode_ok_flag = 3;		//长按
		}
		
    }     
}

到了这里,关于【stm32单片机基础】红外NEC协议解码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于STM32单片机的智能家居窗户窗帘控制系统红外遥控proteus仿真原理图PCB

    功能: 0.本系统采用STM32F103RCT6作为单片机 1.LCD1602液晶实时显示当前时间/窗帘状态/光照强度 2.支持手动按键/定时/光强检测三种模式控制窗帘 3.\\\'设置’键进入设置界面 4.默认状态下’确定’键可切换模式 5.设置界面’确定’为确定 6.支持掉电保存 7.采用DC002作为电源接口可直

    2024年02月11日
    浏览(58)
  • STM32单片机(五)第二节:EXTI外部中断练习(对射式红外传感器计次和旋转编码器计次)

    ❤️ 专栏简介:本专栏记录了从零学习单片机的过程,其中包括51单片机和STM32单片机两部分;建议先学习51单片机,其是STM32等高级单片机的基础;这样再学习STM32时才能融会贯通。 ☀️ 专栏适用人群 :适用于想要从零基础开始学习入门单片机,且有一定C语言基础的的童鞋

    2024年02月09日
    浏览(45)
  • 105-基于stm32单片机智能家居温湿度烟雾监测人体红外防盗报警系统Proteus仿真+程序源码

    一:功能介绍 1、采用stm32单片机+LCD1602+DHT11温湿度传感器+烟雾传感器+按键开关+蜂鸣器+LED灯,制作一个智能家居温湿度烟雾监测人体红外防盗报警系统; 2、通过按键开关来模拟人体红外检测触发,并且可以通过按键开关来设置正在布防和停止布防状态,布防状态下,当检测

    2024年02月03日
    浏览(64)
  • STM32单片机(九)USART串口----第一节:USART串口协议

    ❤️ 专栏简介:本专栏记录了从零学习单片机的过程,其中包括51单片机和STM32单片机两部分;建议先学习51单片机,其是STM32等高级单片机的基础;这样再学习STM32时才能融会贯通。 ☀️ 专栏适用人群 :适用于想要从零基础开始学习入门单片机,且有一定C语言基础的的童鞋

    2024年02月16日
    浏览(64)
  • POWERLINK协议在stm32单片机+w5500移植成功经验分享

    连续折腾了多个晚上,又趁周末又花了一天时间,终于把powerlink协议移植成功到单片机上啦。本想放弃,但想了下不管我能不能用上,结个尾吧,分享给有需要的人。放弃并不难,但坚持一定很酷。为了移植测试这个协议花了不少血本。stm32开发板就买了两套,其中第一套板

    2024年02月09日
    浏览(57)
  • K_A12_004 基于STM32等单片机采集人体红外感应(HC-SR501)模块串口与OLED0.96双显示

    单片机型号 测试条件 模块名称 代码功能 STC89C52RC 晶振11.0592M HC-SR501模块 STC89C52RC采集HC-SR501模块参数 串口与OLED0.96双显示 STM32F103C8T6 晶振8M/系统时钟72M HC-SR501模块 STM32F103C8T6采集HC-SR501模块参数 串口与OLED0.96双显示 其他资料目录 直戳跳转 HC-SR501模块 引脚说明 VCC 正极 3.3-5V供电

    2024年01月19日
    浏览(50)
  • 【STM32】基础知识 第一课 单片机简介

    单片机 (Single-Chip Microcomputer) 单品微型计算机, 是一种集成电路芯片. 电脑 vs 单片机: 电脑 单片机 CPU CPU 内存 SRAM 硬盘 Flash 主板 外设 SRAM 静态随机读取器 (Static Random-Access Memory): SRAM 是随机存储器的一种, 属于静态数据, 这类存储器要是维持电源, 里面存储的信息就可以恒常维持

    2024年02月11日
    浏览(93)
  • 单片机第三季-第一课:STM32基础

    STM32系列分类: 型号命名原则: STM32F103系列: 涉及到的几个概念: DMA:Direct Memory Access,直接存储器访问。DMA传输将数据从一个地址空间复制到另一个地址空间,提供外设和存储器或存储器和存储器之间的高速数据传输; 2.0到3.6V供电,IO口可以兼容5V电压; 与51单片机不同

    2024年02月09日
    浏览(41)
  • 101、基于STM32单片机智能输液器红外点滴液位监控报警系统设计(程序+原理图+PCB源文件+参考论文+硬件设计资料+元器件清单等)

    单片机主芯片选择方案 方案一:AT89C51是美国ATMEL公司生产的低电压,高性能CMOS型8位单片机,器件采用ATMEL公司的高密度、非易失性存储技术生产,兼容标准MCS-51指令系统,片内置通用8位中央处理器(CPU)和Flash存储单元,功能强大。其片内的4K程序存储器是FLASH工艺的,这种单

    2024年02月13日
    浏览(60)
  • 32、基于51单片机红外智能垃圾桶系统设计

    随着现代化进程的日益推进,科技越来越发达,人们的生活水平也提高了,城市化程度越来越高,与此同时也带了许多问题,生活垃圾越来越多垃圾设施却不够完善。无论是在公共场合还是家庭厨房的垃圾大都是没有盖或者有盖但需要人用手打开的,比如夏天的家庭厨房没有

    2023年04月14日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包