找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5755|回复: 3
打印 上一主题 下一主题
收起左侧

带动画+频谱的光立方的全套资料(包括原理图和程序)

[复制链接]
跳转到指定楼层
楼主

光立方原理图:


单片机源程序如下:
  1. /*****************************************************************************/
  2. /*                          光立方【动画+频谱】                              */
  3. /* 警    告:                                                                */
  4. /*                                                                           */
  5. /* 芯    片:STC12C5A60S2                                                    */
  6. /* 晶    振:22.1184MHz                                                      */
  7. /* 编 译 器:KEIL 4                                                          */
  8. /* 占用资源:data=9  xdata=702  code=13530                                   */
  9. /*                                                                           */
  10. /* 驱动芯片:ULN2803 + 74HC573(并行数据端口)                               */
  11. /* 驱动类型:64×8                                                            */  
  12. /*                                                                           */
  13. /* 说    明:动画+频谱                                                       */
  14. /*                                                                           */
  15. /* 修改记录                                                                  */
  16. /* 2013-08-21 修改端口                                                       */
  17. /*****************************************************************************/
  18. #include <intrins.h>         //
  19. #include"STC12C5A60S2.H" //芯片头文件
  20. #include"FFT.H"                         //FFT(快速傅里叶变换)功能头文件
  21. #include"key.h"                         //按键扫描头文件
  22. #include"zimo.h"                 //
  23. #include"hc573.h"                 //hc573驱动
  24. #include"flash.h"                 //



  25. //定义ULN2803数据端口
  26. #define anum P3

  27. //指示用LED(未使用)
  28. sbit  LED =P1^3;

  29. //变量区分定时器0功能(0:用于音乐频谱,1:用于动画)
  30. uchar flag1;


  31. //uchar COUNT=15;
  32. //uchar COUNT1=0;
  33. uchar ADC_Count=0,LINE=15,G=0,T;

  34. //uchar code tablew[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
  35. //uchar code tablew[]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};
  36. //uchar code tablew[]={0xff,0x7f,0x3f,0x1f,0x0f,0x07,0x03,0x01};

  37. uchar code tablew[]={0x00,0x80,0xC0,0xE0,0xF0,0xF8,0xFC,0xFE};

  38. uchar G;
  39. uchar buffer[8];

  40. //功能初始化
  41. void Init()
  42. {  
  43.         //IO口默认状态
  44.         P0 = 0x00; //74HC573数据口
  45.         P2 = 0x00; //74HC573位选端
  46.         P3 = 0x00; //ULN2803数据口

  47.         //IO口模式初始化
  48.         P3M0 = 0xff; //ULN2803输出口设置为推挽输出
  49.         P3M1 = 0x00;
  50.         P0M0 = 0xff; //P0、P2用于控制74HC573,推挽输出
  51.         P0M1 = 0x00;
  52.         P2M0 = 0xff;
  53.         P2M1 = 0x00;
  54.         P4M0 = 0x00; //P4端口接有按键,设置为输入
  55.         P4M1 = 0xff;

  56.         //573初始化
  57.         initial573();
  58.        
  59. //----- ADC初始化 ------------------------------------------------------------------------------
  60.         P1ASF  = 0x02;          //0000,0010, 将 P1.1 置成模拟口
  61.         AUXR1 &=0xFB;           //1111,1011, 令 ADRJ=0
  62.         EADC   =1;                                //AD中断打开
  63.         ADC_CONTR = ADC_POWER | ADC_SPEEDHH | ADC_START | channel; //1110 1001   1打开 A/D (ADC_POWER)转换电源;11速度为90周期一次;
  64.                                                                            //0中断标志清零;1启动adc(ADC_START);001AD通道打开(这里为P1.1);
  65. //----- 定时器初始化 ------------------------------------------------------------------------------
  66.         //TMOD=0X12;                                          
  67.         //TH0=0xf0;                                                                   
  68.         //TL0=0xf0;
  69.        
  70.         //TH1=0xfe;                                                                                                  
  71.         //TL1=0Xd4;

  72.         ET0 = 1;                          //定时器0中断 启用
  73.         TR0 = 0;                          //定时器0     关闭
  74.         ET1 = 1;                          //定时器1中断 启用
  75.         TR1 = 0;              //定时器1     关闭
  76.         PT1 = 0;                          //定时器1 低优先级
  77.         PT0 = 1;                           //定时器0 高优先级
  78.         IPH = PADCH;
  79.         IP  = PADC;                          //中断优先级
  80.         EA  = 1;                          //总中断打开
  81.         clear(0);                          //清空显示缓冲区

  82.         //按键设置
  83.         P4SW = 0x70; //将NA、ALE、EX_LVD设置为准IO口(P4.4、P4.5、P4.6)
  84. }


  85. /******** 主函数 ***************************************************************************************/
  86. void main()
  87. {
  88.         uchar i = 0; //for循环变量

  89.         //设备初始化
  90.         Init();

  91.         //正常工作循环
  92.         while(1)
  93.         {                                       
  94.                 clear(0);        //清空刷新显示缓冲区
  95.                 key_scan();        //扫描按键

  96.                 //关闭显示
  97.                 if(key1flag==1)
  98.                 {
  99.                         key1flag = 0;

  100.                         xiansi1();         //关闭所有573输出
  101.                         anum = 0xff; //关闭ULN2083输出
  102.                         TR1  = 0;         //定时器1 关闭
  103.                         TR0  = 0;         //定时器0 关闭
  104.                 }

  105.                 //FFT
  106.                 if(key2flag==1)
  107.                 {
  108.                         TMOD = 0x12; //T0: 8位自动重装      T1: 16位模式
  109.                         //TH0  = 0xb0; //ADC采样周期(80us或6.66us)  采样率 12.5 KHz                                                                
  110.                         //TL0  = 0xb0; //
  111.                         TH0  = 0x60; //ADC采样周期(80us或6.66us)  采样率 12.5 KHz                                                                
  112.                         TL0  = 0x60; //
  113.                         //TH1  = 0xfe; //刷新显示周期(300us或25us)         刷新率                                                                                   
  114.                         //TL1  = 0Xd4; //
  115.                         TH1  = 0xfd; //刷新显示周期(300us或25us)         刷新率                                                                                   
  116.                         TL1  = 0Xa8; //
  117.                                                
  118.                         while(1)
  119.                         {
  120.                                 flag1 = 0;
  121.                                 TR1   = 1; //刷新显示
  122.                                 TR0   = 1; //控制采样速率
  123.                                 //P0    = 0xaa; //P0 未知作用1010 1010
  124.                                 ADC_Count=0;
  125.                                
  126.                                 TR1  = 1;     //开启定时器中断1
  127.                                 TR0  = 1;     //开启定时器中断0
  128.                                 EADC = 1;          //开启ADC
  129.                                 while(ADC_Count<128); //转换128次
  130.                                 for(i=0;i<128;i++)          //FFT参数虚部赋值
  131.                                 {
  132.                                         Fft_Image[i]=0;          //原始数据 虚部赋值为0
  133.                                 }
  134.                                 FFT();                //FFT运算并转换为各频段幅值       

  135.                                 //其他按钮,跳出
  136.                                 key_scan();
  137.                                 if(key2flag == 0) break;
  138.                         }                                                                                                                                                                                                                                                                                                                                               
  139.                 }

  140.                 //顺序循环
  141.                 if(key3flag==1)
  142.                 {
  143.                         TMOD=0x11;
  144.                        
  145.                         while(1)
  146.                         {
  147.                                 clear(0);
  148.                                 flag1=1;  //定时器0功能控制
  149.                                 TR1=0;          //关闭定时器1
  150.                                 TR0=1;          //开启定时器0
  151.                                 //TH0=0xf0;
  152.                                 //TL0=0xff;

  153.                                 flash_6();
  154.                                 clear(0); key_scan(); if(key3flag == 0) break;
  155.                                 flash_5();
  156.                                 clear(0); key_scan(); if(key3flag == 0) break;
  157.                                 flash_1();
  158.                                 clear(0); key_scan(); if(key3flag == 0) break;
  159.                                 flash_2();
  160.                                 clear(0); key_scan(); if(key3flag == 0) break;
  161.                                 flash_4();
  162.                                 clear(0); key_scan(); if(key3flag == 0) break;
  163.                                 flash_3();
  164.                                 clear(0); key_scan(); if(key3flag == 0) break;
  165.                                 flash_8();
  166.                                 clear(0); key_scan(); if(key3flag == 0) break;
  167.                                 flash_7();
  168.                                 clear(0); key_scan(); if(key3flag == 0) break;
  169.                                 flash_11();
  170.                                 clear(0); key_scan(); if(key3flag == 0) break;
  171.                                 flash_9();
  172.                                 clear(0); key_scan(); if(key3flag == 0) break;
  173.                                 flash_10();
  174.                                 clear(0); key_scan(); if(key3flag == 0) break;
  175.                                 flash_11();
  176.                                 clear(0); key_scan(); if(key3flag == 0) break;
  177.                                 flash_6();
  178.                                 clear(0); key_scan(); if(key3flag == 0) break;
  179.                                 flash_5();
  180.                                 clear(0); key_scan(); if(key3flag == 0) break;
  181.                                 flash_4();
  182.                                 clear(0); key_scan(); if(key3flag == 0) break;
  183.                                 flash_7();
  184.                                 clear(0); key_scan(); if(key3flag == 0) break;
  185.                                 flash_9();
  186.                                 clear(0); key_scan(); if(key3flag == 0) break;
  187.                                 flash_8();
  188.                                 clear(0); key_scan(); if(key3flag == 0) break;
  189.                                 flash_4();
  190.                                 clear(0); key_scan(); if(key3flag == 0) break;
  191.                                 flash_2();
  192.                                 clear(0); key_scan(); if(key3flag == 0) break;

  193.                                         
  194.                         }                               
  195.                 }
  196.         }                
  197. }


  198. //定时器1中断 用于刷新显示(只在频谱显示时使用)
  199. void LED_Display() interrupt 3                                         //中断一次显示一列
  200. {                  
  201.         //TH1=0xfe;
  202.         //TL1=0xD4;
  203.         TH1  = 0xfd; //刷新显示周期(300us或25us)         刷新率                                                                                   
  204.         TL1  = 0Xa8; //
  205.        
  206.         G++;                                                         
  207.         if(G>=17) G=1;
  208.         switch(G)                                                                     //往点阵屏填充一列的数据
  209.         {               
  210.                 case 1: anum=tablew[(LED_TAB[1] )%8];hang1();break;         //(LED_TAB[1] )%8取八的余数
  211.                 case 2: anum=tablew[(LED_TAB[2] )%8];hang1();break;
  212.                 case 3: anum=tablew[(LED_TAB[3] )%8];hang2();break;
  213.                 case 4: anum=tablew[(LED_TAB[4] )%8];hang2();break;
  214.                 case 5: anum=tablew[(LED_TAB[5] )%8];hang3();break;
  215.                 case 6: anum=tablew[(LED_TAB[6] )%8];hang3();break;
  216.                 case 7: anum=tablew[(LED_TAB[7] )%8];hang4();break;
  217.                 case 8: anum=tablew[(LED_TAB[8] )%8];hang4();break;
  218.                 case 9: anum=tablew[(LED_TAB[9] )%8];hang5();break;
  219.                 case 10:anum=tablew[(LED_TAB[10])%8];hang5();break;
  220.                 case 11:anum=tablew[(LED_TAB[11])%8];hang6();break;
  221.                 case 12:anum=tablew[(LED_TAB[12])%8];hang6();break;
  222.                 case 13:anum=tablew[(LED_TAB[13])%8];hang7();break;
  223.                 case 14:anum=tablew[(LED_TAB[14])%8];hang7();break;
  224.                 case 15:anum=tablew[(LED_TAB[15])%8];hang8();break;
  225.                 case 16:anum=tablew[(LED_TAB[15])%8];hang8();break;
  226.         }       
  227.         LED=0;         
  228. }               


  229. //ADC转换完成中断
  230. void ADC_Finish() interrupt 5
  231. {          
  232.         ADC_CONTR &= !ADC_FLAG;
  233.         Fft_Real[LIST_TAB[ADC_Count]] = (int)((ADC_RES)<<1)+(ADC_RESL>>1)*2;     //按LIST_TAB表里的顺序,进行存储采样值

  234.         if(ADC_Count<=127){ ADC_Count++;  }
  235.         else              { EADC=0;TR0=0; }                                                                                                                   
  236. ……………………

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

所有资料51hei提供下载:
光立方(频谱 动画 夜光灯).zip (1.59 MB, 下载次数: 77)


评分

参与人数 1黑币 +1 收起 理由
yyhyyhyyh + 1

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:244589 发表于 2017-11-24 10:42 | 只看该作者
下载了两次,第一次下载后解压不了,第二次才成功下载了,然后下载后发现里面没有代码文件(不是说全部抄袭你的代码,只是让我这种新手写整个代码很难写好),上面楼主给的代码也只有一部分。希望楼主能共享一下
回复

使用道具 举报

板凳
ID:476297 发表于 2019-3-6 23:55 | 只看该作者
学习光立方中
回复

使用道具 举报

地板
ID:343137 发表于 2019-8-1 08:10 | 只看该作者
想把套件的改成有频谱的来看看程序
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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