参考示例
根据测得的遥控器编码波形可知,433MHz接收端输出的信号中,电平维持时间有20ms、9ms、1.6ms、700us这几种。使用1.6ms高电平 + 700us低电平表示逻辑1,700us高电平 + 1.6ms低电平表示逻辑0,9ms高电平表示引导/起始码,700us高电平 + 20ms低电平表示结束码,同时也表示“重复码“”的起始。
程序设计中,对700us的电平进行检测并计数,要保证做够的容错能力,需要将定时器中断做到100us以下,甚至更小,显然使用定时器中断处理时不合理的。在本示例中,采用外部中断 + 定时器计数的方式进行电平长度采样。外部中断采用上升沿和下降沿触发,在中断中根据当前电平切换边沿触发方式。定时器使用系统时钟(16.6MHz)的64分频作为时钟源,具有足够的分辨率,可提高接收机的容错能力。
数据采样逻辑中,下降沿时判断当前高电平表示的逻辑值,上升沿是对上一步中产生的逻辑值进行确认,若逻辑值合法则对该逻辑值进行记录,若不合法,这舍弃该逻辑值,并初始化接收机,等待下一次数据。程序流程图如下:
|