基于FPGA的红外遥控接收器模块数据传输

时间:2025-06-13  作者:Diven  阅读:0

简介

基于FPGA的红外遥控接收器模块数据传输

本例是FPGA之旅设计的第十四例,本例将红外遥控的使用,并将红外接收器接收到红外遥控的数据显示在数码管上。

红外遥控接收器模块,非常简单,也是由GND,VCC和数据三个引脚组成,通过杜邦线可以直接连接在FPGA的IO口上,产品细节如下

红外数据传输

数据传输过程如下

引导码:标志的数据传输的开始。

数据码:传输红外遥控发送的数据,一帧数据共有32bit,4个字节。分别为**地址,地址反码,数据,数据反码。**先发送**低**位。

停止码:标志着数据传输的完成。

重复码:当一直按下某个按键的时候,并不会再次发送数据,而且通过重复码标志按键一直处于按下的状态。如果一直按下的话,约110ms,发送一次重复码。

在对数据传输过程有了个大致的了解后,下面就对每个部分进行详细的讲解。

所有波形都是对于遥控器来说的

1

引导码

引导码波形如下,遥控器先发送9ms的信号,然后空闲4.5ms后,引导码结束。

这个时候在开发板上结束到的电平变化为,9ms的低电平,4.5ms的高电平。也就是说,遥控器发送信号的时候,接收器上为低电平,遥控器空闲时,接收器上为高电平,这点在处理的时候需要注意。

2

数据码

数据码主要是看,数据0和数据1是如何表示的。通过下图可知,数据1是560us的信号,加1.69ms的空闲。数据0是560us的信号,加560us的空闲。知道了数据是如何表示的后,在接收的时候,只需要按照波形接收32bit的数据即可。

3

结束码

在最后一个数据接收完成了,遥控器会发送560us的信号,然后空闲,表示发送结束。

4

重复码

重复码,是和引导码对应的,如果发送的是重复码的话,引导码中的空闲4.5ms,会变成2.25ms,然后直接进入结束吗。根据空闲时间的长短,可以判断是引导码,还是重复码。

了解了其发送的波形变换情况,就可以进行代码的编写了。

Verilog代码实现

1

端口信号确定

端口信号很简洁,当接到一次红外数据的时候,infrared_end,就会拉高一个周期。

 

 

Infrared_Reception(  input    sys_clk,  input    rst_n,    input    infrared,        //红外信号IO  output  infrared_end,      //接收数据完成    output[7:0]  infrared_data    //接收到的数据);

 

 

2

状态确定

通过上面的分析可知,一共可以分为如下四个状态。I_START其中包括引导码和重复码,根据时间可以确定,下一个状态该跳转到那。

通过上面的分析可知,一共可以分为如下四个状态。I_START其中包括引导码和重复码,根据时间可以确定,下一个状态该跳转到那。

 

 

localparam  I_IDLE           =    'd0;    //空闲态localparam  I_START          =    'd1;    //开始态,也就是引导码阶段localparam  I_DATA           =    'd2;    //数据态localparam  I_END            =    'd3;    //结束态

 

 

3

状态机跳转

 

 

always@(*)begin  case(state)  I_IDLE:    if(infrared_negedge == 1'b1)      next_state <= I_START;    else      next_state <= I_IDLE;  I_START:    if(infrared_negedge == 1'b1)            if(time_cnt < Infrared_Time2_25ms)  //表示重复码,直接放回上一次的接收值        next_state <= I_END;      else        next_state <= I_DATA;    else      next_state <= I_START;  I_DATA:    if(infrecv_bit_cnt == 'd31 && infrared_negedge == 1'b1)      next_state <= I_END;    else      next_state <= I_DATA;  I_END:    if(infrared_posedge == 1'b1)      next_state <= I_IDLE;    else      next_state <= I_END;  default: next_state <= I_IDLE;  endcaseend

 

 

效果图如下。

编辑:黄飞

猜您喜欢

聚丙烯膜电容器是常见的电子元件。很多人问,的高度是从引脚处测量的吗?本文将探讨这个问题,并提供一些相关信息。电容器的基本知识电容器是储存电能的设备。由两个导体和...
2025-03-25 23:30:35


现代电力管理中,DC-DC控制器是一种重要的组件,通过优化电流转换与电压调整,提升各种电气设备的效率和稳定性。DC-DC控制器以其高度的可靠性和灵活性,成为家庭...
2024-11-02 00:00:00

贴片电阻2016,指的是尺寸为2.0mm长,1.6mm宽的矩形贴片电阻,是电子电路中不可或缺的基础元件。它体积小巧,却扮演着调节电流、分压、滤波等重要角色,广泛...
2024-11-26 11:29:21

电位器作为常见的无源元件,应用于调节电路电压、电流等参数。捷比信(Jebsen)作为知名电位器品牌,其产品性能稳定,深受市场欢迎。本文将围绕“捷比信电位器电流参...
2015-09-27 22:46:30

e96贴片电阻体积微小,如何快速准确地识别它们呢?本指南提供几种简单有效的方法,即使是新手也能轻松掌握。首先,观察电阻表面的三位数字标识。这三位数字并非直接代表...
2024-11-26 11:29:53

随着现代通信技术的发展,各种多址技术在日常生活中的应用正变得越来越广泛。所谓多址技术,是指许多用户同时使用同一频谱,采用不同的处理技术,使不同用户信号之间互不干...
2018-05-31 09:04:00

贴片电阻上的103可不是简单的数字,代表的是电阻的阻值。 103采用的是数字编码表示法,前两位数字10代表有效数字,第三位数字3代表10的幂次方。 因此,103...
2024-11-29 10:26:04

精密电阻作为关键的元器件,其性能直接影响整个系统的稳定性与精准度。奥斯特(OST)作为国内知名的电子元器件品牌,其精密电阻产品因高品质和很好性能受到关注。本文将...
2021-03-09 08:50:55

硅电容式压力传感器是现代技术重要组成部分。在工业、医疗等领域应用。本文将对此传感器进行详细介绍。定义硅电容式压力传感器是利用硅材料制作的传感器。通过测量压力造成...
2025-04-13 01:31:41