找回密码
 立即注册

QQ登录

只需一步,快速开始

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

一整套关于光立方的资源 动画+频谱 595 573

[复制链接]
跳转到指定楼层
楼主
ID:294624 发表于 2018-4-26 19:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
包括程序,仿真的代码

单片机源程序如下:
  1. //聚强电子
  2. /*****************************************************************************/
  3. /*                          光立方【动画+频谱】                              */
  4. /* 配    置:                                                                */
  5. /*                                                                           */
  6. /* 芯    片:STC12C5A60S2                                                    */
  7. /* 晶    振:22.1184MHz                                                      */
  8. /* 编 译 器:KEIL 4                                                        */
  9. /* 驱动芯片:ULN2803 + 74HC573(并行数据端口)                               */
  10. /* 驱动类型:64×8                                                            */  
  11. /*                                                                           */
  12. /* 说    明:动画+频谱                                                       */
  13. /*                                                                           */
  14. /*****************************************************************************/
  15. #include <intrins.h>         //
  16. #include"STC12C5A60S2.H" //芯片头文件
  17. #include"FFT.H"                         //FFT(快速傅里叶变换)功能头文件
  18. #include"key.h"                         //按键扫描头文件
  19. #include"zimo.h"                 //
  20. #include"hc573.h"                 //hc573驱动
  21. #include"flash.h"                 //



  22. //定义ULN2803数据端口
  23. #define anum P3

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

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


  28. //uchar COUNT=15;
  29. //uchar COUNT1=0;
  30. uchar ADC_Count=0,LINE=15,G=0,T;

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

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

  35. uchar G;
  36. uchar buffer[8];

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

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

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

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

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


  82. /******** 主函数 ***************************************************************************************/
  83. void main()
  84. {
  85.         uchar i = 0; //for循环变量

  86.         //设备初始化
  87.         Init();

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

  93.                 //关闭显示
  94.                 if(key1flag==1)
  95.                 {
  96.                         key1flag = 0;

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

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

  132.                                 //其他按钮,跳出
  133.                                 key_scan();
  134.                                 if(key2flag == 0) break;
  135.                         }                                                                                                                                                                                                                                                                                                                                               
  136.                 }

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

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

  190.                                         
  191.                         }                               
  192.                 }
  193.         }                
  194. }


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


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

  231.         if(ADC_Count<=127){ ADC_Count++;  }
  232.         else              { EADC=0;TR0=0; }                                                                                                                   
  233. ……………………

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

所有资料51hei提供下载:
光立方源程序 动画 频谱 595 573.rar (135.12 KB, 下载次数: 30)


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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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