找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 34434|回复: 114
收起左侧

DIY音乐频谱8*16(超简单,带PCB 原理图 程序和教程)

  [复制链接]
ID:56580 发表于 2013-12-3 11:14 | 显示全部楼层 |阅读模式
超简单的音乐频谱8*16 diy,带PCB 原理图 程序和制作教程


0.png 1.png

下面是主程序(完整代码在本帖最后附件里面下载):
  1. #include "src\STC12C5A.h"                 

  2. #include <intrins.h>      //51基本运算(包括_nop_空函数)
  3. #include <math.h>

  4. #include "src\Define.h"


  5. ///////全局变量///////
  6. uchar data DelayTime=9;          //<=8效果最好;
  7. uchar data INTTime=0x40;  //0x40;       
  8. uchar data gain=6;
  9. uchar data Menu=2;
  10. uchar idata refreshflag[40];
  11. uchar  data LEDBuf[35];          //15列;从左到右;亮的位为真(1);
  12. uint32  data TouchKey=0;
  13. uchar data CBeep=0;
  14. //////////////////////


  15. void Delays(uint t)
  16. {  
  17.         uint j;
  18.         while(--t)
  19.                 for(j=0;j<5;j++);   
  20. }
  21. void Delaysms(uint t)
  22. {  
  23.         uint j;
  24.         while(--t)
  25.                 for(j=0;j<15;j++);   
  26. }



  27. #include "src\ADC.c"
  28. #include "src\Font.c"
  29. #include "src\fft.h"



  30. void PWM_init (void)          //PWM初始化函数         //PWM模式,接P1.3接口(PWM0),强上拉.
  31. {                  
  32.         CMOD=0x00;    //设置PCA定时器          0x00~0x03;
  33.         CL=0xEF;
  34.         CH=0xEF;
  35.         CCAPM0=0x42; //PWM0设置PCA工作方式为PWM方式(0100 0010)
  36.         CCAP0L=0xEF; //设置PWM0初始值与CCAP0H相同
  37.         CCAP0H=0xFF; // PWM0初始时为0

  38.         CR=1;        //启动PCA定时器
  39. }

  40. void PWM0_set (uchar set)           //PWM0占空比设置函数        (0x00~0xFF)
  41. {
  42.         CCAP0L= set; //设置值写入CCAP0L
  43.         CCAP0H= set; //设置值写入CCAP0H
  44. }


  45. void IOINIT(void)                                                          //I/O强上拉模式;
  46. {
  47.         P4SW = 0xff;                                  //启动I/O:P4;
  48.         P4M1 = B(00000000); P4M0 = B(10000000);P47=0;//震动马达;
  49.         P0M1 = 0x00;            P0M0 = 0xff;       P0=0; //点阵列(Y)(L:OFF; H,H+:ON,ON+;)
  50.         P1M1 = B(01000011); P1M0 = B(00110100);P1=B(10110111); //(P17@(高阻,IN)&P16@(高阻,IN);TouchKey) ... P14@(传统IO,Beep,IN) P13@(强推,OUT)呼吸灯 ... P11@(高阻,IN)AD2;P10@(高阻,IN)AD1;      
  51.         P2M1 = B(00000000); P2M0 = B(11111111);P2=0; //点阵行(X0(Left))(L:OFF; H,H+:ON,ON+;)  
  52.         P3M1 = B(00000000);        P3M0 = B(11111111);P3=0; //点阵行(X1(Right))(L:OFF; H,H+:ON,ON+;)               
  53.         P1ASF =B(00000011);                          //将P10,P11的IO设置为模拟输入功能;     

  54. //  Y(P0)
  55. //  ↑
  56. //H        |
  57. //         |
  58. //        |
  59. //L        |
  60. //         ---------------------→
  61. //        [L:X0(P2):H][L:X1(P3):H]

  62. //TestCode:
  63. //        P0=B(10000000);
  64. //        P2=B(00000001);
  65. //        P3=B(00010000);

  66. }



  67. void BufToLED_Refresh()                     //Refresh&Write Buf to LED ;
  68. {       
  69.          uchar data i;
  70.          uchar data X=1;          
  71.          uchar data Y=1;
  72.          for(X=1,i=2;X;X<<=1,i+=2)              //for(X=1;X!=0;X<<=1) //8bit
  73.          {
  74.                   P2=X;
  75.                 for(Y=1;Y!=0;Y<<=1)                            //Y=Y<<1;
  76.                  {
  77.                         P0=Y&LEDBuf[i];
  78.                         Delays(DelayTime);
  79.                         P0=0;
  80.                 }
  81.                 P2=0;       
  82.          };
  83.          for(X=1;X<B(10000000);X<<=1,i+=2)            //7bit
  84.          {
  85.                   P3=X;
  86.                 for(Y=1;Y!=0;Y<<=1)                            //Y=Y<<1;
  87.                  {
  88.                         P0=Y&LEDBuf[i];
  89.                         Delays(DelayTime);
  90.                         P0=0;
  91.                 }
  92.                 P3=0;       
  93.          };
  94.                
  95. }




  96. void LEDRefresh_INT() interrupt 3 //using 3   
  97. {
  98.         static uint x=0;                  
  99.         static uchar flag=1;

  100.     TL1 = 0x00;      
  101.     TH1 = INTTime;               //0x50~0x80

  102.         if(flag)
  103.         {
  104.                 if(++x==0xFF)                         //MINOUTPUT
  105.                 {
  106.                         flag=0;               
  107.                 }               
  108.         }
  109.         else
  110.         {
  111.                 if(--x==0xCF)                 //MAXOUTPUT
  112.                 {
  113.                         flag=1;                       
  114.                 }
  115.         }                        
  116.         PWM0_set(x);                 //设置PWM占空比

  117.         BufToLED_Refresh();                        
  118. }  


  119. void Timer_INT()
  120. {
  121.         TMOD = 0x11; //高4位控制T/C1
  122.         EA = 1;             //开总中断
  123.         TH1 = 0x00;  //16位计数寄存器T1高8位
  124.         TL1 = 0x00;  //16位计数寄存器T1低8位
  125.         ET1 = 1;     //T/C1中断开
  126.     TR1 = 1;     //T/C1启动

  127. }


  128. void FullScan()
  129. {
  130.         uchar data X=1;          
  131.         uchar data Y=1;

  132.          for(Y=1;Y!=0;Y<<=1)                       //Y=Y<<1;
  133.          {       
  134.                  P0=Y;
  135.                 for(X=1;X;X<<=1)                   //8bit
  136.                 {
  137.                          P2=X;
  138.                         Delays(7);       
  139.                 };

  140.                 P2=0;
  141.                 for(X=1;X<B(10000000);X<<=1)    //7bit
  142.                 {
  143.                          P3=X;
  144.                         Delays(7);
  145.                 };
  146.                 P3=0;
  147.                 P0=0;
  148.          }
  149. }


  150. void Main()
  151. {  
  152.         uint data Count=700;
  153.         uchar data i,Cgain,num=0;

  154.         IOINIT();
  155.         InitADC();                  

  156.         while(--Count)
  157.                 FullScan();

  158.         for(i=0;i<40;i++) refreshflag[i]=0x09;
  159.        
  160.         P14=0;                          //Beep
  161.         Delays(4000);
  162.         P14=1;

  163.         PWM_init();      //PWM初始化
  164.         PWM0_set(0xFB);
  165.        
  166.         Timer_INT();

  167.         for(i=0;i<34;i++)
  168.                 LEDBuf[i]=0x00;
  169.         FontDisp();

  170.         while(520)
  171.         {
  172.                 for(i=0;i<65;i++)
  173.                 {  
  174.                         dd[i].real=(GetADCResult(0)+GetADCResult(1))<<gain;          //读取ad结果并放大;
  175.                 }

  176.                  processfft();//傅立叶变化及处理

  177.                  ///////////////////TouchKey//////////////////////////
  178.                  while(P16==1)                                           //依据:脉冲 干扰持续时间短;
  179.                  {       
  180.                         if(CBeep)P14=0;
  181.                         if(++TouchKey>0x0000FF00)break;       
  182.                  }
  183.                  P14=1;

  184.                  if(P16==1)
  185.                  {
  186.                         if(++Menu==4)Menu=0;

  187.                         P14=0;
  188.                         P47=1;
  189.                         Delays(7000);          
  190.                         P14=1;
  191.                         P47=0;               
  192.                  }       
  193.                         TouchKey=0;
  194.                  //////////////////////////////////////////////

  195.                 if(P17==0)CBeep=!CBeep;

  196.                  if(dd[2].real<32)
  197.                  {
  198.                          if(++Count==300)          //电平值过小,这降低gain,减少噪音的电平显示;
  199.                          {
  200.                                 Count=0;
  201.                                 //if(++Menu==4)Menu=0;                  //切换Menu,显示方式;
  202.                                 gain=6;

  203.                                 P14=0;                          //Beep
  204.                                 Delays(1000);
  205.                                 P14=1;
  206.                          }
  207.                  }
  208.                  else
  209.                  {
  210.                          Count=1;
  211.        
  212.                          if(++num==0xAF)                         //播放时,Auto gain;
  213.                          {
  214.                                 num=0;

  215.                                 P14=0;                                   //Beep
  216.                                 Delays(700);
  217.                                 P14=1;
  218.                                                            //自动增益;Automatic gain;
  219.                                 Cgain=dd[2].real/32;
  220.                                 if(7<Cgain<=8)
  221.                                 {
  222.                                         gain=4;
  223.                                        
  224.                                 }
  225.                                 else if(4<Cgain<=6)
  226.                                 {
  227.                                         gain=5;
  228.                                        
  229.                                 }
  230.                                 else if(2<Cgain<=4)
  231.                                 {
  232.                                         gain=6;
  233.                                 }
  234.                                 else
  235.                                 {
  236.                                         gain=7;
  237.                        
  238.                                 }
  239.        
  240.                          }

  241.                   }                 
  242.         }
  243.         while(1);
  244. }


