遥控精灵。得先确定手机是否带红外线功能。
遥控精灵是由“天佳(上海)信息技术有限公司”开发的手机配件和应用程序的总称,最早版本由天佳于2012年3月发布。
应用程序安装在手机上后,所有红外设备都可以远程控制。将手机和平板电脑改造成通用红外遥控器,可控制电视、机顶盒、投影机、DVD、空调、单反、风扇、插座等所有35kHz至45khz范围内的红外设备和装置。
手机有自己的红外功能,可以直接下载,供遥控向导客户端使用,如果手机不支持红外但支持OTG功能,则可与遥控向导OTG附件配合使用,实现遥控。
扩展资料:
功能特点
1、它可以直接安装在支持红外功能的手机上。
2、如果手机没有红外功能但有OTG功能,则可以与遥控器导板的OTG附件一起使用。
3、应用程序附带了数万个遥控数据,其中大部分可以下载,并通过匹配遥控或搜索模式直接使用。
4、应用程序具有电视节目预览功能,可以预览当前节目信息和未来两天的节目预览。
5、app的机顶盒功能可以通过移动wifi接入家庭电视机顶盒,用户可以通过手机管理机顶盒应用。
参考资料来源:
百度百科-遥控精灵
给你一个我编的红外解码的程序,这个程序会将接收到的红外编码中的8位码通过串口发送到上位机,你可以通过串口调试助手来看看,程序是正确的,希望对你有参考价值。 ////////////////////////////////////////////////////////////////// //////////////////////////yorkWorldDream///////////////////////// ///////////////////////////////////////////////////////////////// #include"reg52.h" #define uchar unsigned char #define uint unsigned int //tc9012 uchar flag=0//是否接到起始位标志 未接到为0 接到为1 uchar traflag=0//翻译是否完成标记 完成为1 uchar rec[33]//接收遥控器发送的所有数据 用来记录两个下降沿之间的时间 uchar recok=0//是否接收完一帧数据标记 接收完为1 uchar sendok=0//是否发送完毕标记 发送完成为1 uchar num=0//变相记录时间 uchar n=0//rec[]中的数组定位 void timerinit()//定时器0初始化 void ruptinit()//外部中断0初始化 void tradata()//一帧数据的翻译 即把时间记录转换成0/1 void send()//把收到的数据发给上位机 void delay()//////////////////////////定时器 中断初始化///////////////////////////////// void timerinit()//定时器0 { TMOD=0x02//定时器0使用方式2 TH0=0x00 TL0=0x00 EA=1 ET0=1//定时器中断开 TR0=1//计时开 } void ruptinit()//外部中断0 { EA=1 EX0=1//外部中断开 IT0=1//下降沿触发 0是电平触发 } ////////////////////////////定时器 中断函数////////////////////////////// void timer() interrupt 1 //系统从0x00记到0xff 每记一次时间大概为1us 记256次 即256us中断一次 { num++//num记录的是256us的个数 总时间=num*256us } void rupt() interrupt 0 //外部中断0 当遇到下降沿时触发 { if(flag==1)//flag为1 说明收到了起始位 接下来要开始进行记录了 { if(num>32)//时间为32*256us=8.2ms是整个起始位的时间 { n=0 } rec[n]=num//记录两个下降沿之间的num值 这样也就相当于记录了其间的时间 num=0 n++ if(n==33)//因为前面是n++ 所以当n=33时 数组已经从0记到了32 已经记满了 { recok=1//标记 接收一帧数据完成 n=0 } } else//首次得到下降沿到达这里 使flag变1 用来说明收到了起始位 { flag=1 } } /////////////////////////////时间翻译函数/////////////////////////////////////// void tradata()//一帧数据的翻译 即把时间记录转换成0/1 { uchar i for(i=1i/0的数据时间是num=4.4 1的数据时间是num=8.8 { //记住要从rec[1]开始 因为rec[0]记录的是引导码的num值 if(rec[i]>6)//使用6做中间值 小于则为0 大于为1 用0/1替换rec中的数据 这样就进行了翻译 { rec[i]='1' }//因为要以字符串发送 所以这里用字符形式 else rec[i]='0' } traflag=1//翻译完成标记 } /////////////////////////////发送数据函数//////////////////////////////////// void send()//把收到的数据发送给上位机 具体细节不懂看串口通信 mcu to pc { uchar i TMOD=0x20 TH1=0xfd TL1=0xfd TR1=1 SM0=0 SM1=1 REN=1 for(i=25i/选择要发送出去的数据 这里是从25开始发送的 { SBUF=rec[i] while(!TI) TI=0 } sendok=1} //////////////////////////////////////////////////////////////////////// void delay()//1ms { unsigned char a,b,c for(c=1c>0c--) for(b=142b>0b--) for(a=2a>0a--)} void main() { timerinit()//定时器0初始化 ruptinit()//外部中断0初始化 while(1) { if(recok==1)//接收一帧数据完成 { P1=0xfe//灯亮一下 为了指示是否收到了数据 tradata()//翻译数据 } delay() if(traflag==1)//翻译完成 { send()//发送 } delay() if(sendok==1)//发送完成 { flag=0 traflag=0 recok=0 sendok=0 P1=0xff timerinit() ruptinit() } //全部恢复初始 }程序太长,须仔细研究。
#define main_GLOBALS#include <reg51.h>
#include "main.h"
#include "SAA3010.h"
unsigned char counter
unsigned char temp
sbit P2_0 = 0xA0
sbit P2_1 = 0xA1
sbit P2_2 = 0xA2
sbit P2_3 = 0xA3
void decode_init(void)
{
load_code_detected=0
repeat_code_detected=0
decode_error=0
temp1=0
temp2=0
temp3=0
temp4=0
TH1=0
TL1=0
TR1=0
}
void main(void)
{
EX0=1
IT0=1
TMOD=0x11
ET0=1
TH0=128
TL0=0
TR0=1
P0=0
TH1=0
TL1=0
decode_init()
EA=1
counter=0
data_available=0
while(1)
{
if(data_available==1)
{
if (key_code==01) //display "1"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0xf9
}
if (key_code==0x02) //display "2"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0xa4
}
if (key_code==0x03) //display "3"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0xb0
}
if (key_code==0x04) //display "4"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0x99
}
if (key_code==0x05) //display "5"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0x92
}
if (key_code==0x06) //display "6"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0x82
}
if (key_code==0x07) //display "7"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0xf8
}
if (key_code==0x08) //display "8"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0x80
}
if (key_code==0x09) //display "9"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0x90
}
if (key_code==0x00) //display "0"
{
P2_0=0 //选中四个数码管
P2_1=0
P2_2=0
P2_3=0
P0=0xc0
}
data_available=0
}
}
}
//**********************************************************************************************************************
void key_isr(void) interrupt 0
{
EX0=0 // 立即关闭外部中断,转为查询方式解码
led=0 // 开LED表示收到红外信号
temp=SAA3010_decode() // 解码
if(temp==1) goto key_isr_exit
counter=0
key_isr_exit:
decode_init()
led=1
EX0=1
}
void Timer0_isr(void) interrupt 1
{
counter++
if(counter>3)
{
if(led==0) led=1
counter=0
}
ET0=1
}
#define SAA3010_GLOBALS
#include <reg51.h>
#include "SAA3010.h"
#include "main.h"
//===========================================================================================================
// 该函数的作用是每调用一次就在temp1-4组成的32bit长度的最低位上移入
// 一个0或者1,数据由bitdata确定
void SAA3010_cycle_data(unsigned char bitdata)
{
temp4=temp4<<1
if((temp3&0x80)==1) temp4=temp4|0x01
else temp4=temp4&0xfe
temp3=temp3<<1
if((temp2&0x80)==1) temp3=temp3|0x01
else temp3=temp3&0xfe
temp2=temp2<<1
if((temp1&0x80)==1) temp2=temp2|0x01
else temp2=temp2&0xfe
temp1=temp1<<1
if(bitdata==1) temp1=temp1|0x01
else temp1=temp1&0xfe
}
//===========================================================================================================
// 解码出错返回1,对则返回0
unsigned char SAA3010_decode(void)
{
//-----------------------------------------------------------------------------------------------------------
unsigned char count=0
TR1=1 // 启动计时
while(1)
{
while(ir_receive==0) // 等待电平变高,不需要超时监测
TR1=0 // 高电平(对发射电路而言)测试结束
high_level_time=TH1*256+TL1 // 记录高电平的数据
//-----------------------------------------------------------------------------------------------------------
TH1=0 TL1=0 TR1=1 // 启动对低电平的测试
//-----------------------------------------------------------------------------------------------------------
// 处理低电平
if((high_level_time<750)||(high_level_time>1800)) return 1 // 不是合格的电平
if((high_level_time>750)&&(high_level_time<1000)){SAA3010_cycle_data(0)count+=1} // 移入一个0
if((high_level_time>1500)&&(high_level_time<1800)) {SAA3010_cycle_data(0)SAA3010_cycle_data(0)count+=2} // 移入两个0
while(ir_receive==1) // 等待电平变低
{
if(TH1>0x08) break // 高电平超时,正常情况下是测试结束,异常时则是出错
}
TR1=0 // 低电平(对发射电路而言)测试结束
if(TH1>0x08) {break}
low_level_time=TH1*256+TL1 // 保存低电平的数据
TH1=0 TL1=0 TR1=1 // 为增加计时的准确性,数据的处理都是在计时过程里
//-----------------------------------------------------------------------------------------------------------
// 处理高电平
if((low_level_time<750)||(low_level_time>1800)) return 1 // 不是合格的电平
if((low_level_time>750)&&(low_level_time<1000)) {SAA3010_cycle_data(1) count+=1} // 移入一个0
if((low_level_time>1500)&&(low_level_time<1800)) {SAA3010_cycle_data(1) SAA3010_cycle_data(1)count+=2} // 移入两个0
}
if(count==26) {SAA3010_cycle_data(1) count++}
if(count!=27) return 1
led=0
// 提取按健信息
key_code=0
if((temp1>>1)&0x01) key_code=key_code|0x01
else key_code=key_code&0xfe
if((temp1>>3)&0x01) key_code=key_code|0x02
else key_code=key_code&0xfd
if((temp1>>5)&0x01) key_code=key_code|0x04
else key_code=key_code&0xfb
if((temp1>>7)&0x01) key_code=key_code|0x08
else key_code=key_code&0xf7
if((temp2>>1)&0x01) key_code=key_code|0x10
else key_code=key_code&0xef
if((temp2>>3)&0x01) key_code=key_code|0x20
else key_code=key_code&0xdf
// 提取系统信息
sys_code=0
if((temp2>>5)&0x01) sys_code=sys_code|0x01
else sys_code=sys_code&0xfe
if((temp2>>7)&0x01) sys_code=sys_code|0x02
else sys_code=sys_code&0xfd
if((temp3>>1)&0x01) sys_code=sys_code|0x04
else sys_code=sys_code&0xfb
if((temp3>>3)&0x01) sys_code=sys_code|0x08
else sys_code=sys_code&0xf7
if((temp3>>5)&0x01) sys_code=sys_code|0x10
else sys_code=sys_code&0xef
if((temp3>>7)&0x01) sys_code=sys_code|0x20
else sys_code=sys_code&0xdf
data_available=1
return 0
}
//===========================================================================================================
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)