標(biāo)題: 16*16全彩點(diǎn)陣屏PCB原理圖+單片機(jī)源程序 [打印本頁]

作者: 19937676606    時間: 2019-4-10 22:02
標(biāo)題: 16*16全彩點(diǎn)陣屏PCB原理圖+單片機(jī)源程序
Altium Designer畫的16*16全彩點(diǎn)陣屏電路原理圖和PCB圖如下:(51hei附件中可下載工程文件)


單片機(jī)源程序如下:
  1. #define uchar unsigned char
  2. #define        uint unsigned int
  3. uchar dd,ee,m1=0,m2=1,m3=2,m4=3,m5=4,m6=5,m7,m8,m9,m10,m11,m12,m13,m14,m15,m16;
  4. uchar yd,xh,xh1;        //yd控制移動間隔時間i:每個字的顯示循環(huán);j每個字的顯示碼除以2
  5. uint yd1=0;                    //顯示偏移控制,char類型最多只能顯示14個漢字+一個空白位字符        

  6. sbit hwx=P3^2;                //紅外接收數(shù)據(jù)引腳,
  7. unsigned char l_posit=0;        //顯示位置

  8. unsigned char ly_lhj[4];                                        //保存NEC的四個字節(jié)數(shù)據(jù)
  9. bit ly_flag=1;                                                                //成功接收標(biāo)志

  10. sbit STTP = P4^2;
  11. sbit key1=P4^3;

  12. sbit aa=P4^0;
  13. sbit a1=P2^0;
  14. sbit a2=P2^1;
  15. sbit a3=P2^2;
  16. sbit a4=P2^3;

  17. sbit bb=P0^4;
  18. sbit b1=P0^0;
  19. sbit b2=P0^1;
  20. sbit b3=P0^2;
  21. sbit b4=P0^3;

  22. sbit cc=P0^5;
  23. sbit c1=P2^4;
  24. sbit c2=P2^5;
  25. sbit c3=P2^6;
  26. sbit c4=P2^7;


  27. void delay(uint c)
  28. {
  29.         int i,j;
  30.         for(i=0;i<c;i++)
  31.         for(j=0;j<1;j++);
  32. }
  33. void out_rxd(uchar *d)
  34. {
  35.         SBUF=*d;
  36.         while(TI==0);
  37.         TI=0;               
  38. }
  39. void mm1()
  40. {
  41.         if(m1==1){aa=0;bb=1;cc=1;}
  42.         if(m1==2){aa=0;bb=0;cc=1;}
  43.         if(m1==3){aa=1;bb=0;cc=1;}
  44.         if(m1==4){aa=1;bb=0;cc=0;}
  45.         if(m1==5){aa=1;bb=1;cc=0;}
  46.         if(m1==6){aa=0;bb=1;cc=0;}
  47. }
  48. void mm2()
  49. {
  50.         if(m2==1){aa=0;bb=1;cc=1;}
  51.         if(m2==2){aa=0;bb=0;cc=1;}
  52.         if(m2==3){aa=1;bb=0;cc=1;}
  53.         if(m2==4){aa=1;bb=0;cc=0;}
  54.         if(m2==5){aa=1;bb=1;cc=0;}
  55.         if(m2==6){aa=0;bb=1;cc=0;}
  56. }
  57. void mm3()
  58. {
  59.         if(m3==1){aa=0;bb=1;cc=1;}
  60.         if(m3==2){aa=0;bb=0;cc=1;}
  61.         if(m3==3){aa=1;bb=0;cc=1;}
  62.         if(m3==4){aa=1;bb=0;cc=0;}
  63.         if(m3==5){aa=1;bb=1;cc=0;}
  64.         if(m3==6){aa=0;bb=1;cc=0;}
  65. }
  66. void mm4()
  67. {
  68.         if(m4==1){aa=0;bb=1;cc=1;}
  69.         if(m4==2){aa=0;bb=0;cc=1;}
  70.         if(m4==3){aa=1;bb=0;cc=1;}
  71.         if(m4==4){aa=1;bb=0;cc=0;}
  72.         if(m4==5){aa=1;bb=1;cc=0;}
  73.         if(m4==6){aa=0;bb=1;cc=0;}
  74. }
  75. void mm5()
  76. {
  77.         if(m5==1){aa=0;bb=1;cc=1;}
  78.         if(m5==2){aa=0;bb=0;cc=1;}
  79.         if(m5==3){aa=1;bb=0;cc=1;}
  80.         if(m5==4){aa=1;bb=0;cc=0;}
  81.         if(m5==5){aa=1;bb=1;cc=0;}
  82.         if(m5==6){aa=0;bb=1;cc=0;}
  83. }
  84. void mm6()
  85. {
  86.         if(m6==1){aa=0;bb=1;cc=1;}
  87.         if(m6==2){aa=0;bb=0;cc=1;}
  88.         if(m6==3){aa=1;bb=0;cc=1;}
  89.         if(m6==4){aa=1;bb=0;cc=0;}
  90.         if(m6==5){aa=1;bb=1;cc=0;}
  91.         if(m6==6){aa=0;bb=1;cc=0;}
  92. }

  93. void xianshi()
  94. {
  95.         for(xh=0;xh<16;xh++)
  96.         {
  97.                 if(xh==0){a1=b1=c1=0;a2=b2=c2=0;a3=b3=c3=0;a4=b4=c4=0;mm1();}
  98.                 if(xh==1){a1=b1=c1=1;a2=b2=c2=0;a3=b3=c3=0;a4=b4=c4=0;mm2();}
  99.                 if(xh==2){a1=b1=c1=0;a2=b2=c2=1;a3=b3=c3=0;a4=b4=c4=0;mm3();}
  100.                 if(xh==3){a1=b1=c1=1;a2=b2=c2=1;a3=b3=c3=0;a4=b4=c4=0;mm4();}
  101.                 if(xh==4){a1=b1=c1=0;a2=b2=c2=0;a3=b3=c3=1;a4=b4=c4=0;mm5();}
  102.                 if(xh==5){a1=b1=c1=1;a2=b2=c2=0;a3=b3=c3=1;a4=b4=c4=0;mm6();}
  103.                 if(xh==6){a1=b1=c1=0;a2=b2=c2=1;a3=b3=c3=1;a4=b4=c4=0;mm1();}
  104.                 if(xh==7){a1=b1=c1=1;a2=b2=c2=1;a3=b3=c3=1;a4=b4=c4=0;mm2();}
  105.                 if(xh==8){a1=b1=c1=0;a2=b2=c2=0;a3=b3=c3=0;a4=b4=c4=1;mm3();}
  106.                 if(xh==9){a1=b1=c1=1;a2=b2=c2=0;a3=b3=c3=0;a4=b4=c4=1;mm4();}
  107.                 if(xh==10){a1=b1=c1=0;a2=b2=c2=1;a3=b3=c3=0;a4=b4=c4=1;mm5();}
  108.                 if(xh==11){a1=b1=c1=1;a2=b2=c2=1;a3=b3=c3=0;a4=b4=c4=1;mm6();}
  109.                 if(xh==12){a1=b1=c1=0;a2=b2=c2=0;a3=b3=c3=1;a4=b4=c4=1;mm1();}
  110.                 if(xh==13){a1=b1=c1=1;a2=b2=c2=0;a3=b3=c3=1;a4=b4=c4=1;mm2();}
  111.                 if(xh==14){a1=b1=c1=0;a2=b2=c2=1;a3=b3=c3=1;a4=b4=c4=1;mm3();}
  112.                 if(xh==15){a1=b1=c1=1;a2=b2=c2=1;a3=b3=c3=1;a4=b4=c4=1;mm4();}


  113.                 STTP=0;
  114.                 out_rxd(&hanzi[3][xh1+yd1+1]);
  115.                 out_rxd(&hanzi[3][xh1+yd1]);
  116.                 out_rxd(&hanzi[2][xh1+yd1+1]);
  117.                 out_rxd(&hanzi[2][xh1+yd1]);
  118.                 out_rxd(&hanzi[1][xh1+yd1+1]);
  119.                 out_rxd(&hanzi[1][xh1+yd1]);
  120.                 out_rxd(&hanzi[0][xh1+yd1+1]);
  121.                 out_rxd(&hanzi[0][xh1+yd1]);
  122.                 STTP=1;
  123.                 delay(10);
  124.                 STTP=0;
  125.                 out_rxd(&hanzi[3][0]);
  126.                 out_rxd(&hanzi[3][0]);
  127.                 out_rxd(&hanzi[2][0]);
  128.                 out_rxd(&hanzi[2][0]);
  129.                 out_rxd(&hanzi[1][0]);
  130.                 out_rxd(&hanzi[1][0]);
  131.                 out_rxd(&hanzi[0][0]);
  132.                 out_rxd(&hanzi[0][0]);
  133.                 STTP=1;               
  134.                 xh1=xh1+2;
  135.         }
  136.         yd++;
  137.         xh1=0;
  138.         if(yd>ee)        //移動間隔時間;取值0--255
  139.         {
  140.                 yd=0;yd1=yd1+32;
  141.                 if(yd1>896){yd1=32;}
  142.                 m1++;m2++;m3++;m4++;m5++;m6++;
  143.                 if(m1>5)m1=0;if(m2>5)m2=0;if(m3>5)m3=0;
  144.                 if(m4>5)m4=0;if(m5>5)m5=0;if(m6>5)m6=0;        
  145.         }
  146. }

  147. void zd()
  148. {
  149.         EA=1;                                        //首先開啟總中斷
  150.         EX0=1;                                  //開啟外部中斷1,紅外接收數(shù)據(jù)引腳
  151.         IT0=1;                                //設(shè)置成下降沿觸發(fā)方式
  152.         TMOD=0X01;                                //定時器1的方式1,16位計(jì)數(shù)器,用來計(jì)數(shù)時間
  153.         aa=0;
  154. }
  155. /***********外中斷1入口函數(shù),P33引腳,紅外線接收IC數(shù)據(jù)腳**************************/
  156. void hongwai(void) interrupt 0
  157. {
  158.         unsigned char i,ia;
  159.         /**************開始判斷是否為NEC波形引導(dǎo)碼的前9MS和后4.5MS******************************/
  160.         TL0=0;
  161.         TH0=0;                                //定時/計(jì)數(shù)器1初始值
  162.         TR0=1;                                //定時器以12M晶振12分頻計(jì)數(shù),即1us計(jì)數(shù)
  163.         while(!hwx);
  164.         TR0=0;                                //信號翻轉(zhuǎn)停止計(jì)數(shù)
  165.         if(TH0<60||TH0>80)        //NEC引導(dǎo)碼前9MS,計(jì)數(shù)約9000,TH1約等于35,給個誤差值,用30-40之間來判斷
  166.                 return;

  167.         TH0=0;                                //定時/計(jì)數(shù)器1初始值
  168.         TR0=1;
  169.         while(hwx){
  170.                 delay(20);
  171.                 if(TH0>44)                //NEC引導(dǎo)碼引導(dǎo)碼的后4。5MS,計(jì)數(shù)約4500,TH1約等于17
  172.                         return;               
  173.         }
  174.         TR0=0;
  175.         if(TH0<24)                        //NEC引導(dǎo)碼引導(dǎo)碼的后4。5MS,計(jì)數(shù)約4500,TH1約等于17
  176.                 return;

  177.         /***********開始接收四個字節(jié)內(nèi)容**************************************/        
  178.         for(i=0;i<4;i++){
  179.                 for(ia=0;ia<8;ia++){                                
  180.                         while(!hwx);        //低電平開始,不處理只等待高電平
  181.                         
  182.                         TH0=0;
  183.                         TR0=1;                        //高電平開始,啟動計(jì)數(shù)
  184.                         while(hwx){
  185.                                 delay(20);
  186.                                 if(TH0>30)               
  187.                                         return;               
  188.                         }
  189.                         TR0=0;
  190.                         //高電平結(jié)束,判斷數(shù)據(jù)1或0向變量移入
  191.                         ly_lhj[i]>>=1;                        //數(shù)據(jù)由高位移入低位
  192.                         if(TH0>8)                                //時間量TH1高于4,即高于1MS判斷為1
  193.                                 ly_lhj[i]|=0x80;
  194.                 }
  195.         }
  196.         ly_flag=1;        //接收成功
  197. ……………………

  198. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼

所有資料51hei提供下載:
1616全彩.zip (2.86 MB, 下載次數(shù): 114)



作者: 779899166    時間: 2020-5-23 22:08
電子元件表可以發(fā)一下么




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