复制代码



需要的拿走吧,请多多指教!!


DIY音乐频谱显示资料.zip

4.69 MB, 下载次数: 1021, 下载积分: 黑币 -5

评分

参与人数 2黑币 +55 收起 理由
chtom + 5 很给力!
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:56580 发表于 2013-12-3 22:46 | 显示全部楼层
51hei有你更精彩!!
回复

使用道具 举报

ID:57920 发表于 2013-12-29 10:32 | 显示全部楼层
51hei电子论坛有你更精彩!!!!!!!
回复

使用道具 举报

ID:59170 发表于 2014-2-22 12:04 | 显示全部楼层

谢谢楼主分享
回复

使用道具 举报

ID:60906 发表于 2014-4-20 17:01 | 显示全部楼层
好东西!!!
回复

使用道具 举报

ID:61200 发表于 2014-4-28 17:02 | 显示全部楼层
这个很漂亮啊。感谢分享。
回复

使用道具 举报

ID:63273 发表于 2014-6-24 23:46 | 显示全部楼层
buc可以了。。不错。
回复

使用道具 举报

ID:64606 发表于 2014-8-1 00:01 | 显示全部楼层
好东西
回复

使用道具 举报

ID:64606 发表于 2014-8-1 00:04 | 显示全部楼层
打不开也。。
回复

