蓝桥杯板子红外线使用,NEC协议

遥控器 是ht6121 接收器是TSOP1838

协议的讲解ppt里有点击打开链接

连线就是把N_B2连到P3^2

简单讲讲代码

#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit IRIN = P3^2;
uchar tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
uchar dspbuf[]={10,10,10,10,10,10,10,10};
#define delay1us {_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();}
uchar discom=0;

void IrInit();
void DelayMs(unsigned int );

void displaylcd()////////////////////实验室的开发板
{
    P2=(P2&0X1F)|0XE0;
	P0=0Xff;	   //消隐
	P2=(P2&0X1F);

	P2=(P2&0X1F)|0XC0;
    P0=(1<<discom);	   //位选   00000001
	P2=(P2&0X1F);

	P2=(P2&0X1F)|0XE0;
    P0=~tab[dspbuf[discom]]; 	   //段选 dspbuf[0]=1
	P2=(P2&0X1F);
	DelayMs(1);
	if(++discom==8)
	discom=0;
}

unsigned char IrValue[6];	  //用来存放读取到的红外值
unsigned char Time;

void main()
{
	IrInit();
	while(1)
	{
		IrValue[4]=IrValue[2]>>4;	 	 	//高位
		IrValue[5]=IrValue[2]&0x0f;		//低位
		dspbuf[0] = 0x00;
		dspbuf[1] =IrValue[4];
		dspbuf[2] =IrValue[5];
		dspbuf[3] = 0;	  //01110110
		dspbuf[4] = 0x00;
		dspbuf[5] = IrValue[4];
		dspbuf[6] = IrValue[5];
		dspbuf[7] = 0;

		displaylcd();
	}
}									 

void DelayMs(unsigned int a)   //0.14ms误差 0us
{
  uint i,j;
  for(j=0;j<a;j++)
  for(i=0;i<11;i++)
  {
	  delay1us  delay1us
	  delay1us  delay1us
	  delay1us  delay1us
	  delay1us  delay1us

  }
}

void IrInit()
{
	IT0=1;//下降沿触发
	EX0=1;//打开中断0允许
	EA=1;	//打开总中断

	IRIN=1;//初始化端口
}

void ReadIr() interrupt 0
{
	unsigned char j,k;
	unsigned int err;
	Time=0;
	DelayMs(70);

	if(IRIN==0)		//确认是否真的接收到正确的信号
	{	 

		err=200;				//1000*10us=10ms,超过说明接收到错误的信号
		/*当两个条件都为真是循环,如果有一个条件为假的时候跳出循环,免得程序出错的时
		侯,程序死在这里*/
		while((IRIN==0)&&(err>0))	//等待前面9ms的低电平过去
		{
			DelayMs(1);
			err--;
		}
		if(IRIN==1)			//如果正确等到9ms低电平
		{
			err=100;
			while((IRIN==1)&&(err>0))		 //等待4.5ms的起始高电平过去
			{
				DelayMs(1);
				err--;
			}
			for(k=0;k<4;k++)		//共有4组数据
			{
				for(j=0;j<8;j++)	//接收一组数据
				{

					err=60;
					while((IRIN==0)&&(err>0))//等待信号前面的560us低电平过去
					{
						DelayMs(1);
						err--;
					}
					err=500;
					while((IRIN==1)&&(err>0))	 //计算高电平的时间长度。
					{
						DelayMs(1);//0.14ms
						Time++;
						err--;
						if(Time>30)
						{
							EX0=1;
							return;
						}
					}
					IrValue[k]>>=1;	 //k表示第几组数据
					if(Time>=12)			//如果高电平出现大于565us,那么是1
					{
						IrValue[k]|=0x80;
					}
					Time=0;		//用完时间要重新赋值
				}
			}
		}
		if(IrValue[2]!=~IrValue[3])
		{
			return;
		}
	}
}  

主要有几个地方注意一下,我原先疑问应该在进入中断时关掉它免得后面的下降沿继续出发,但是我后来查了一下,如下
一个外部中断的请求标志只有一位,这个标志在遇到RETI时撤出,所以在进入中断到RETI前这段时间,中断请求标志不会随你的有效触发条件而变化。  
简而言之,在中断程序执行时下降沿不会再出发外部中断
再者就是延时,这个芯片也不能用烧录软件直接生成延时,我知道的最靠谱的办法就是用_nop_() 但是还有for在,所以具体时间还是不太准,有空再测一下 先这样吧
还有就是刚刚看别人的代码发现一个容易错的 姑且也在这说一下,就是这里移位放到读到1或0之前,放到之后的话就会多移一位,不小心有可能会错

