標題: 8051單片機制作紅外發(fā)射與接收 [打印本頁]

作者: jinsheng7533967    時間: 2018-12-6 11:03
標題: 8051單片機制作紅外發(fā)射與接收
[attach]159518[/attach]

///////////////////////////  紅外發(fā)射代碼  ///////////////////////////

#include <reg51.h>

#define uchar unsigned char

#define uint unsigned int

sbit rfot=P1^6;  //紅外線輸出

sbit akey=P1^2;  //A鍵輸入

sbit bkey=P1^3;  //B鍵輸入

sbit ckey=P1^4;  //C鍵輸入

sbit dkey=P1^5;  //D鍵輸入

void delay_ms(uint xms)              //延時子函數(shù)1ms*xms

{

     uint i,j;

     for(i=xms;i>0;i--)

           for(j=127;j>0;j--);

}

void delay_112()                 //紅外線延時函數(shù),延時1.12毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=142;n>0;n--);



}

void delay_56()                 //紅外線延時函數(shù),延時0.56毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=70;n>0;n--);



}

void delay_50()                 //紅外線延時函數(shù),延時0.5毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=64;n>0;n--);



}

void bit_boot()

{

     rfot=0;      delay_ms(9);

     rfot=1;

     delay_ms(4);

     delay_50();

}

void a_key()           //A鍵編碼

{

     uint i;

     bit_boot();

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_56();

     }

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_112();

     }

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;      delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      //用戶碼



     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();    //用戶反碼      

     rfot=0;

     delay_ms(1);

     rfot=1;      

}

void b_key()          //B鍵編碼

{

     uint i;

     bit_boot();

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_56();

     }

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_112();

     }

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;      delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();        用戶碼



     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();          用戶反碼      

     rfot=0;

     delay_ms(1);

     rfot=1;   

}

void c_key()            //C鍵編碼

{

     uint i;

     bit_boot();

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_56();

     }

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_112();

     }

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;      delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();        用戶碼



     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();          用戶反碼      

     rfot=0;

     delay_ms(1);

     rfot=1;

}

void d_key()                //D鍵編碼

{

     uint i;

     bit_boot();

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_56();

     }

     for(i=0;i<8;i++)

     {

         rfot=0;

         delay_56();

         rfot=1;

         delay_112();

     }

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;      delay_56();

     rfot=1;

     delay_56();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();        用戶碼



     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_112();      

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();        

     rfot=0;

     delay_56();

     rfot=1;

     delay_56();          用戶反碼      

     rfot=0;

     delay_ms(1);

     rfot=1;

}

void init()

{

     TMOD=0x01;

     TH0=(65536-50000)/256;

     TL0=(65536-50000)%256;

     EA=1;

     ET0=1;

}

void keyscan()        //鍵盤掃描程序

{

     if(akey==0)

     {

        delay_ms(5);

        if(akey==0)

        {

           a_key();

           while(!akey);   

        }

     }

      if(bkey==0)

     {

        delay_ms(5);

        if(bkey==0)

        {

           b_key();

           while(!bkey);   

        }

     }

     if(ckey==0)

     {

        delay_ms(5);

        if(ckey==0)

        {

           c_key();

           while(!ckey);   

        }

     }

     if(dkey==0)

     {         delay_ms(5);

        if(dkey==0)

        {

           d_key();

           while(!dkey);

           TR0=~TR0;   

        }

     }     

}

void main()                 //程序從這里開始

{

     init();



     while(1)

     {

         keyscan();

     }

}

void T0_time()interrupt 1

{

     TH0=(65536-50000)/256;

     TL0=(65536-50000)%256;   

}  



///////////////////////////  紅外接收代碼  ///////////////////////////
#include <reg51.h>

#define uchar unsigned char

#define uint unsigned int

sbit rfin=P3^7;  //紅外線輸入

void delay_ms(uint xms)              //延時子函數(shù)1ms*xms

{

     uint i,j;

     for(i=xms;i>0;i--)

           for(j=127;j>0;j--);

}

void delay_112()                 //紅外線延時函數(shù),延時1.12毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=142;n>0;n--);



}

void delay_56()                 //紅外線延時函數(shù),延時0.56毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=70;n>0;n--);



}

void delay_50()                 //紅外線延時函數(shù),延時0.5毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=64;n>0;n--);



}



void delay_35()                 //紅外線延時函數(shù),延時0.35毫秒

{      uint m,n;

     for(m=1;m>0;m--)

        for(n=60;n>0;n--);



}

void delay_30()                 //紅外線延時函數(shù),延時0.30毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=41;n>0;n--);



}

void delay_25()                 //紅外線延時函數(shù),延時0.25毫秒

{

     uint m,n;

     for(m=1;m>0;m--)

        for(n=26;n>0;n--);



}

void main()

{

     uchar i,j,k,temp,m;

     uchar usercode,user_code,datecode,date_code;

     //k=0;

     //temp=0;

     //rfin=0;

  if(rfin==0)

     {

         for(m=0;m<10;m++)     //跳過9mS引導區(qū)

         {

            if(rfin==0)

            {

               delay_56();

               delay_30();

            }

         }

         if(rfin==1)                //跳過4.5mS引導區(qū)

         {

             delay_ms(4);

             delay_50();

         }

         if(rfin==0);

         {              delay_56;

             delay_56;

             delay_30;

         }

             for(i=0;i<4;i++)   

             {

                   temp=0;
                   k=1;   

                for(j=0;j<9;j++)

                {

                    if(rfin==0)

                    {

                       k=0;

                    }

                     else  

                       if(rfin==1)

                       {

                       k=1;

                       }                             

                    temp=(temp<<1)|k;

                       if(rfin==0)

                       {  

                           delay_25();

                           if(rfin==1);

                           delay_56();

                           delay_30();

                        }

                        else

                        {   

                           if(rfin==1)

                           {  

                              delay_35();

                              if(rfin==1);

                              delay_56();

                              delay_30();

                           }

                         }

                  }

                  switch (i)

                  {

                     case 0: usercode=temp;        //用戶碼數(shù)據(jù)寄存器

                      break;

                     case 1: user_code=temp;       //用戶反碼數(shù)據(jù)寄存器

                      break;                      case 2: datecode=temp;         //數(shù)據(jù)碼數(shù)據(jù)寄存器

                      break;

                     case 3: date_code=temp;        //數(shù)據(jù)反碼數(shù)據(jù)寄存器

                      break;

                  }      

             }

         P1=datecode;                    //將數(shù)據(jù)碼送入P1端口點亮LED

      }

}








作者: admin    時間: 2018-12-6 16:44
補全原理圖或者詳細說明一下電路連接即可獲得100+黑幣
作者: jinsheng7533967    時間: 2018-12-6 18:15
明明放了原理圖的,怎么就沒了呢
作者: jinsheng7533967    時間: 2018-12-6 20:55
8051單片機制作紅外發(fā)射與接收電路圖.rar (73.76 KB, 下載次數(shù): 51)

作者: 四無青年啦啦啦    時間: 2020-4-17 01:17
源程序怎么下載呀




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1