使用道具 举报

ID:65533 发表于 2014-8-28 16:23 | 显示全部楼层
谢谢分享。自己也想做一个
回复

使用道具 举报

ID:66029 发表于 2014-9-11 15:20 | 显示全部楼层
赞赞赞
回复

使用道具 举报

ID:67370 发表于 2014-10-14 17:21 | 显示全部楼层
下不了
回复

使用道具 举报

ID:67254 发表于 2014-10-16 10:38 | 显示全部楼层
这东西 真心不错哦
回复

使用道具 举报

ID:67647 发表于 2014-10-19 19:37 | 显示全部楼层
还可以吧
回复

使用道具 举报

ID:67922 发表于 2014-10-28 22:26 | 显示全部楼层
好漂亮  学习一下
回复

使用道具 举报

ID:69092 发表于 2014-11-20 12:34 | 显示全部楼层
謝謝分享
回复

使用道具 举报

ID:69803 发表于 2015-5-13 11:15 | 显示全部楼层
不错,不错
回复

使用道具 举报

ID:65980 发表于 2015-5-14 11:17 | 显示全部楼层
资料找不到啊,楼主分享下
回复

使用道具 举报

ID:80547 发表于 2015-5-19 22:36 | 显示全部楼层
谢谢分享,学习下
回复