时间: 2024-10-13 18:28:40

蓝桥杯板子红外线使用,NEC协议的相关文章

蓝桥杯板子 超声波模块使用

超声波测距离的原理非常简单,单片机的一个引脚连到发射模块  发出一定频率的信号,此时打开定时器开始计时,如果发射模块发出的声波被物体反射回来,就会在接收端            连出的一极产生下降沿,此时读取定时器时间   知道了来回时间和声速,就可以算出距离并显示出来. 这听起来非常简单明了,所以我在弄这个模块的时候也有点掉以轻心,直接一整份打完,下载调试,结果调试了好长时间... 在这里吸取一点教训,对于没用过的,不熟悉的东西,一定要打一点,测试一下,否则调试的时候,错误的可能性太多,不好找

蓝桥杯实例之开发板特点

本人之前参加了蓝桥杯,下面我将总结一下我的经历,由于本人技能有限,请多见谅! 我之前用过几种51的板子,说说蓝桥杯的板子: 首先开发板设置了三种芯片的插座,说实话,我估计设计者是出于性价比高的考虑,如果开发AVR.51或者8255的只要插上相应的芯片就行了,其他的都可以用.但是我认为这样设置占据了板子的很大面积,所以单片机开发板相比其他板子有点大(我个人认为的).如果当我们需要其他芯片时,可以接一个转换板不就行了.这样还能节省成本呢. 看一下原理图: 原理图中与其他板子相比,它运用了好多个锁存器

2015年蓝桥杯省赛B组C/C++(试题+答案)

首先说,这次我是第二次参加蓝桥杯(大学里最后一次),可这次去连个三等都没拿到,有些心灰意冷,比上一次还差, 当时看到成绩出来的时候有些失落,但是跌倒了,再站起来继续跑就可以了.可能是状态不好吧,纯属自我安慰. 接下来我把今年的题目又重新做了一遍,写下了这篇博客,如果也有需要探讨答案的,希望可以有帮助. 第一题: 第1题:统计不含4的数字 题目大意 统计10000至99999中,不包含4的数值个数. 解题分析: 第一种解法: 数学方法,这种是在网上看到的一种解法: 最高位除了0.4不能使用,其余8

NEC协议

注意: 用示波器在接收头抓的电平看起来和NEC协议刚好相反, 那是因为:HS0038B 这个红外一体化接收头,当收到有载波的信号的时候,会输出一个低电平,空闲的时候会输出高电平. 具体情况,具体分析. 1. 红外协议之NEC协议 http://www.linuxidc.com/Linux/2014-09/106408.htm NEC协议载波:38khz 其逻辑1与逻辑0的表示如图所示: 逻辑1为2.25ms,脉冲时间560us: 逻辑0为1.12ms,脉冲时间560us. 所以我们根据脉冲时间长

蓝桥杯——算法训练之乘积最大

问题描述 今年是国际数学联盟确定的"2000--世界数学年",又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得以参加.活动中,主持人给所有参加活动的选手出了这样一道题目: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大. 同时,为了帮助选手能够正确理解题意,主持人还举了如下的一个例子: 有一个数字串:312, 当N=3,K=1时

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh童鞋的提醒. 勘误2:第7题在推断连通的时候条件写错了,后两个if条件中是应该是<=12 落了一个等于号.正确答案应为116. 1.煤球数目 有一堆煤球.堆成三角棱锥形.详细: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形), 第四层10个(排列成三角形). -. 假设一共

蓝桥杯——判定字符的位置。

蓝桥杯——判断字符的位置 题目: 输入一个字符串,编写程序输出该字符串中元音字母的首次出现位置,如果没有元音字母输出0.英语元音字母只有‘a’.‘e’.‘i’.‘o’.‘u’五个. 样例输入: hello样例输出:2 样例输入: apple样例输出:1 样例输入: pmp样例输出:0 java code: import java.util.*;public class Yuanyingzifu {    public static int fun(String str)    {        

蓝桥杯 地宫取宝(12&#39;)

X 国王有一个地宫宝库.是n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大, 小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行 3个整数,用空格分开:n m

蓝桥杯-开心的金明

//蓝桥杯-算法训练 开心的金明 //评测结果 AC //动态规划 01背包 #include <cstdio> #include <algorithm> #include <cstring> using namespace std; const int maxn = 30005; int main() { int N, m; scanf( "%d%d", &N, &m ); int f[maxn]; int v, w; memset