红外遥控小车程序
红外循迹小车程序设计
智能电子制作实验室像头则更有优势。
这一章将通过设计一个基于红外传感器的循迹小车,让大家初步了解机器人导航行走的原理。
红外循迹小车程序设计主要内容智能电子制作实验室1、总体功能及原理智能电子制作实验室2、LM393红外传感器模块简介智能电子制作实验室智能电子制作实验室接收管电源指示灯信号指示灯+5V GND注意:此操作建议次数不要太多次,否者会造成红外对管针脚断断裂,建议多买几个,也可单独购买循迹模块(默认90度焊接)和避障模块(默认平直焊接)1)引脚说明智能电子制作实验室接收管电源指示灯+5V GND信号输出1)引脚说明智能电子制作实验室2) 检测原理检测原理为当发射管照射在黑白分明的路面智能电子制作实验室黑白路面检测原理智能电子制作实验室3) 原理图说明与编程须知方有障碍物),out输出低电平0,指示灯亮;当照在黑色路面(避障时为前方无障碍物),out输出高电平1,指示灯不亮智能电子制作实验室智能电子制作实验室手把手教你做智能车与机器人4)红外传感器的安装与调试(1)传感器安装:面的高度允许有一定的范围,后面程序中两驱是离地面1mm ,四驱是3mm 左右.如果是其它距离,其调试的方法与第2步”传感器调试”20mm空心铜柱(2)传感器调试:滑动变阻器信号指示灯黑白三对智能电子制作实验室循迹小车各模块接线方法智能电子制作实验室3、两驱万向轮小车接线方法智能电子制作实验室两驱万向轮小车接线说明:相连,见下图.智能电子制作实验室电池线万向轮小车、电池、驱动与电智能电子制作实验室GNDGNDVCC P11P10驱动模块与单片机接线方法智能电子制作实验室智能电子制作实验室传感器与单片机接线方法对传感器的OUT脚分别与单片机P34 P35 的相连.4、两驱万向轮小车程序及现象演示智能电子制作实验室5、四驱小车接线方法智能电子制作实验室四驱小车接线说明:智能电子制作实验室电池线四轮小车后轮电池、驱动与电机智能电子制作实验室两个驱动模块VDDGND对四驱小车前轮接线方法(注意此智能电子制作实验室GNDGNDVCC P11P10上部驱动模块与单片机接线方法智能电子制作实验室GNDP11P10下部驱动模块与单片机接线方法智能电子制作实验室智能电子制作实验室传感器与单片机接线方法对传感器的OUT脚分别与单片机P34 P35 的相连.6、四驱小车程序及现象演示智能电子制作实验室智能电子制作实验室舵机转向小车两驱万向轮小车分离设计两种车型任意组合7、如何利用舵机转向小车进行此实验舵机转向小车请利用我们赠送的万向轮改装成为万向轮。
嵌入式课程设计--红外遥控小车程序
#include <reg52.h>#include <intrins.h>#define uchar unsigned char#define uint unsigned intsbit IRIN = P3^3;sbit P1_0=P1^0; //数码管动态扫描接口sbit P1_1=P1^1;sbit P1_5=P1^5; //蜂鸣器报警接口sbit P2_0=P2^0; //控制两个直流电机的控制端口sbit P2_1=P2^1;sbit P2_2=P2^2;sbit P2_3=P2^3;sbit P2_4=P2^4;sbit P2_5=P2^5;bit flag; //红外解码判断标志位,0有效uchar IR_buf[4]={0x00,0x00,0x00,0x00};//IR_buf[0]、IR_buf[1]为用户码低位、用户码高位接收缓冲区// IR_buf[2]、IR_buf[3]为键数据码和键数据码反码接收缓冲区uchar disp_buf[4]={0x00,0x00,0x40,0x00}; //显示缓冲单元ucharseg_data[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x 8e};//0~F符的显示码(字形码)void delay(uchar x); //延时函数void Delay_ms(uint xms); //延时void init();void car_forward(); //小车前进函数void car_back(); //小车后退函数void car_Leftturn(); //小车左转弯函数void car_Rightturn(); //小车右转弯函数void car_stop(); //小车停止函数void Display(uint m); //数码管显示函数void aralm();void car_jiaspeed();void car_jianspeed();/********以下是主函数********/void main(){init();while(1){Display(disp_buf[2]);switch(disp_buf[2]){case 0x46: car_forward();break;case 0x15: car_back();break;case 0x44: car_Leftturn();break;case 0x43: car_Rightturn();break;case 0x40: car_stop();break;case 0x47:car_jiaspeed();break;case 0x45:car_jianspeed();break;default: aralm();break;}}}void init(){EA=1;EX1=1; //允许总中断中断,使能INT1 外部中断IT1 = 1; //触发方式为脉冲负边沿触发IRIN=1; //遥控输入脚置1P2_0=0;P2_1=0;P2_2=0;P2_3=0;P2_4=1;P2_5=1;}void car_jiaspeed(){P2_4=1;P2_5=1;}void car_jianspeed(){while(1){P2_4=1;P2_5=0;Delay_ms(200);P2_4=0;P2_5=1;Delay_ms(200);if(disp_buf[2]!=0x45){break;}}}/********以下是0.14ms的x倍延时函数********/void delay(uchar x) //延时x*0.14ms{uchar i;while(x--)for (i = 0; i<13; i++);}/********以下是延时函数********/void Delay_ms(uint xms){uint i,j;for(i=xms;i>0;i--) //i=xms即延时约xms毫秒for(j=110;j>0;j--);}/********以下是显示函数********/void Display(uint m){uint a,b;a=m;b=m;a=a>>4;b=b&0x0f;P1_0=0;P1_1=1;P0=seg_data[a];Delay_ms(5);P1_0=1;P1_1=0;P0=seg_data[b];Delay_ms(5);}void car_forward() {P2_4=1;P2_5=1;P2_0=1;P2_1=0;P2_2=1;P2_3=0;}void car_back() {P2_4=1;P2_5=1;P2_0=0;P2_1=1;P2_2=0;P2_3=1;}void car_Leftturn() {P2_0=1;P2_1=0;P2_2=0;P2_3=0;}void car_Rightturn(){P2_0=0;P2_1=0;P2_2=1;P2_3=0;}void car_stop(){P2_0=0;P2_1=0;P2_2=0;P2_3=0;}void aralm(){P1_5=0;Delay_ms(500);P1_5=1;Delay_ms(500);}/********以下是外中断1函数********/void IR_decode() interrupt 2{uchar i,j,k,count=0;EX1 = 0; //暂时关闭外中断1中断请求delay(20); //延时20*0.14=2.8msif (IRIN==1) //等待IRIN低电平出现{EX1 =1; //开外中断0return; //中断返回}while (!IRIN) delay(1); //等待IRIN变为高电平,跳过9ms的低电平引导码for (j=0;j<4;j++) //收集四组数据,即用户码低位、用户码高位、键值数据码和键值数码反码{for (k=0;k<8;k++) //每组数据有8位{while (IRIN) //等待IRIN变为低电平,跳过4.5ms的高电平引导码信号。
基于msp430g2553的红外遥控小车解码控制程序
基于msp430g2553的红外遥控小车解码控制程序//遥控小车最终程序#include#define CPU_F ((double)12000000)//数字控制震荡器1MHZ#define delay_us(x) __delay_cycles((long)(CPU_F*(double)x/12000000.0))//延时X微秒#define delay_ms(x) __delay_cycles((long)(CPU_F*(double)x/12000.0))//延时X毫秒char const redled[8]={0x07,0x00,0x01,0x02,0x03,0x04,0x05,0x06};//led测试版对应的八个灯unsigned char receive[2]={0x00,0x00};//数据码,数据反码unsigned char j=0,k=0,f=0,led=0;//中断次数,receive的元素,,找到按键地址数组的第f个元素int flag=1;//***************************主程序********************//void main(void){WDTCTL=WDTPW+WDTHOLD; //关闭看门狗BCSCTL1=CALBC1_1MHZ; //这两句的作用,基本时钟系统控制,数控震荡控制,将时钟校准1MHZDCOCTL=CALDCO_1MHZ;P1DIR|=BIT0+BIT6+BIT2+BIT3+BIT4;//P1端口的P1.0、P1.6设置为输出方向P2DIR|=0x0f; //P2的0,1,2,3设置为输出口P1OUT|=BIT0+BIT6; //P1.0、P1.6输出高电平,次单片机的VCC为3.56VP1IE|=0X02; //P1.1中断使能P1IES|=BIT1; //P1.1中断边沿选择,下降沿触发P1IFG=0; //清P1.1中断标志_BIS_SR(GIE); //开总中断while(1) //{if(receive[0]==0xa2){flag=1;}if(receive[0]==0xe2){flag=-1;}if(flag==1) //正转P1.0{P1OUT&=~BIT3;P1OUT&=~BIT4;switch(receive[0]){case 0x68:{P1OUT&=~BIT0;P1OUT&=~BIT2;break;} //0键case0x30:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(1);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(9);}break;}//1键case0x18:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(2);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(8);}break;}//2键case0x7a:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(3);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(7);}break;}//3键case0x10:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(4);P1OUT&=~BIT0;P1OUT&=~BIT2;delay_m s(6);}break;}//4键case0x38:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(5);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(5);}break;}//5键case0x5a:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(6);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(4);}break;}//6键case0x42:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(7);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(3);}break;}//7键case0x4a:{{P1OUT|=BIT0;P1OUT|=BIT2;delay_ms(8);P1OUT&=~B IT0;P1OUT&=~BIT2;delay_m s(2);}break;}//8键case 0x52:{P1OUT|=BIT0;P1OUT|=BIT2;break;} //9键}}else if(flag==-1) //反转P1.2{P1OUT&=~BIT0;P1OUT&=~BIT2;switch(receive[0]){case 0x68:{P1OUT&=~BIT3;P1OUT&=~BIT4;break;} //0键case0x30:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(1);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(9);}break;}//1键case0x18:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(2);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(8);}break;}//2键case0x7a:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(3);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(7);}break;}//3键case0x10:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(4);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(6);}break;}//4键case0x38:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(5);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(5);}break;}//5键case0x5a:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(6);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(4);}break;}//6键case0x42:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(7);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(3);}break;}//7键case0x4a:{{P1OUT|=BIT3;P1OUT|=BIT4;delay_ms(8);P1OUT&=~B IT3;P1OUT&=~BIT4;delay_m s(2);}break;}//8键case 0x52:{P1OUT|=BIT3;P1OUT|=BIT4;break;} //9键}}}}//*********************红外遥控器中断程序*******************//#pragma vector=PORT1_VECTOR //中断程序的格式:#pragma vector=中断矢量__interrupt void port1(void)//格式:__interrupt void 函数名(void){P1IFG=0X00; //清P1中断标志int count=0; //高电平持续时间计数值while(!(P1IN&BIT1)); //等电平变为高电平while(P1IN&BIT1) //计算高电平持续时间{count++;if(count>8000)return;//如果高电平持续时间过长则推出中断程序}if(j>16) //一体化红外接收头一接收遥控器信号,就会输出32位的脉冲序列波,其中后16位{ //决定遥控器的按键地址,16位由8位数据码和数据反码组成,我们需要将其解码//time[j-17]=count; //将记得的高电平持续时间放入时间数组中if(j==25)k++; //到数据反码的起始位的时候,我让receive数组元素下标+1receive[k]<<=1; //接收数据码左移一位,比如:xxxx xxxx 左移一位后xxxx xxx0if(count>80)receive[k]|=0x01;//高电平持续时间超过80,则将左移一位后的最低位变1,} //结果变为,xxxx xxx1,如果没超过80则保持不变,xxxx xxx0 j++;if(j>32){j=0;k=0; //解码结束,j,k值清零delay_ms(150);}}。
自动避障红外电动小车C51程序
#define Busy 0x80 //用于检测LCD状态字中的Busy标识
sbit c=P1^2; //转向灯使能端
uchar code talk1[]={"backward"};
uchar code talk2[]={"forward"};
uchar code talk3[]={"Turnleft"};
****************************/
void infrared_ray()interrupt 0 using 3
{ uchar i=90;
flage=0x01; //接受标志位
while(i--); //减小灵敏度
EX0=0; //关掉中断,等到发射方波后才开启,处于别动
}
//延时子程序
LCD_Data = WCLCD;
LCD_RS= 0;
LCD_RW= 0;
LCD_E = 0; //延时,为了安全
LCD_E = 0;
LCD_E = 0; //延时
LCD_E = 1;
}
void LCDInit(void) //LCD初始化
{
Delay400Ms();
LCD_Data = 0;
WriteCommandLCD(0x38,0); //三次显示模式设置,不检测忙信号
//右边有障碍物,左转
else if(temp==0x02) {control(2,dj_state3,right_light ); temp =0x00;}
//两个方向都有障碍物,后退,右转
else if(temp==0x03) {control(10,dj_state4,back_light );
红外遥控小车程序
附录一程序代码红外遥控编码程序#include<reg51.h>#define uchar unsigned char#define uint unsigned int#define uintlong unsigned longsbit p3_0=P3^0;sbit p2_1=P2^1;sbit p1_0=P1^0;sbit p1_1=P1^1;sbit p1_2=P1^2;sbit p1_3=P1^3;bit out;uint keyvalue=0x00,flag_key=0,value1,value2,keycount=0,i,j,flag_set=0, flag_press=0;uchar code keycode[4]={0x7f,0xbf,0xdf,0xef};uchar codeportvalue[12]={0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x00, 0x0b};uchar code wy[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//**********红外发送部分**********//uchar user1=0x00,user2=0x00;uint count=0,endcount=0;uint irdata=0;void deltime(void);void key_scan(void);void sendirdata(void);main(void){EA = 1;TMOD = 0x11;ET0 = 1;p3_0=1;P1=0xff;TH0 = 0xFF;TL0 = 0xE4;TR0 = 0;while(1){key_scan();if(flag_press==1){flag_press=0;TR0=1;sendirdata();}}}//**********按键扫描***********// void key_scan(void){for(i=0;i<=3;i++){P1=keycode[i];if(p1_3==0){keycount=i*3+0;flag_key=1; break;}if(p1_2==0){keycount=i*3+1;flag_key=1;break;}if(p1_1==0){keycount=i*3+2;flag_key=1;break;}}if(flag_key==1){flag_key=0;value1=P1;deltime();value2=P1;if(value1==value2){keyvalue=portvalue[keycount];flag_set=1;flag_press=1;}while(flag_set){value2=P1;if(value1!=value2)flag_set=0;}}}//**********延时**********//void deltime(void){uint k;for(k=0;k<=20;k++){ }}//**********定时中断**********// void time0int(void) interrupt 1{TH0=0xFF;TL0=0xE4;count++;}//**********发送数据**********// void sendirdata(){uchar s=0,datapd=0;endcount=320;p3_0=0;count=0;do{}while(count<endcount); endcount=180;count=0;p3_0=1;do{}while(count<endcount);for(s=0;s<=11;s++){endcount=20;count=0;p3_0=0;do{}while(count<endcount);endcount=20;count=0;p3_0=1;do{}while(count<endcount);}irdata=keyvalue;for(s=0;s<=7;s++){datapd=irdata & wy[s];if (datapd==0){endcount=20;count=0;} else{endcount=60;count=0;} p3_0=0;do{}while(count<endcount);endcount=20;count=0;p3_0=1;do{}while(count<endcount);}irdata=keyvalue;for(s=0;s<=7;s++){datapd=irdata & wy[s];if (datapd==0){endcount=60;count=0;} else{endcount=20;count=0;}p3_0=0;do{}while(count<endcount);endcount=20;count=0;p3_0=1;do{}while(count<endcount);}TR0=0;}红外遥控解码及驱动程序COUNT EQU 30HFLAG_USER1 EQU 45HFLAG_USER2 EQU 46HSA VEDATA EQU 47HCS1 EQU P3.0CS2 EQU P3.1RS EQU P3.3RW EQU P3.4E EQU P3.5PAGES EQU 56HCOLUMN EQU 57HNUM EQU 58HORG 0000HLJMP MAINORG 0003HLJMP EXTER0INTORG 000BHLJMP TIMER0INTORG 1000HMAIN:MOV P1,#0C5HSETB P3.6SETB P3.7MOV TMOD,#01H ;中断初始化MOV TH0,#0FFHMOV TL0,#9CHSETB EASETB IT0SETB ET0SETB EX0MOV R0,52H ;数据接收初始化MOV 52H,#00HMOV 53H,#00HMOV 54H,#00HMOV 55H,#00HMOV 51H,#00HMOV COUNT,#00HMOV R1,#08HMOV R2,#02HCLR PSW.5 ;数据接收标志CLR PSW.1 ;数据处理标志MOV FLAG_USER1,#00HLCALL CLEARMOV DPTR,#TAB0 ;显示初始化MOV PAGES,#1MOV COLUMN,#0LCALL LCD_DISPMOV DPTR,#TAB2MOV PAGES,#1MOV COLUMN,#16LCALL LCD_DISPMOV DPTR,#TAB1MOV PAGES,#1MOV COLUMN,#32LCALL LCD_DISPMOV DPTR,#TAB3MOV PAGES,#1MOV COLUMN,#48LCALL LCD_DISPMOV DPTR,#TAB4MOV PAGES,#1MOV COLUMN,#64LCALL LCD_DISPMOV DPTR,#TAB5MOV PAGES,#1MOV COLUMN,#80 ;显示红外遥控模式LCALL LCD_DISPMOV DPTR,#TAB6MOV PAGES,#3MOV COLUMN,#0LCALL LCD_DISPMOV DPTR,#TAB7MOV PAGES,#3MOV COLUMN,#16LCALL LCD_DISPMOV DPTR,#TAB8MOV PAGES,#3MOV COLUMN,#32LCALL LCD_DISPMOV DPTR,#TAB10MOV PAGES,#3MOV COLUMN,#64LCALL LCD_DISPMOV DPTR,#TAB9MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISP ;显示状态:初始LOOP: ;是否进行数据处理JNB PSW.1,$LCALL DATACHULICLR PSW.1MOV A,SA VEDATALCALL DATASHOWENDLOOP:LJMP LOOPEXTER0INT: ;外部中断SETB TR0MOV 30H,#00HRETITIMER0INT: ;定时中断,数据的验证和接收.MOV TH0,#0FFHMOV TL0,#9CHINC 30HSETB P3.2MOV C,P3.2JB PSW.5,DATARECEIVEPDJNC ENDTIMER0INTMOV A,30HCLR CSUBB A,#90JC ENDTIMER0INTSETB PSW.5CLR TR0MOV R1,#08HMOV 51H,#00HMOV R0,#52HMOV R2,#04H ;共接受两组数据LJMP ENDTIMER0INTDATARECEIVEPD: ;数据接收判断JNC ENDTIMER0INTCLR TR0MOV A,30HCLR TR0SUBB A,#10JC ORECEIVESETB CMOV A,51HRRC AMOV 51H,ALJMP WENDPDORECEIVE:CLR CMOV A,51HRRC AMOV 51H,AWENDPD:DJNZ R1,ENDTIMER0INT ;重复两次接收,确保存储.MOV R1,#08HMOV @R0,51HMOV @R0,51HINC R0MOV 51H,#00HDJNZ R2,ENDTIMER0INTCLR PSW.5SETB PSW.1SETB P0.0ENDTIMER0INT: ;定时中断结束RETIDATACHULI: ;数据处理MOV A,52HCLR CSUBB A,FLAG_USER1JNZ ENDDATACHULIMOV A,54HANL A,55HJNZ ENDDATACHULIMOV A,54HMOV SA VEDATA,AMOV 52H,#00HMOV 53H,#00HMOV 54H,#00HMOV 55H,#00HENDDATACHULI: ;处理完成,返回主程序RETDATASHOW: ;判断接收信号,进行相应处理CJNE A,#00H,CON1LJMP AOTO ;状态判断CON1:CJNE A,#02H,CON2MOV P1,#0FAHMOV DPTR,#TAB11MOV PAGES,#3LJMP ENDDATASHOW ;后转并显示CON2:CJNE A,#04H,CON3MOV P1,#0E5HMOV DPTR,#TAB12MOV PAGES,#3LJMP ENDDATASHOW ;左转并显示CON3:CJNE A,#05H,CON4MOV P1,#0C5HMOV DPTR,#TAB13MOV PAGES,#3LJMP ENDDATASHOW ;停转并显示CON4:CJNE A,#06H,CON5MOV P1,#0D5HMOV DPTR,#TAB14MOV PAGES,#3LJMP ENDDATASHOW ;右转并显示CON5:CJNE A,#08H,CON6MOV P1,#0F5HMOV DPTR,#TAB15MOV PAGES,#3LJMP ENDDATASHOW ;前转并显示CON6:JMP ENDDATASHOW1ENDDATASHOW:MOV COLUMN,#48LCALL LCD_DISPMOV DPTR,#TAB16MOV PAGES,#3MOV COLUMN,#64LCALL LcD_DISPENDDATASHOW1:RETAOTO:MOV P1,#0C0H ;寻迹壁障程序MOV DPTR,#TAB17MOV PAGES,#1MOV COLUMN,#0LCALL LCD_DISPMOV DPTR,#TAB18MOV PAGES,#1MOV COLUMN,#16LCALL LCD_DISPMOV DPTR,#TAB19MOV PAGES,#1MOV COLUMN,#32LCALL LCD_DISPMOV DPTR,#TAB20MOV PAGES,#1MOV COLUMN,#48LCALL LCD_DISP ;显示寻迹避障MOV DPTR,#TAB10MOV PAGES,#3MOV COLUMN,#64LCALL LCD_DISPMOV DPTR,#TAB9MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISP ;显示初始LCALL DLY ;模式工作前等待3秒AOTO1: ;自动寻迹避障程序MOV DPTR,#TAB15MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISPMOV DPTR,#TAB16MOV PAGES,#3MOV COLUMN,#64LCALL LCD_DISP ;显示前转MOV P1,#0F5HJNB PSW.5,AOTO2 ;检测红外信号LCALL CLEARMOV P1,#0C5HLCALL DLY1LJMP MAINAOTO2:JNB P1.6,ZZ ;状态判断JNB P1.7,YZJNB P3.6,HTJNB P3.7,HTSJMP AOTO1ZZ:MOV P1,#0E5H ;右寻迹灯亮MOV DPTR,#TAB12MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISPLCALL DLYSJMP DDYZ:MOV P1, #0D5H ;左寻迹灯亮MOV DPTR,#TAB14MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISPLCALL DLYHT:MOV P1,#0FAH ;发现障碍物MOV DPTR,#TAB11MOV PAGES,#3MOV COLUMN,#48LCALL LCD_DISPLCALL DLYSJMP ZZDD:LJMP AOTO1DL Y:MOV R7,#0BDH ;3秒延时DL1:MOV R6,#0E6HDL0:MOV R5,#21HDJNZ R5,$DJNZ R6,DL0DJNZ R7,DL1RETDLY1:MOV R7,#0A7H ;1秒延时DL3:MOV R6,#0ABHDL2:MOV R5,#10HDJNZ R5,$DJNZ R6,DL2DJNZ R7,DL3NOPRETCLEAR: MOV R4,#00H ;清屏程序CLEAR1:MOV A ,R4ORL A,#0B8HLCALL WCL0LCALL WCR0MOV B,#40HLCALL WCL0LCALL WCR0MOV R3,#40HCLEAR2:MOV B,#00HLCALL WCL1LCALL WCR1DJNZ R3,CLEAR2INC R4CJNE R4, #08H, CLEAR1RETLCD_DISP: ;汉字显示程序MOV R1,#02HMOV R0,#00HMOV NUM,#10HDISP: MOV R4,NUMDISPWORD:MOV A,COLUMNCLR CSUBB A,#63JNC YXPMOV A,COLUMNORL A,#40HMOV B,ALCALL WCL0ORL A,#0B8HMOV B,ALCALL WCL0 DISPDATA1:INC COLUMNMOV A,R0MOVC A,@A+DPTRMOV B,ALCALL WCL1LJMP NEXTDISPYXP:MOV A,COLUMNCLR CSUBB A,#64ORL A,#40HMOV B,ALCALL WCR0MOV A,PAGESORL A,#0B8HMOV B,ALCALL WCR0 DISPDATA2:INC COLUMNMOV A,R0MOVC A,@A+DPTRMOV B,ALCALL WCR1 NEXTDISP:INC R0DJNZ R4,DISPWORDCLR CSUBB A,#10HMOV COLUMN, AINC PAGESDJNZ R1,DISPRETWCL0: CLR CS1SETB CS2CLR RSSETB RWWCL00: MOV P2,#0FFHSETB EMOV A,P2CLR EJB ACC.7,WCL00CLR RWMOV P2, BSETB ENOPCLR ERETWCL1: CLR CS1SETB CS2CLR RSSETB RWWCL11: MOV P2,#0FFHSETB EMOV A,P2CLR EJB ACC.7,WCL11CLR RWSETB RSMOV P2, BSETB ECLR ERETWCR0: SETB CS1CLR CS2CLR RSSETB RWWCR00: MOV P2,#0FFHSETB EMOV A,P2CLR EJB ACC.7,WCR00CLR RWMOV P2, BSETB ECLR ERETWCR1: SETB CS1CLR CS2CLR RSSETB RWWCR11: MOV P2,#0FFHSETB EMOV A,P2CLR EJB ACC.7,WCR11CLR RWSETB RSMOV P2, BSETB ECLR ERETTAB0:DB20H,30H,0ACH,63H,20H,10H,04H,04H,04H,04H,0FCH,04H,06H,04H,00H,00H,22H,67H,22H,12H,12H,52H,40H,40H,40H,40H,7FH,40H,40H,60H,40H,00H ; 红TAB1:DB40H,42H,44H,0CCH,00H,42H,36H,2AH,22H,0FEH,21H,29H,25H,80H,00H,00H,00H,40H,20H,1FH,21H,41H,5DH,49H,49H,4FH,49H,49H,5DH,61H,21H,00H ; 外TAB2:DB00H,80H,0E0H,18H,17H,10H,90H,70H,00H,0FFH,20H,40H,80H,00H,00H,00H,01H,40H,20H,11H,0AH,04H,03H,00H,00H,0FFH,00H,00H,00H,01H,03H,00H ; 遥TAB3:DB10H,10H,10H,0FFH,90H,50H,0CH,44H,24H,15H,06H,14H,24H,54H,0CH,00H,02H,42H,81H,7FH,00H,40H,42H,42H,42H,42H,7EH,42H,43H,62H,40H,00H ; 控TAB4:DB10H,10H,0D0H,0FFH,94H,14H,0E4H,0BFH,0A4H,0A4H,0A4H,0BFH,0F4H,26H,04H,00H,04H,03H,00H,0FFH,08H,89H,8BH,4AH,2AH,1EH,2AH,2AH,4BH,0C8H,48H,00H ; 模TAB5:DB10H,10H,90H,90H,90H,90H,90H,10H,0FFH,10H,12H,14H,10H,18H,10H,00H,00H,20H,60H,20H,1FH,10H,10H,08H,01H,06H,18H,20H,40H,80H,70H,00H ; 式TAB6:DB00H,08H,30H,00H,0FFH,20H,20H,20H,20H,0FFH,20H,22H,24H,30H,20H,00H,08H,0CH,02H,01H,0FFH,40H,20H,1CH,03H,00H,03H,0CH,30H,60H,20H,00H; 状TAB7:DB04H,04H,84H,84H,44H,24H,54H,8FH,14H,24H,44H,44H,84H,86H,84H,00H,01H,21H,1CH,00H,3CH,40H,42H,4CH,40H,40H,70H,04H,08H,31H,00H,00H;态TAB8:DB000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,036H,036H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H,000H ;:TAB9:DB10H,10H,91H,0D6H,30H,98H,00H,08H,08H,0F8H,08H,08H,08H,0FCH,08H,00H,02H,01H,00H,0FFH,01H,82H,40H,20H,18H,07H,40H,80H,40H,3FH,00H,00H ; 初TAB10:DB10H,10H,0F0H,1FH,10H,0F0H,40H,60H,58H,47H,40H,40H,50H,60H,0C0H,00H,40H,22H,15H,08H,16H,61H,00H,0FEH,42H,42H,42H,42H,42H,0FFH,02H,00H;始TAB11:DB00H,00H,0FCH,24H,24H,24H,24H,24H,24H,22H,22H,23H,0A2H,30H,20H,00H,40H,30H,0FH,00H,00H,0FFH,41H,41H,41H,41H,41H,41H,0FFH,01H,00H,00H;后TAB12:DB08H,08H,08H,08H,88H,78H,0FH,08H,08H,08H,08H,88H,0CH,08H,00H,00H,20H,50H,48H,46H,41H,41H,41H,41H,7FH,41H,41H,41H,41H,60H,40H,00H;左TAB13:DB40H,20H,0F8H,07H,00H,04H,74H,54H,55H,56H,54H,54H,76H,04H,00H,00H,00H,00H,0FFH,04H,03H,01H,05H,45H,85H,7DH,05H,05H,01H,05H,03H,00H ;停TAB14:DB08H,08H,08H,08H,0C8H,38H,0FH,08H,08H,08H,08H,08H,88H,0CH,08H,00H,08H,04H,02H,01H,0FFH,41H,41H,41H,41H,41H,41H,41H,0FFH,01H,00H,00H ;右TAB15:DB08H,08H,0E8H,29H,2AH,2EH,0E8H,08H,08H,0CCH,0AH,0BH,0E8H,0CH,08H,00H,00H,00H,0FFH,09H,49H,89H,7FH,00H,00H,0FH,40H,80H,7FH,00H,00H,00H;前TAB16:DB08H,0C8H,0B8H,8FH,0E8H,88H,40H,48H,0C8H,7FH,48H,48H,4CH,68H,40H,00H,08H,18H,08H,04H,0FFH,04H,00H,02H,13H,22H,62H,9AH,06H,02H,00H,00H;转TAB17:DB00H,00H,82H,92H,92H,92H,92H,92H,92H,92H,92H,0FFH,02H,00H,00H,00H,04H,04H,04H,04H,0CH,34H,04H,04H,44H,84H,7FH,04H,04H,06H,04H,00H ;寻TAB18:DB40H,42H,0CCH,00H,08H,0C8H,08H,0F9H,0AH,0EH,0F8H,08H,4CH,88H,00H,00H,40H,20H,1FH,20H,42H,41H,50H,4FH,40H,50H,5FH,40H,40H,63H,20H,00H ;迹TAB19:DB40H,42H,0C4H,00H,0FEH,22H,22H,3FH,8AH,0A8H,0C9H,8EH,0C8H,0ACH,88H,00H,40H,20H,1FH,22H,5FH,51H,51H,5FH,40H,44H,44H,7FH,44H,64H,20H,00H ;避TAB20:DB00H,0FEH,22H,5AH,86H,10H,0D2H,56H,5AH,53H,5AH,56H,0F2H,58H,10H,00H,00H,0FFH,04H,08H,17H,10H,17H,15H,15H,0FDH,15H,15H,17H,10H,10H,00H ;障END。
智能红外循迹小车程序
#include<reg52.h>#define uint unsigned int#define uchar unsigned char#define ulong unsigned longsbit you_2=P2^0;//红外探测端口定义sbit you_1=P2^1;sbit zhong=P2^2;sbit zuo_1=P2^3;sbit zuo_2=P2^4;sbit CG=P0^1;sbit DC=P0^0;uchar code L_F[8]= {0x10,0x30,0x20,0x60,0x40,0xc0,0x80,0x90};//左电机正转uchar code L_B[8]= {0x90,0x80,0xc0,0x40,0x60,0x20,0x30,0x10};//左电机反转uchar code R_F[8]= {0x01,0x03,0x02,0x06,0x04,0x0c,0x08,0x09};//右电机正转uchar code R_B[8]= {0x09,0x08,0x0c,0x04,0x06,0x02,0x03,0x01};//右电机反转uchar code B_F[8]= {0x91,0x83,0xc2,0x46,0x64,0x2c,0x38,0x19};//左反右正uchar code F_B[8]= {0x19,0x38,0x2c,0x64,0x46,0xc2,0x83,0x91}; //左正右反uchar code duandian[8]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};//断电unsigned char code qianjin[]={0x11,0x33,0x22,0x66,0x44,0xcc,0x88,0x99};//前进unsigned char h[]={0x11,0x33,0x22,0x66,0x44,0xcc,0x88,0x99};//uchar i;void delay(uint z){uint k ;uint j;for(k=0; k<z; k++)for(j=0; j<110; j++);}void QJ(unsigned int i){for(i=0;i<8;i++){P1=h[i]=qianjin[i];delay(13);}}void DD(){P1=0x00;delay(300);}void wtj(){while(1){if(P2==0xff){DD();delay(1000);break;}else{QJ(8);}}}void YG_1(){unsigned char i;for(i=0;i<8;i++){P1=h[i]=F_B[i];delay(10);}}void ZG_1(){ unsigned char i;for(i=0;i<8;i++){P1=h[i]=B_F[i];delay(10);}}void byg(){while(1){if(P2==0xfb)break;else if(P2==0xf9)break;else if(P2==0xfd)break;/*if(P2^0==0)break;else if(P2^1==0)break;/*else if(P2^2==0)break;else if(P2^3==0)break;else if(P2^4==0)break;*/elseYG_1();}}void bzg(){while(1){if(P2==0xfb)break;else if(P2==0xf3)break;else if(P2==0xf7)break;/*if(P2^0==0)break;else if(P2^1==0)break;else if(P2^2==0)break;if(P2^3==0)break;else if(P2^4==0)break;*/elseZG_1();}}void YG_2(){//unsigned char i; //unsigned char g;if(P2==0xfa){//delay(4000); wtj();byg();/*for(g=0;g<40;g++){for(i=0;i<8;i++){P1=F_B[i];delay(20);}} */}else if(P2==0xf2){//delay(4000); wtj();byg();/*for(g=0;g<40;g++){for(i=0;i<8;i++){P1=F_B[i];delay(20);}}*/}else if(P2==0xf6){//delay(4000);byg();/*for(g=0;g<40;g++){for(i=0;i<8;i++){P1=F_B[i];delay(20);}}*/}else if(P2==0xf4){//delay(4000); wtj();byg();/*for(g=0;g<40;g++){for(i=0;i<8;i++){P1=F_B[i];delay(20);}}*/}else ;}void ZG_2(){//unsigned char i; //unsigned char g;if(P2==0xeb){//delay(4000); wtj();bzg();/*for(g=0;g<40;g++){for(i=0;i<8;i++){P1=B_F[i];delay(20);}}*/else if(P2==0xe9){//delay(4000); wtj();bzg();/*for(g=0;g<40;g++) {for(i=0;i<8;i++){P1=B_F[i];delay(20);}}*/}else if(P2==0xed){//delay(4000); wtj();bzg();/*for(g=0;g<40;g++) {for(i=0;i<8;i++){P1=B_F[i];delay(20);}}*/}else if(P2==0xe5){//delay(4000); wtj();bzg();/*for(g=0;g<40;g++) {for(i=0;i<8;i++){P1=B_F[i];delay(20);}}*/}else ;}void ZG(){unsigned char i;for(i=0;i<8;i++){P1=h[i]=R_F[i];delay(11);}}void YG(){unsigned char i;for(i=0;i<8;i++){P1=h[i]=L_F[i];delay(11);}}/*void HT(){unsigned char i;for(i=0;i<8;i++){P1=houtui[i];delay(55);}}*/void zd(){while(1){if(P2==0xe0)QJ(8);else if(P2==0xff){while(1){DD();}}else{QJ(80);if(P2==0xff){while(1){DD();}}else{DC=0;break;break;}}}}void zd1(){while(1){if(P2==0xe0)QJ(8);else if(P2==0xff){while(1){DD();}}else{QJ(80);if(P2==0xff)while(1){DD();}}else{DC=0;break;}}}}void hy(){unsigned char i;for(i=0;i<8;i++){P1=h[i];delay(10);}}void main(){DC=1;while(1){QJ(8);if(P2!=0xff){delay(9000);break;}}while(1){DC=1;if(CG==1){delay(9000);DC=1;while(1){switch(P2){case 0xfb:QJ(8);break;//11011case 0xf1:QJ(8);break;//10001case 0xf3:QJ(8);break;//10011case 0xf7:ZG();break;//10111case 0xe7:ZG_1();break;//00111case 0xef:ZG_1();break;//01111case 0xe3:ZG_1();break; //00011case 0xe1:ZG_1();break; //00001case 0xf9:QJ(8);break;//11001case 0xfd:YG();break;//11101case 0xfc:YG_1();break;//11100case 0xfe:YG_1();break;//11110case 0xf8:YG_1();break; //11000case 0xf0:YG_1();break;//10000case 0xfa://11010QJ(16);// delay(4000);YG_2();//f7 break;case 0xf2://10010QJ(16);// delay(4000);YG_2();break;case 0xf6://10110QJ(16);// delay(4000);YG_2();break;case 0xf4://10100QJ(16);// delay(4000);YG_2();break;case 0xeb://01011QJ(16);//delay(4000);ZG_2();//fd break;case 0xe9://01001QJ(16);//delay(4000);ZG_2();break;case 0xed://01101QJ(16);//delay(4000);ZG_2();break;case 0xe5://00101QJ(16);//delay(4000);ZG_2();break;case 0xe0:zd1();break;//00000case 0xff:hy();break;//11111default:QJ(8); break;}}}else{switch(P2){case 0xfb:QJ(8);break;//11011 case 0xf1:QJ(8);break;//10001case 0xf3:QJ(8);break;//10011 case 0xf7:ZG();break;//10111 case 0xe7:ZG_1();break;//00111 case 0xef:ZG_1();break;//01111 case 0xe3:ZG_1();break; //00011 case 0xe1:ZG_1();break; //00001case 0xf9:QJ(8);break;//11001 case 0xfd:YG();break;//11101 case 0xfc:YG_1();break;//11100 case 0xfe:YG_1();break;//11110 case 0xf8:YG_1();break; //11000 case 0xf0:YG_1();break;//10000case 0xfa://11010QJ(16);// delay(4000);YG_2();//f7 break;case 0xf2://10010QJ(16);// delay(4000);YG_2();break;case 0xf6://10110QJ(16);// delay(4000);YG_2();break;case 0xf4://10100QJ(16);// delay(4000);YG_2();break;case 0xeb://01011QJ(16);//delay(4000);ZG_2();//fd break;case 0xe9://01001QJ(16);//delay(4000);ZG_2();break;case 0xed://01101QJ(16);//delay(4000);ZG_2();break;case 0xe5://00101QJ(16);//delay(4000);ZG_2();break;case 0xe0:zd();break;//00000case 0xff:hy();break;//11111default:QJ(8); break;}}}}。
单片机红外遥控小车源程序
单片机红外遥控小车源程序The document was finally revised on 202151单片机红外遥控小车源程序单片机源程序如下:1./*******************************************************************************2.--------------------------------------------------------------------------------3.* 实验名 : 红外线试验4.* 实验说明 : 数码管显示红外线发送过来的键值。
5.* 连接方式 : 见连接图6.* 注意 :7.*******************************************************************************/8.9.//#include<>10.#include<>11.//--定义使用的IO--//12.13.14.sbit IRIN = P3^2;15.sbit PWM1?= P0^1;16.sbit PWM2?= P0^2;17.18.//--定义一个全局变量--//19.unsigned char timer1;20.unsigned char IrValue[6]; //用来存放读取到的红外值21.unsigned char Time;22.23.//--声明全局函数--//24.void IrInit();25.void DelayMs(unsigned int );26.void Time1Config();27.void speedup();28.void Slowdown();29.void go();30.void left();31.void right();32.void pwm_left(int x);33.void pwm_right(int x);34./*******************************************************************************35.* 函数名 : main36.* 函数功能 : 主函数37.* 输入 : 无38.* 输出 : 无39.*******************************************************************************/40.41.void main()42.{43. PWM1=0;44. PWM2=0;45. IrInit();46. Time1Config();47. while(1)48. {49.50. IrValue[4]=IrValue[2]>>4; //高位51. IrValue[5]=IrValue[2]&0x0f; //低位52. if(IrValue[4]==0x0e&&IrValue[5]==0x08)53. {54.55. pwm_left(37);56. pwm_right(40);57.58. }59.60.61. if(IrValue[4]==0x0d&&IrValue[5]==0x04)62. {63.64. pwm_left(0);65. pwm_right(0);66.67. }68.69.//70. if(IrValue[4]==0x0e&&IrValue[5]==0x02)71. {72.73. pwm_left(35);74. pwm_right(22);75.76.77. }78.79. if(IrValue[4]==0x0e&&IrValue[5]==0x00)80. {81.82. pwm_left(22);83. pwm_right(35);84.85.86. }87.88. }89.90.}91.92.93.94.95.96.void pwm_left(int x)97.{98. if(timer1>100)//PWM周期为100*99. {100.101. timer1=0;102. }103.104. if(timer1 < x) //改变30这个值可以改变直流电机的速度105. {106.107. PWM1=1;108. }109.110. else111. {112.113. PWM1=0;114. }115.116.}117.118.void pwm_right(int y)119.{120. if(timer1>100)//PWM周期为100*121. {122.123. timer1=0;124. }125.126. if(timer1 < y) //改变30这个值可以改变直流电机的速度127. {128.129. PWM2=1;130. }131.132. else133. {134.135. PWM2=0;136. }137.138.}139./***************************************************************** **************140.* 函数名 : DelayMs()141.* 函数功能 : 延时142.* 输入 : x143.* 输出 : 无144.****************************************************************** *************/145.146.void DelayMs(unsigned int x) //误差 0us147.{148. unsigned char i;149. while(x--)150. {151.152. for (i = 0; i<13; i++)153. {}154. }155.156.}157./***************************************************************** **************158.* 函数名 : IrInit()159.* 函数功能 : 初始化红外线接收160.* 输入 : 无161.* 输出 : 无162.****************************************************************** *************/163.164.void IrInit()165.{166. IT0=1;//下降沿触发167. EX0=1;//打开中断0允许168. EA=1; //打开总中断169.170. IRIN=1;//初始化端口171. PWM1=0;172.173. PWM2=0;174.}175./***************************************************************** **************176.* 函数名 : ReadIr()177.* 函数功能 : 读取红外数值的中断函数178.* 输入 : 无179.* 输出 : 无180.****************************************************************** *************/181.182.void ReadIr() interrupt 0183.{184. unsigned char j,k;185. unsigned int err;186. Time=0;187. DelayMs(70);188.189. if(IRIN==0) //确认是否真的接收到正确的信号190. {191.192.193. err=1000; //1000*10us=10ms,超过说明接收到错误的信号194. /*当两个条件都为真是循环,如果有一个条件为假的时候跳出循环,免得程序出错的时195.侯,程序死在这里*/196. while((IRIN==0)&&(err>0)) //等待前面9ms的低电平过去197. {198.199. DelayMs(1);200. err--;201. }202.203. if(IRIN==1) //如果正确等到9ms低电平204. {205.206. err=500;207. while((IRIN==1)&&(err>0)) //等待的起始高电平过去208. {209.210. DelayMs(1);211. err--;212. }213.214. for(k=0;k<4;k++) //共有4组数据215. {216.217. for(j=0;j<8;j++) //接收一组数据218. {219.220.221. err=60;222. while((IRIN==0)&&(err>0))//等待信号前面的560us低电平过去223. {224.225. DelayMs(1);226. err--;227. }228.229. err=500;230. while((IRIN==1)&&(err>0)) //计算高电平的时间长度。
红外遥控控制小车前进,后退,左右转程序
while (!IRIN) //等 IR 变为高电平
{delay(1);}
while (IRIN) //计算IR高电平时长
{
delay(1);
N++;
{delay(1);}
for (j=0;j<4;j++) //收集四组数据
{
for (k=0;k<8;k++) //每组数据有8位
{
while (IRIN) //等 IR 变为低电平,跳过4.5ms的前导高电平信号。
{
uchar j,k,N=0;
EX0 = 0;
delay(15);
if (IRIN==1)
{ EX0 =1;
return;
}
//确认IR信号出现
while (!IRIN) //等IR变为高电平,跳过9ms的前导低电平信号。
beep();
EX0 = 1;
}
void delay(uchar x) //x*0.14MS红外用判断时间
{
uchar i;
while(x--)
{
for (i = 0; i<13; i++) {;}
}
}
sbit ENA = P3^0;//L298的使能端
sbit ENB = P3^1;//L298的使能端
sbit IRIN=P3^2;//声明红外接口
uchar IRCOM[4],m,zuozhuan,youzhuan,zhuanwa,shache,qj,dc,j=20;
uchar K,a,b;
红外遥控小车的c程序
#include<reg52.h>#include<math.h>#include<intrins.h>#define uchar unsigned char //数据类型#define uint unsigned intsbit hwx=P3^3;uchar key;uchar l_lhj[66];//定义66位数组变量来存储接收的时间参数uchar ledmap[10]={0x3f, 0x06 , 0x5b, 0x4f, 0x66, 0x6d,0x7d};//*********************************************sbit ENa=P2^4; //* L298的Enable Asbit ENb=P2^7; //* L298的Enable Bsbit IN1=P2^2; //* L298的Input 1sbit IN2=P2^3; //* L298的Input 2sbit IN3=P2^5; //* L298的Input 3sbit IN4=P2^6; //* L298的Input 4uchar t=0; //* 中断计数器uchar m1=0; //* 电机1速度值uchar m2=0; //* 电机2速度值uchar tmp1,tmp2; //* 电机当前速度值//*************************************************//函数定义void Init8952( ) ; //初始化AT89C52单片机void Move_Fo( ) ; // 小车向前运动void Move_Ba( ) ; // 小车向后运动void Move_Le( ) ; // 小车向左运动void Move_Ri( ) ; // 小车向右运动void Stop( );// 小车停止void Move_Qi(); //小车加速运动void Move_Sl();//小车减速运动void Delay(uchar n) ;// 延时n 毫秒void Delay1(void);//空5个指令void Motor(uchar index , char speed);//控制小车速度void Car_Action();//*****************************************************//延时//*****************************************************void Delay(uchar n){uchar i;while(n--){for (i=0;i<250;i++){}}}void Delay1(void)//空5个指令{unsigned char i=13;while(i)i--;}//******************************************************* //单片机初始化//******************************************************* void Init8952(){TMOD = 0x02; //定时器0工作与方式2EX1=1; //开启外部中断1IT1=1; // 设置成下降沿触发方式TH0=0x9B; // 装入定时器0的初值TL0=0x9B;ET0=1; // 定时器0允许中断TR0=1; // 启动定时器0EA = 1 ;// 开总中断}//******************************************************** //电机控制函数index-电机号(1,2); speed-电机速度(-100到+100) //******************************************************** void motor(uchar index, char speed){if(speed>=-100 && speed<=100){if(index==1) // 电机1的处理{m1=abs(speed); // 取速度的绝对值if(speed<0) // 速度值为负则反转{IN1=0;IN2=1;}else // 不为负数则正转{IN1=1;IN2=0;}}if(index==2) // 电机2的处理{m2 = abs(speed); // 电机2的速度控制if(speed<0) // 电机2的方向控制{IN3 = 0;IN4 = 1;}else{IN3 = 1;IN4 = 0;}}}}//***************************************void Move_Fo( ) // 小车向前运动{P1 = ledmap[1];Motor(1,40);Delay(250) ;}void Move_Ba( ) // 小车向后运动{P1 = ledmap[2];Motor(1,-40) ;Delay(250) ;}void Move_Le( ) // 小车向左运动{P1 = ledmap[3];//Motor(1,40);Motor(2,90);Delay(30) ;Motor(1,80);Delay(50) ;}void Move_Ri( ) // 小车向右运动{P1 = ledmap[4];Motor(2,-90);Delay(30) ;//Delay(250) ;Motor(1,80);Delay(50) ;}void Move_Qi( )//加速{uchar i;P1 = ledmap[5];for(i=40;i<100;i+=15){Motor(1,i);// Motor(2,i-3);Delay(250) ;Delay(250) ;}}void Move_Sl()//减速{uchar j;P1 = ledmap[6];for(j=80;j>0;j-=8){Motor(1,j);Delay(250) ;Delay(250) ;}}void Stop( ) //小车停止{P1 = ledmap[0];IN1 = IN2;IN3 = IN4;}void Car_Action() //判断红外线信号小车响应运动{switch( key ){case 0x03://暂停Stop( ) ; break ;case 0x01: //前进Move_Fo() ;break;case 0x02: // 后退Move_Ba() ;break;case 0x04: // 左转Move_Le() ;break;case 0x05: // 右转Move_Ri() ;break;case 0x06://快速运行Move_Qi( ) ; break ;case 0x07:Move_Sl( ) ;break ;//减速}}//************************************************* //主函数void main( ){//Delay(100) ;Init8952( );while(1){Car_Action();//Delay(10) ;}//*****************************************************//定时器0 中断函数void timer0( ) interrupt 1 // T0中断服务程序{if(t==0) // 1个PWM周期完成后才会接受新数值{tmp1 = m1 ;tmp2 = m2 ;}if(t<tmp1)ENa = 1 ;elseENa = 0 ; // 产生电机1的PWM信号if(t<tmp2)ENb = 1 ;elseENb = 0 ; // 产生电机2的PWM信号t++;if(t>=100) // 1个PWM信号由100次中断产生t = 0 ;}//********************************************************void hongwai(void) interrupt 2 //外部中断1 ,INT1(P3^3)连接红外线接收IC数据脚{uchar i,j,tmp;EX1=0;j=33;//传送一组数包括引导码1位,地址码8位加反码8位,指令码8位加反码8位,总共33位i=0;//从第一维数组开始tmp=100;//加八延时,while(tmp){tmp--;}if(hwx){//然后再检测红线接收脚是有数据招收,有继续,没有则退出EX1=1;return;}{//循环接收33位数据,为何我们用到66位数组,我们可以不接收高电平时间常数,只接低电平常数就//可以判断1或0了,在这里我们都接收,为串口调试软件接收计算波形//还有一点要知道,接收波形是反向,在没有接收时端口为高电平tmp=0;l_lhj[i]=1;//时间量从1开始while(!hwx){//检测高低电平的变化l_lhj[i]++;//没变继续加1Delay1();//加入延时,是因为我们采用8位二进来存储,如果不加延时,时间量将计满tmp++;//此变量为防止干扰带来的死循环if(tmp==250)break;}i++;tmp=0;l_lhj[i]=1;//时间量从1开始while(hwx){//检测高低电平的变化l_lhj[i]++;//没变继续加1Delay1();//同上tmp++;if(tmp==250)break;}i++;j--;}i=255;//加入循环延时,抗干扰while(i){tmp=255;while(tmp){tmp--;}i--;}tmp=0;for(i=3;i<19;i++,i++){//处理地址位,对低电平时间数据的数理,这里我们只处理地址码和指令码,引导码和反码我们就忽略tmp>>=1;//右移一位,接收低电平在前if(l_lhj[i]>30)//检测低电平时间超过30就确认为1tmp+=0x80;}for(i=35;i<51;i++,i++){//同上,这里处理指令位tmp>>=1;if(l_lhj[i]>30)tmp+=0x80;}key=tmp;EX1=1;}。
基于51单片机的红外遥控智能小车源程序(C语言)
基于51单片机的红外遥控智能小车源程序(C语言)/*预处理命令*/#include //包含单片机寄存器的头文件#include //包含_nop_()函数定义的头文件#define uchar unsigned char#define uint unsigned int#define delayNOP(); {_nop_();_nop_();_nop_();_nop_();}; sbit IRIN=P3^2; //红外接收器数据线sbit LCD_RS = P0^7;sbit LCD_RW = P0^6;sbit LCD_EN = P0^5;uchar begin[]={"My car!"};uchar cdis1[]={"jiansu!"};uchar cdis2[]={"qianjin!"};uchar cdis3[]={"jiasu!"};uchar cdis4[]={"zuozhuang!"};uchar cdis5[]={"STOP!"};uchar cdis6[]={"youzhuan!"};uchar cdis8[]={"daoche!"};sbit M1 = P1^0;sbit M2 = P1^1;sbit M3 = P1^2;sbit M4 = P1^3;sbit EN12 = P1^4;sbit EN34 = P1^5;uchar IRCOM[7];uchar m,n;uchar t=2;uchar g;uchar code digit[]={"0123456789"};uint v;uchar count;bit flag;void delayxms(uchar t);void delay(unsigned char x) ;void delay1(int ms);void motor();void lcd_display();/*检查LCD忙状态lcd_busy为1时,忙,等待。
红外遥控小车程序
程序已调试,能实现前进、后退、左前转、右前转、左后转、右后转、左圆转、右圆转等,并且有LED灯显示。
//**********************************************//***************红外小车***********************//**********************************************#include<reg52.h>#define uint unsigned int#define uchar unsigned charsbit M11=P1^0; // 电机1接口sbit M12=P1^1;sbit M21=P1^2; // 电机2接口sbit M22=P1^3;sbit LED0=P0^0; // 紧急灯sbit LED1=P0^1; // 左前灯sbit LED2=P0^2; // 右前灯sbit LED3=P0^3; // 左后灯sbit LED4=P0^4; // 左后灯sbit F=P1^5; //蜂鸣器接口sbit Int0 = P3^3; // 红外接收采用外部中断1uchar TEMP1=0; //全局变量用于存放红外返回值-用于PWM占空比的控制uchar TEMP2=10; // 用于方向的控制uchar databus[7];//用于红外接收存放数据//************************************************************//延时函数void delay1(uint xms) //delay 0.1ms{uint i,j;for(i=xms;i>0;i--)for(j=13;j>0;j--);}//************************************************************//********************接受解码函数uchar Rec(){uchar temp=0; //函数内部临时变量用于返回函数值uint i=0; // 用于存放数据的临时变量uint j=0;uint m=0; // 局部计数临时变量uint n=0; // 局部计数临时变量uint k=0; // 局部计数临时变量EX1=0; // 关外部中断1 以防再次外部1中断的介入while(!Int0) //用于计时前9Ms低电平的引导码{delay1(1);m++; // 计数引导码的长度}if(m<=60)return 0; //while(Int0) //用于计时4.5ms高电平的引导码{delay1(1);n++; //计时高电平}if(n<=30)return 0;M11=M12=M21=M22=0; //进入中断停止电机防止电机颤抖for(i=0;i<4;i++)for(j=0;j<8;j++){while(!Int0) //过滤数据的低位0.56ms低电平{delay1(1);}while(Int0) // 进入高电平计时{delay1(1);k++; // k计时每次的高电平}databus[i]=databus[i]>>1; // 数据接收数组首先默认接收为0信号即databus 【i】//第7位移入0if(k>=10){databus[i]=databus[i]|0x80; // 若为1把第8位置1}k=0; //把k的值重新置零};if(databus[2]!=~databus[3])return 0;temp=databus[2]; // 返回赋值return temp; //}//****************************************************//**********红外接受中断服务函数+接受编码TEMP1TEMP2void int0() interrupt 2{uchar temp; // 临时存放红外接收函数返回值uint i=0; // 计数临时变量LED0=1; //因紧急灯是闪烁的每次中断时结果不一样为保证效果先灭紧急指示灯temp=Rec(); // 红外函数返回赋值switch (temp) // 对返回的数据进行编码方便后面的操作{case 0x40:{TEMP2=0;//紧急状态暂停break;}case 0x46:{TEMP2=1;//前进LED2=LED1=0; //指示灯设置LED4=LED3=1;break;}case 0x44:{TEMP2=2;//左前转LED1=0; //指示灯设置LED2=LED4=LED3=1;break;}case 0x43 :{TEMP2=3;//右前转LED2=0; //指示灯设置LED1=LED4=LED3=1;break;}case 0x15:{TEMP2=4; //倒车状态LED2=LED1=1; //指示灯设置LED4=LED3=0;break;}case 0x07:{TEMP2=5;//左后转LED3=0; //指示灯设置LED1=LED4=LED2=1;break;}case 0x09:{TEMP2=6;//右后转LED4=0; //指示灯设置LED1=LED2=LED3=1;break;}case 0x45:{TEMP2=7; //左园转break;}case 0x47:{TEMP2=8;//右园转break;}} //每次接受红外蜂鸣器蜂鸣一次F=1;delay1(300);F=0;EA=1; // 开总中断EX1=1; // 开外1中断IT1=1; // 下降沿触发}//*****************************************//**********电机驱动函数void PWM_RUN(){uchar n=0; //n=TEMP2;if(n==0) //紧急状态{M11=M12=M21=M22=0;LED0=~LED0; //设置紧急灯动作delay1(1000);}if(n==1) //m1和m2都前转前进{ M11=1; M12=0; M21=0; M22=1; }if(n==2) //m1停止m2前转实现左前转弯{ M11=0; M12=0; M21=0; M22=1; }if(n==3) // m1前转m2停止实现右前转{ M11=1; M12=0; M21=0; M22=0; }if(n==4)//m1m2倒转实现倒车{ M11=0; M12=1; M21=1; M22=0; }if(n==5) //m1停止m2倒转实现左后转{ M11=0; M12=0; M21=1; M22=0; }if(n==6)// m1倒转m2停止实现右后转{ M11=0; M12=1; M21=0; M22=0; }if(n==7)//m1倒传m2前转实现左方向原地打转{ M11=0; M12=1; M21=0; M22=1; }if(n==8)//m1前转m2倒转实现右方向原地打转{ M11=1; M12=0; M21=1; M22=0; }}//***************************THE main()void main(){EA=1; // 开总中断EX1=1; // 开外1中断IT1=1; // 下降沿触发P1=0; // P1口为电机控制口初始化为0即开机时电机是停止的while(1) {PWM_RUN();}}。
基于51单片机下红外遥控小车程序原理
<!--
序已由电子乐层经过实物调试过了的。大家放心使用,下面把程序资料及实
物测评照片贴出,供大家参加,大家试验过程中有什幺问题可以咨询电子乐
屋,这里只贴出 51 单片机无线遥控开关手机 app 控制程序实例,需要 APP
安装包的请留言留下电子邮箱地址(现在网盘连接经常效)。
这是一款手机 APP 蓝牙遥控控制单片机 LED 灯的亮灭开关的单片机
源代码及 APP.apk 资料包。需要一个“蓝牙串口”的安卓应用,可以在安卓手
机应用商店里找到 SPP 蓝牙串口 APP。完整手机 APP 蓝牙遥控控制单片机
LED 灯的亮灭开关单片机源代码及 APP.apkfhvooA
sbitled1=P2;//指示灯 0 sbitled2=P2;//指示灯 1 sbitled3=P2;//指示灯 3 voidinit();//串口初始化 voidsend(unsignedchara);//单字节发送函数 voidctrl();//接收处理函数 voidmain() {
前进、后退、左拐、右拐停止等功能。APP 由电子乐屋提供。
单片机程序及 APP 安装_0V7eg
这是一款 51 单片机无线遥控开关手机 app 控制程序实例资料,资料含单
片机驱动 ESP8266 无线 WIFI 模块程序、测试 APP.apk 安装文件,单片机程
基于 51 单片机下红外遥控小车程序原理
下面是一款 Android 手机通过蓝牙模块与单片机通信单片机程序,单片机 可以使用以下 51 单片机: AT89C51,AT89C52,AT89S51,AT89S52,STC89C52RC,下面是单片机 程序。 #include“reg52.h“ #include “intrins.h“ unsigned char tmp; unsigned int c=0;
红外线控制小车
/************************************************************************** **简单寻迹程序:接法EN1 EN2 PWM输入端,本程序不输入PWM,直接使插上跳线帽,使能输出,这样就能全速运行在指定位置加入红外一体化接收头P1_0 P1_1 接IN1 IN2 当P1_0=1,P1_1=0; 时左上电机正转左上电机接驱动板子输出端(蓝色端子OUT1 OUT2)P1_0 P1_1 接IN1 IN2 当P1_0=0,P1_1=1; 时左上电机反转P1_0 P1_1 接IN1 IN2 当P1_0=0,P1_1=0; 时左上电机停转P1_2 P1_3 接IN3 IN4 当P1_2=1,P1_3=0; 时左下电机正转左下电机接驱动板子输出端(蓝色端子OUT3 OUT4)P1_2 P1_3 接IN3 IN4 当P1_2=0,P1_3=1; 时左下电机反转P1_2 P1_3 接IN3 IN4 当P1_2=0,P1_3=0; 时左下电机停转P1_4 P1_5 接IN5 IN6 当P1_4=1,P1_5=0; 时右上电机正转右上电机接驱动板子输出端(蓝色端子OUT5 OUT6)P1_4 P1_5 接IN5 IN6 当P1_4=0,P1_5=1; 时右上电机反转P1_4 P1_5 接IN5 IN6 当P1_4=0,P1_5=0; 时右上电机停转P1_6 P1_7 接IN7 IN8 当P1_6=1,P1_7=0; 时右下电机正转右下电机接驱动板子输出端(蓝色端子OUT7 OUT8)P1_6 P1_7 接IN7 IN8 当P1_6=0,P1_7=1; 时右下电机反转P1_6 P1_7 接IN7 IN8 当P1_6=0,P1_7=0; 时右下电机停转P3_4接四路寻迹模块接口第一路输出信号即中控板上面标记为OUT1P3_5接四路寻迹模块接口第二路输出信号即中控板上面标记为OUT2P3_6接四路寻迹模块接口第三路输出信号即中控板上面标记为OUT3P3_7接四路寻迹模块接口第四路输出信号即中控板上面标记为OUT4四路寻迹传感器有信号(白线)为0 没有信号(黑线)为1四路寻迹传感器电源+5V GND 取自于单片机板靠近液晶调节对比度的电源输出接口关于单片机电源:本店驱动模块内带LDO稳压芯片,当电池输入6V时时候可以输出稳定的5V分别在针脚标+5 与GND 。
msp430单片机红外遥控小车设计程序_1
/*************************************************************************原理:根据高电平持续时间判断信号传输的是0还是1进行解码方法:采用定时器这里用width=end-start,width的长度来判断解码信号为1还是0 功能:按一个键,单片机数码管上显示按键的用户码、数据码和数据反码**************************************************************************/#include <msp430f5438a.h>#include "PIN_DEF.H"#define uchar unsigned char#define uint unsigned intuint start = 0,end = 0; //计数开始和结束标志uint width = 0; //用于存放脉宽uint en = 0,n = 0; // en用于保存是否有引导码进入,n表示保存信号的数组IR[]下标uchar IR[32]; //先用数组将接收到的数据保存起来uchar IR_buf[4]={0x00,0x00,0x00,0x00};//IR_buf[0]、IR_buf[1]为用户码低位、用户码高位接收缓冲区// IR_buf[2]、IR_buf[3]为键数据码和键数据码反码接收缓冲区uchar disp_buf[8]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}; //显示缓冲单元,初值为0x00,指向显示码的8个"0"uchar seg_data[]={ 0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xbf};//0~F和"-"符的显示码(字形码)/* 50us的延迟函数*/void delay_50us(unsigned int t){unsigned int j;for(;t>0;t--)for(j=10;j>0;j--);}/********以下是显示函数********/void Display(){P8DIR = 0XFF; //段选方向打开P8OUT = seg_data[disp_buf[0]]; //用户码低P9DIR = 0x01; //选位P9OUT = ~0x01; //数码管第一位输出delay_50us(1); //延迟50usP8OUT = seg_data[disp_buf[1]]; //用户码低P9DIR = 0x02;P9OUT = ~0x02;delay_50us(1);P8OUT = seg_data[disp_buf[2]]; //用户码高P9DIR = 0x04;P9OUT = ~0x04;delay_50us(1);P8OUT = seg_data[disp_buf[3]]; //用户码高P9DIR = 0x08;P9OUT = ~0x08;delay_50us(1);P9DIR = 0x00;P8OUT = seg_data[disp_buf[4]]; //数据码P1DIR = 0x10;P1OUT = ~0x10;delay_50us(1);P8OUT = seg_data[disp_buf[5]]; //数据码P1DIR = 0x20;P1OUT = ~0x20;delay_50us(1);P8OUT = seg_data[disp_buf[6]]; //数据反码P1DIR = 0x40;P1OUT = ~0x40;delay_50us(1);P8OUT = seg_data[disp_buf[7]]; //数据反码P1DIR = 0x80;P1OUT = ~0x80;delay_50us(1);P1DIR = 0x00;}//***************************************************************************// // // // Init_Port(void): 设置IO端口//// // //***************************************************************************// void Init_Port(void){P5DIR |= POWER ; // 主电源MAIN_POWER_ON ;}//***************************************************************************//// // //函数:Init_CLK(void) ////功能:初始化主时钟: MCLK = XT2=16MHZ // // // //***************************************************************************// void Init_CLK(void){P5SEL |= 0x0c; //选择内部16MHZ晶振,将引脚作为第二功能使用P5DIR |= 0x0c;UCSCTL6 &= ~XT2OFF; //EN XT2//因为XT1未开启,所以给默认为XT1的时钟重新选择时钟来源UCSCTL4 |= SELA_1; //先将ACLK配置为VLOCLKUCSCTL3 |= SELREF_2; //将FLLREFCLK配置为REFCLKwhile (SFRIFG1 & OFIFG){UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); // 清除时钟标志位SFRIFG1 &= ~OFIFG; // 清除时钟错误标志位}UCSCTL4 |=SELS_5; //将SMCLK时钟源配置为XT2}//***************************************************************************// // // // Init_IRUART(void): 设置红外端口//// // //***************************************************************************// void Init_IRUART(void){P1SEL |= (0x01<<2); //捕获的输入引脚P1.2P1DIR &= ~(0x01<<2);}/********以下是解码函数********/void Decode(void){if(width > 8600) //如果高电平时间大于4.3ms,则判断为引导码并将解码标志en置为1{en = 1;n = 0;}if(en == 1) //判断是否执行解码操作{if(width >=1700&&width <=4000) //当高电平时间>=0.85ms,<=2ms时判断为1 {IR[n] = 1;n++;width = 0;}if(width > 600&&width<1700) //当高电平时间<0.85ms,>0.3ms时判断为0{IR[n] = 0;n++;width = 0;}if(n >= 32) //当数组存满32位时,n清零,en使能标志位清零{en = 0;n = 0;}}}/*将IR[]里的值八位一组分开并转换到IR_buf[]里面,并将IR_buf的值转换成数码管显示的缓存*/void Process(void){if(n == 0){ //如果n == 0将IR[]的值转存到IR_buf[]里IR_buf[0]=IR[8*0]*128+IR[8*0+1]*64+IR[8*0+2]*32+IR[8*0+3]*16+IR[8*0+4]*8+IR[8*0+5]*4+IR[ 8*0+6]*2+IR[8*0+7];IR_buf[1]=IR[8*1]*128+IR[8*1+1]*64+IR[8*1+2]*32+IR[8*1+3]*16+IR[8*1+4]*8+IR[8*1+5]*4+IR[ 8*1+6]*2+IR[8*1+7];IR_buf[2]=IR[8*2]*128+IR[8*2+1]*64+IR[8*2+2]*32+IR[8*2+3]*16+IR[8*2+4]*8+IR[8*2+5]*4+IR[ 8*2+6]*2+IR[8*2+7];IR_buf[3]=IR[8*3]*128+IR[8*3+1]*64+IR[8*3+2]*32+IR[8*3+3]*16+IR[8*3+4]*8+IR[8*3+5]*4+IR[ 8*3+6]*2+IR[8*3+7];//if(IR_buf[2] == ~IR_buf[3]) //校验{disp_buf[0]=IR_buf[0]>>4; //取键码的低四位送显示缓冲disp_buf[1]=IR_buf[0]&0x0f; //右移4次,高四位变为低四位送显示缓冲disp_buf[2]=IR_buf[1]>>4;disp_buf[3]=IR_buf[1]&0x0f;disp_buf[4]=IR_buf[2]>>4;disp_buf[5]=IR_buf[2]&0x0f;disp_buf[6]=IR_buf[3]>>4;disp_buf[7]=IR_buf[3]&0x0f;}}}/********以下是主函数********/void main(void){WDTCTL = WDTPW + WDTHOLD; // 关闭看门狗Init_Port(); // 电源初始化Init_IRUART(); //红外端口初始化Init_CLK() ; //初始化时钟TA0CTL = TASSEL_2+ID_3+TACLR+TAIE+MC_1; //定时器A时钟信号选择SMCLK,8分频,//同时设置定时器A计数模式为增计模式TA0CCTL1 = CM0+SCS+CAP+CCIE; //输入上升沿捕获,CCI0A为捕获信号源TA0CCR0 = 20000; //设置计数器溢出时间为10ms_EINT() ; //开启全局中断while(1){Process(); //将IR[]数组缓存转换为数码管显示缓存函数Display(); //数码管显示函数}}#pragma vector=TIMER0_A1_VECTOR //定时器A中断处理__interrupt void Timer0_A1(void){switch(TA0IV) //向量查询{ case 2: //捕获中断if(TA0CCTL1&CM0) //捕获到上升沿{TA0CCTL1=(TA0CCTL1&(~CM0))|CM1; //更变设置为下降沿触发start=TA0R; //记录初始时间}else if (TA0CCTL1&CM1) //捕获到下降沿{TA0CCTL1=(TA0CCTL1&(~CM1))|CM0; //==更变设置为上升沿触发end=TA0R; //用start,end,overflow计算脉冲宽度if(end>start)width = end - start; //实际高电平宽度Decode(); //解码end = 0;start = 0;TA0R=0;}break;default:break;}}。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
#include<reg52.h>
#include"lcd1602.h"
#include<stdio.h>
#include<string.h>
#define uchar unsigned char
#define uint unsigned int
#define V_TH0 0XFF
#define V_TL0 0XF6
#define V_TMOD 0X01
sbit ina=P1^1;
sbit inb=P1^2;
sbit inc=P1^3;
sbit ind=P1^4;
sbit ena=P3^6;
sbit enb=P3^7;
uchar ZKB1=50;
uchar ZKB2=50;
uchar shou;
uchar str1[8];
uchar str2[]=" ";
uchar irtime;
uchar startflag;
uchar irdata[33];
uchar bitnum;
uchar irreceok;
uchar ircode[3];
uchar irprosok;
//************************************************ //延时函数,在12MHz的晶振频率下
//大约50us的延时
//************************************************ void delay_50us(uint t)
{
uchar j;
for(;t>0;t--)
for(j=19;j>0;j--);
}
//************************************************
//延时函数,在12MHz的晶振频率下
//大约50ms的延时
//************************************************ void delay_50ms(uint t)
{
uint j;
for(;t>0;t--)
for(j=6245;j>0;j--);
}
void timer0init(void)
{
TMOD=0x03;
TH0=0x00;
TL0=0x00;
ET0=1;
EA=1;
TR0=1;
TH1=V_TH0;
TL1=V_TL0;
TR1=1;
ET1=1;
}
void int0init(void)
{
IT0=1;
EX0=1;
EA=1;
}
void irpros(void) //0x1c
{
uchar k,i,j;
uchar value;
k=1;
for(j=0;j<4;j++)
{
for(i=0;i<8;i++)
{
value=value>>1; //7
if(irdata[k]>6) //8
{
value=value | 0x80;
}
k++;
}
ircode[j]=value;
}
irprosok=1;
}
void main()
{
ina=0;
inb=0;
inc=0;
ind=0;
timer0init();
int0init();
lcd1602_init();
lcd1602_printf("cao",0);
while(1)
{
if(irreceok)
{
irpros();
irreceok=0;
shou = ircode[2];
}
sprintf(str1,"%u",shou);
lcd1602_printf(str1,0);
if(shou==3328/256)
{
lcd1602_printf("G_Left",1);
ina=0;
inb=0;
inc=0;
ind=1;
}
else if(shou==6400/256)
{
lcd1602_printf("Go",1);
ina=1;
inb=0;
inc=0;
ind=1;
}
else if(shou==6912/256)
{
lcd1602_printf("G_Right",1);
ina=1;
inb=0;
inc=0;
ind=0;
}
else if(shou==4608/256)
{
lcd1602_printf("B_Right",1);
ina=0;
inb=1;
inc=0;
ind=0;
}
else if(shou==768/256)
{
lcd1602_printf("B_Left",1);
ina=0;
inb=0;
inc=1;
ind=0;
}
else if(shou==5632/256)
{
lcd1602_printf("Back",1);
ina=0;
inb=1;
inc=1;
ind=0;
}
else if(shou==5376/256)
{
lcd1602_printf("Stop",1);
ina=0;
inb=0;
inc=0;
ind=0;
}
else if(shou==5120/256)
{
shou=0;
ZKB1+=10;
ZKB2+=10;
}
else if(shou==3840/256) {
shou=0;
ZKB1-=10;
ZKB2-=10;
}
}
}
void timer0 () interrupt 1 {
irtime++; //255
}
void int0 () interrupt 0
{
if(startflag)
{
if(irtime>32) //检测引导码{
bitnum=0;
}
irdata[bitnum]=irtime; irtime=0;
bitnum++;
if(bitnum==33)
{
bitnum=0;
irreceok=1;
}
}
else
{
startflag=1;
irtime=0;
}
}
void timer1() interrupt 3 {
static uchar click=0;
TH1=V_TH0;
TL1=V_TL0;
click++;
if (click>=100) click=0;
if (click<=ZKB1)
ena=1;
else
ena=0;
if (click<=ZKB2)
enb=1;
else
enb=0;
}。