使用道具 举报

ID:79544 发表于 2015-7-23 11:54 | 显示全部楼层
我下载了怎么编译不了啊?
回复

使用道具 举报

ID:79544 发表于 2015-7-23 11:57 | 显示全部楼层
* RESTRICTED VERSION WITH 0800H BYTE CODE SIZE LIMIT; USED: 0B2AH BYTE (139%) * ****************************************************************************** Program Size: data=132.0 xdata=537 code=4842 LINK/LOCATE RUN COMPLETE.  2 WARNING(S),  0 ERROR(S) *** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS     SEGMENT: ?PR?_SHOWRESULT?PRJ *** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS     SEGMENT: ?PR?INITUART?PRJ *** FATAL ERROR L250: CODE SIZE LIMIT IN RESTRICTED VERSION EXCEEDED     MODULE:  C:\KEIL\C51\LIB\C51L.LIB (-----)     LIMIT:   0800H BYTES Target not created
回复

使用道具 举报

ID:79544 发表于 2015-7-23 11:58 | 显示全部楼层
编译不通过?
回复

使用道具 举报

ID:82982 发表于 2015-7-26 14:02 | 显示全部楼层
怎么感觉反了
回复

使用道具 举报

ID:87240 发表于 2015-7-30 13:26 | 显示全部楼层
这个好!谢谢分享
回复

使用道具 举报

ID:87141 发表于 2015-7-30 19:32 | 显示全部楼层
很好看,挺有意思的。
回复

使用道具 举报

ID:86374 发表于 2015-8-3 22:50 | 显示全部楼层
让我看看怎么样啊,这个有点怪异
回复

使用道具 举报

ID:65533 发表于 2015-10-4 13:05 | 显示全部楼层
自己也想弄一个,下来学习学习。谢谢分享。
回复

使用道具 举报

ID:92462 发表于 2015-10-14 21:14 | 显示全部楼层
怎么不是和音乐同步的
回复

使用道具 举报

ID:79034 发表于 2015-10-29 23:23 | 显示全部楼层
!!!!!!!楼主。。。。。
那个原理图网络都没标记。根本看不明白啊
回复

使用道具 举报

ID:94875 发表于 2015-11-6 14:53 | 显示全部楼层
谢谢楼主分享,嘻嘻
回复

使用道具 举报

ID:96894 发表于 2015-11-24 06:20 | 显示全部楼层
感谢分享,楼主好人呢
回复

使用道具 举报

ID:97407 发表于 2015-11-27 21:34 | 显示全部楼层
不错  我试过
回复

使用道具 举报

ID:92804 发表于 2015-11-27 22:35 | 显示全部楼层
感谢LZ拿走了!!
回复

使用道具 举报

ID:92858 发表于 2015-11-28 12:36 | 显示全部楼层
学习学习哈
回复

使用道具 举报

ID:100772 发表于 2015-12-27 22:12 | 显示全部楼层
你的是不是反掉了
回复

使用道具 举报

ID:64089 发表于 2015-12-28 18:23 | 显示全部楼层
资料是非常好的,值得学习,但是貌似和节奏慢了一点点。
回复

使用道具 举报

ID:101569 发表于 2016-1-2 23:33 | 显示全部楼层
好东西!!!
回复

使用道具 举报

ID:102055 发表于 2016-1-6 12:02 | 显示全部楼层
先赞再下下来用用
回复

使用道具 举报

ID:102055 发表于 2016-1-6 12:04 | 显示全部楼层
为什么我不加积分呢?我要积分啊!!
回复

使用道具 举报

ID:102615 发表于 2016-1-11 15:55 | 显示全部楼层
里面有什么资料喔
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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