找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 6206|回复: 1
收起左侧

16*16全彩点阵屏PCB原理图+单片机源程序

[复制链接]
ID:509200 发表于 2019-4-10 22:02 | 显示全部楼层 |阅读模式
Altium Designer画的16*16全彩点阵屏电路原理图和PCB图如下:(51hei附件中可下载工程文件)
0.png 0.png 0.png

单片机源程序如下:
  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:每个字的显示循环;j每个字的显示码除以2
  5. uint yd1=0;                    //显示偏移控制,char类型最多只能显示14个汉字+一个空白位字符        

  6. sbit hwx=P3^2;                //红外接收数据引脚,
  7. unsigned char l_posit=0;        //显示位置

  8. unsigned char ly_lhj[4];                                        //保存NEC的四个字节数据
  9. bit ly_flag=1;                                                                //成功接收标志

  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,红外接收数据引脚
  151.         IT0=1;                                //设置成下降沿触发方式
  152.         TMOD=0X01;                                //定时器1的方式1,16位计数器,用来计数时间
  153.         aa=0;
  154. }
  155. /***********外中断1入口函数,P33引脚,红外线接收IC数据脚**************************/
  156. void hongwai(void) interrupt 0
  157. {
  158.         unsigned char i,ia;
  159.         /**************开始判断是否为NEC波形引导码的前9MS和后4.5MS******************************/
  160.         TL0=0;
  161.         TH0=0;                                //定时/计数器1初始值
  162.         TR0=1;                                //定时器以12M晶振12分频计数,即1us计数
  163.         while(!hwx);
  164.         TR0=0;                                //信号翻转停止计数
  165.         if(TH0<60||TH0>80)        //NEC引导码前9MS,计数约9000,TH1约等于35,给个误差值,用30-40之间来判断
  166.                 return;

  167.         TH0=0;                                //定时/计数器1初始值
  168.         TR0=1;
  169.         while(hwx){
  170.                 delay(20);
  171.                 if(TH0>44)                //NEC引导码引导码的后4。5MS,计数约4500,TH1约等于17
  172.                         return;               
  173.         }
  174.         TR0=0;
  175.         if(TH0<24)                        //NEC引导码引导码的后4。5MS,计数约4500,TH1约等于17
  176.                 return;

  177.         /***********开始接收四个字节内容**************************************/        
  178.         for(i=0;i<4;i++){
  179.                 for(ia=0;ia<8;ia++){                                
  180.                         while(!hwx);        //低电平开始,不处理只等待高电平
  181.                         
  182.                         TH0=0;
  183.                         TR0=1;                        //高电平开始,启动计数
  184.                         while(hwx){
  185.                                 delay(20);
  186.                                 if(TH0>30)               
  187.                                         return;               
  188.                         }
  189.                         TR0=0;
  190.                         //高电平结束,判断数据1或0向变量移入
  191.                         ly_lhj[i]>>=1;                        //数据由高位移入低位
  192.                         if(TH0>8)                                //时间量TH1高于4,即高于1MS判断为1
  193.                                 ly_lhj[i]|=0x80;
  194.                 }
  195.         }
  196.         ly_flag=1;        //接收成功
  197. ……………………

  198. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
1616全彩.zip (2.86 MB, 下载次数: 113)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:708475 发表于 2020-5-23 22:08 | 显示全部楼层
电子元件表可以发一下么
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表