久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 23084|回復(fù): 34
打印 上一主題 下一主題
收起左側(cè)

基于51單片機(jī)的音樂(lè)頻譜制作

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
這是我焊接的系統(tǒng)的正面圖
這是系統(tǒng)的背面圖

主函數(shù)程序部分:
單片機(jī)源程序如下:
  1. #include "src\STC12C5A.h"                 

  2. #include <intrins.h>      //51基本運(yùn)算(包括_nop_空函數(shù))
  3. #include <math.h>

  4. #include "src\Define.h"

  5. ///////全局變量///////
  6. uchar data DelayTime=9;                 
  7. uchar data gain=6,tt=0;

  8. uchar idata refreshflag[40];
  9. uchar  data LEDBuf[35];          //15列;從左到右;亮的位為真(1);

  10. #include "src\ADC.c"
  11. #include "src\fft.h"

  12. uchar code ax[]={0,0,0,0,0,0,0,0,                                   //“愛(ài)心”圖標(biāo)數(shù)組
  13.                                  0,0,0,0,0,0,0,0,                       
  14. 0x00,0x00,0x00,0x70,0xF8,0xFC,0xFE,0x7F,0x7F,0x7F,0xFE,0xFC,0xF8,0x70,0x00,0x00,
  15.                                  0,0,0,0,0,0,0,0,
  16.                              0,0,0,0,0,0,0,0,
  17.                                 };

  18. void Delays(uint t)                  //延時(shí)函數(shù)
  19. {  
  20.         uint j;
  21.         while(--t)
  22.         {
  23.                 for(j=0;j<5;j++);
  24.         }   
  25. }

  26. void IOINIT()                //初始化IO口工作模式
  27. {
  28.         P0M1 = 0x00;            P0M0 = 0xff;       P0=0; //點(diǎn)陣列(Y)(L:OFF; H,H+:ON,ON+;)
  29.         P1M1 = B(01000011); P1M0 = B(00110000);P1=B(10111111); //(P17@(高阻,IN)&P16@(高阻,IN) ... P11@(高阻,IN)AD2;P10@(高阻,IN)AD1;      
  30.         P2M1 = B(00000000); P2M0 = B(11111111);P2=0; //點(diǎn)陣行(X0(Left))(L:OFF; H,H+:ON,ON+;)  
  31.         P3M1 = B(00000000);        P3M0 = B(11111111);P3=0; //點(diǎn)陣行(X1(Right))(L:OFF; H,H+:ON,ON+;)               
  32.         P1ASF =B(00000011);                          //將P10,P11的IO設(shè)置為模擬輸入功能;     
  33. }

  34. void BufToLED_Refresh()                //把LEDBuf的數(shù)值數(shù)據(jù)傳到P0,通過(guò)LED顯示出來(lái)
  35. {       
  36.          uchar data i;                 //定義循環(huán)變量i               
  37.          uint temp=0x7fff;         //定義temp       

  38.          for(i=0;i<32;i+=2)        //循環(huán)16次操作
  39.          {
  40.                  P0=0x00;                  //P0輸出低電平
  41.                 P2=temp/256;         //P2為前8位
  42.                 P3=temp%256;        //P3為后8位
  43.                 P0=~LEDBuf[i];        //調(diào)用LEDBuf數(shù)組取反       
  44.                 Delays(DelayTime);        //延時(shí)一下
  45.                 P2=0xff;                 //消隱       
  46.                 P3=0xff;                   //消隱
  47.                 temp>>=1;                //右移一位       
  48.                 temp|=0x8000;        //目的是為從左到右依次允許點(diǎn)亮LED(列)提供條件       
  49.          }
  50. }

  51. void LOVE()         //“愛(ài)心”圖標(biāo)顯示
  52. {       
  53.          uchar data i;                   //定義循環(huán)變量i
  54.          uint temp=0x7fff;         //定義temp

  55.          for(i=0;i<16;i++)        //循環(huán)16次操作
  56.          {
  57.                  P0=0x00;                //P0輸出低電平
  58.                 P2=temp/256;          //P2為前8位
  59.                 P3=temp%256;        //P3為后8位
  60.                 P0=ax[i+tt];          //調(diào)用“愛(ài)心”圖標(biāo)數(shù)據(jù)
  61.                 Delays(DelayTime);         //延時(shí)一下
  62.                 P2=0xff;                   //消隱
  63.                 P3=0xff;                //消隱
  64.                 temp>>=1;                   //右移一位
  65.                 temp|=0x8000;          //目的是為從左到右依次允許點(diǎn)亮LED(列)提供條件
  66.          }
  67. }

  68. void Timer_INT()        //定時(shí)器初始化
  69. {
  70.         TMOD = 0x10; //高4位控制T/C1
  71.         EA = 1;             //開(kāi)總中斷
  72.         TH1 = 0x00;  //16位計(jì)數(shù)寄存器T1高8位
  73.         TL1 = 0x00;  //16位計(jì)數(shù)寄存器T1低8位
  74.         ET1 = 1;     //T/C1中斷開(kāi)
  75.     TR1 = 1;     //T/C1啟動(dòng)
  76. }

  77. void ax_xs()                  //愛(ài)心顯示
  78. {
  79.         uint pp=4000;        //定義pp=4000
  80.         while(pp--)                //如果PP減1后為真(即pp減1后不為0,直到pp=0才跳出while循環(huán))
  81.         {
  82.                 if(pp%250==0)        //如果PP/250,余數(shù)為0(即pp能被250整除)
  83.                 {
  84.                         tt++;                //tt加1
  85.                 }
  86.                 LOVE();                         //“愛(ài)心”圖標(biāo)顯示
  87.         }
  88.         pp=4000;                         //pp重新賦值0                                      
  89.         while(pp--)                //如果PP減1后為真(即pp減1后不為0,直到pp=0才跳出while循環(huán))
  90.         {
  91.                 LOVE();                 //“愛(ài)心”圖標(biāo)顯示
  92.         }
  93.         pp=4000;                   //pp重新賦值0
  94.         while(pp--)                //如果PP減1后為真(即pp減1后不為0,直到pp=0才跳出while循環(huán))
  95.         {
  96.                 if(pp%250==0)        //如果PP/250,余數(shù)為0(即pp能被250整除)
  97.                 {
  98.                         tt++;                //tt加1
  99.                 }
  100.                 LOVE();                        //“愛(ài)心”圖標(biāo)顯示
  101.         }
  102. }

  103. void Main()                        //主函數(shù)入口
  104. {  
  105.         uint data Count=700;                   //定義變量Count
  106.         uchar data i,Cgain,num=0;        //定義變量 i,Cgain,num       

  107.         IOINIT();                        //初始化IO口工作模式
  108.         ax_xs();                          //愛(ài)心顯示
  109.         InitADC();                           //ADC初始化
  110.         Timer_INT();                 //定時(shí)器初始化

  111.         while(1)                //主循環(huán)
  112.         {
  113.                 for(i=0;i<65;i++)                 //for循環(huán)操作65次(讀取64次ADC轉(zhuǎn)換結(jié)果)
  114.                 {  
  115.                         dd[i].real=(GetADCResult(0)+GetADCResult(1))<<gain;         
  116.                         //讀取 ad 結(jié)果并放大 2 的 gain(變量)次方,然后給 FFT 算法的緩存區(qū)賦值
  117.                 }
  118.                  processfft();                        //傅立葉變化及處理
  119.                 if(dd[2].real<32)                  //如果讀取到的AD結(jié)果<32(即音頻幅度太小)
  120.                 {
  121.                         if(++Count==300)        //電平值過(guò)小,則降低gain,減少噪音的電平顯示
  122.                         {
  123.                                 Count=0;                //Count清0               
  124.                                 gain=6;                        //gain=6               
  125.                         }
  126.                 }
  127.                 else                                         //否則在AD結(jié)果在正常音頻范圍
  128.                 {
  129.                         Count=1;                        //Count賦值1(為下次的音頻幅度太小做準(zhǔn)備)
  130.                         if(++num==0xAF)                //播放時(shí),Auto gain;
  131.                         {
  132.                                 num=0;                         //num清0               
  133. /*自動(dòng)增益的作用: 當(dāng)輸入的音頻信號(hào)的音量變大或變小時(shí),采樣的 AD 值幅度也會(huì)有相應(yīng)趨勢(shì)的變化,
  134. 于是根據(jù)這個(gè)值自動(dòng)調(diào)節(jié) AD 值放大的倍數(shù),維持在一定的范圍內(nèi),從而使顯示的效果最好,
  135. 不會(huì)出現(xiàn)滿(mǎn)屏或者空屏的現(xiàn)象*/
  136.                                 //自動(dòng)增益;Automatic gain;
  137.                                 Cgain=dd[2].real/32;                                       
  138.                                 if(7<Cgain<=8)                
  139.                                 {
  140.                                         gain=4;                        //4
  141.                                 }
  142.                                 else if(4<Cgain<=6)
  143.                                 {
  144.                                         gain=5;                        //5
  145.                                 }
  146.                                 else if(2<Cgain<=4)
  147.                                 {
  148.                                         gain=6;                        //6
  149. ……………………

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


所有資料51hei提供下載:
音樂(lè)頻譜程序.zip (78.7 KB, 下載次數(shù): 373)


評(píng)分

參與人數(shù) 4黑幣 +19 收起 理由
luliang02003 + 5
294 + 4 回帖助人的獎(jiǎng)勵(lì)!
jrh200310 + 5 贊一個(gè)!
一世顧你 + 5 很給力!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏11 分享淘帖 頂5 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:138313 發(fā)表于 2017-6-18 22:28 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

板凳
ID:128579 發(fā)表于 2017-6-19 08:26 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

地板
ID:214956 發(fā)表于 2017-6-27 00:01 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

5#
ID:278944 發(fā)表于 2018-2-23 22:44 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

6#
ID:293151 發(fā)表于 2018-5-27 22:32 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

7#
ID:88269 發(fā)表于 2018-6-22 18:00 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

8#
ID:88269 發(fā)表于 2018-6-22 18:00 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

9#
ID:128101 發(fā)表于 2018-8-1 20:47 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

10#
ID:128101 發(fā)表于 2018-8-1 20:48 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

11#
ID:318028 發(fā)表于 2018-8-6 16:14 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

12#
ID:384341 發(fā)表于 2018-8-12 21:43 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

13#
ID:69115 發(fā)表于 2018-11-3 00:06 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

14#
ID:396996 發(fā)表于 2018-11-6 22:57 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

15#
ID:400333 發(fā)表于 2018-12-23 13:01 來(lái)自手機(jī) | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

16#
ID:433994 發(fā)表于 2018-12-23 14:23 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

17#
ID:337058 發(fā)表于 2019-3-29 15:58 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

18#
ID:73182 發(fā)表于 2019-3-29 16:30 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

19#
ID:164062 發(fā)表于 2019-4-2 22:24 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

20#
ID:515468 發(fā)表于 2019-4-18 14:51 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

21#
ID:337058 發(fā)表于 2019-4-26 13:18 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

22#
ID:564922 發(fā)表于 2019-6-24 09:55 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

23#
ID:449590 發(fā)表于 2019-7-6 16:50 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

24#
ID:470939 發(fā)表于 2019-7-22 10:48 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

25#
ID:462326 發(fā)表于 2019-7-24 21:53 來(lái)自手機(jī) | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

26#
ID:595915 發(fā)表于 2019-8-6 11:14 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

27#
ID:591526 發(fā)表于 2019-8-6 16:07 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

28#
ID:285265 發(fā)表于 2019-9-5 20:32 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

29#
ID:92513 發(fā)表于 2019-12-16 16:17 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

30#
ID:638431 發(fā)表于 2020-1-16 08:53 來(lái)自手機(jī) | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

31#
ID:701355 發(fā)表于 2020-3-2 20:04 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

32#
ID:3666 發(fā)表于 2020-4-28 09:10 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

33#
ID:589541 發(fā)表于 2020-6-19 23:12 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

34#
ID:941545 發(fā)表于 2021-6-21 14:03 | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

35#
ID:927615 發(fā)表于 2021-6-30 22:25 來(lái)自手機(jī) | 只看該作者
此帖僅作者可見(jiàn)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 成人亚洲精品 | 91精品国产91久久综合桃花 | 欧美一级免费看 | 日韩免费中文字幕 | 黄色欧美在线 | 国产精品久久久久久一区二区三区 | 蜜桃视频在线观看免费视频网站www | 人人做人人澡人人爽欧美 | 日韩av免费在线电影 | 亚洲欧美中文日韩在线v日本 | 国产精品不卡 | 欧美精品一二三 | av黄色免费| 欧美精品成人一区二区三区四区 | 日韩在线精品视频 | 亚洲欧美日韩久久久 | 欧美高清视频一区 | 日韩欧美三级 | 一区二区三区视频在线观看 | 免费观看的av | 欧美黑人激情 | 国精久久 | 国产在线精品一区二区三区 | 91原创视频 | 亚洲欧美国产精品久久 | 国产丝袜一区二区三区免费视频 | 亚洲国产成人精品久久 | 97碰碰碰 | 久久精品视频在线观看 | 亚洲 中文 欧美 日韩 在线观看 | 成年人在线视频 | 在线观看中文字幕 | 精品国产一区二区三区免费 | 四虎最新视频 | 国产a区 | www.伊人.com | 亚洲综合第一页 | 国产片侵犯亲女视频播放 | 欧美激情精品久久久久 | 亚洲毛片 | 亚洲精品福利在线 |