10692浏览
查看: 10692|回复: 21

[项目] 【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)

[复制链接]
偶然心血来潮,想要做一个声音可视化的系列专题。这个专题的难度有点高,涉及面也比较广泛,相关的FFT和FHT等算法也相当复杂,不过还是打算从最简单的开始,实际动手做做试验,耐心尝试一下各种方案,逐步积累些有用的音乐频谱可视化的资料,也会争取成型一些实用好玩的音乐可视器项目。

路上捡到二根坏的LED方管灯,想改造一下废物利用。

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:00:04

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:02:57

彩灯使用WS2812B

其主要特点
智能反接保护,电源反接不会损坏IC。
IC控制电路与LED点光源公用一个电源。
控制电路与RGB芯片集成在一个5050封装的元器件中,构成一个完整的外控像素点。
内置信号整形电路,任何一个像素点收到信号后经过波形整形再输出,保证线路波形畸变不会累加。
内置上电复位和掉电复位电路。
每个像素点的三基色颜色可实现256级亮度显示,完成16777216种颜色的全真色彩显示,扫描频率不低于400Hz/s。
串行级联接口,能通过一根信号线完成数据的接收与解码。
任意两点传传输距离在不超过5米时无需增加任何电路。
当刷新速率30帧/秒时,级联数不小于1024点。
数据发送速度可达800Kbps。
光的颜色高度一致,性价比高。

主要应用领域
LED全彩发光字灯串,LED全彩模组, LED全彩软灯条硬灯条,LED护栏管。
LED点光源,LED像素屏,LED异形屏,各种电子产品,电器设备跑马灯。


【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:05:29

WS2812B灯带选用的是每米60灯黑底裸板


【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:08:26

声音模块,使用性价比更高的MAX4466声音传感器


【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:12:22

MAX4466功能框图

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

附件:MAX4466相关技术资料链接(英文,来自MAXIM美信公司官网)
https://datasheets.maximintegrated.com/en/ds/MAX4465-MAX4469.pdf

附注:MAXIM
是美信公司(Maxim Integrated Products)的英文缩写,全球最好的模拟信号和混合信号半导体公司。Maxim Integrated Products成立于1983年,总部位于美国加利福尼亚的Sunnyvale,公司拥有9300多名员工,是世界范围内模拟和混合信号集成产品的设计、开发与生产领域的领导者之一。通过对温度、压力、声音等现实世界的各种信号进行检测、放大,并将其转换成计算机处理所需要的数字信号, Maxim的电路把现实世界与数字世界“连接”在一起。Maxim是全球模拟、混合信号、高频及数字电路设计、研发、制造的领导者,所提供的产品能够实现上述数字内核与周边系统的连接。它们在世界范围内拥有大约35,000个大型客户。
MAXIM官网:https://www.maximintegrated.com/cn.html
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-9 13:17:04

MAX4466模块特点
电源电压:+2.4V至+5.5V(可直接接STM/ARDUNIO/树莓派等开发板)
电源抑制比:112dB
共模抑制比:126dB
AVOL:125dB(RL = 100kΩ) 轨到轨输出
静态电源电流:24μA
增益带宽:600kHz
尺寸:20.8mm x 13.8mm x 7.5mm/0.8 x 0.5 x 0.3inch



【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1


该模块在 Vcc 和接地引线上都包含铁氧体,以最大限度地减少电源噪声。如果与 MCU 一起使用,最好使用 2.4V – 5.5V 范围内可用的最安静的电源。在 Arduino 上,这通常是 3.3V 电源。

输出是直流耦合的。当输出信号处于静止状态时,它将位于 Vcc/2。如果 Vcc 为 5V,则输出将为 2.5V。如果输出需要交流耦合,可以在输出引脚和它驱动的电路的输入之间增加一个100uF的电容。

背面的小型单圈电位器可让您将增益从 25x 调整到 125x。逆时针旋转电位器会增加增益,而逆时针旋转会降低增益。


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 08:53:37

二只灯管准备分别使arduino nano和 ESP32_C3开发板

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1
回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 09:06:56

arduino nano开发板接脚图

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 09:10:18

ESP32_C3开发板接脚图

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 10:10:54

两套横排LED方管灯所需的硬件

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1



回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 13:06:32

  【花雕动手做】有趣好玩音乐可视化(15)--横排LED方管灯
  项目之一:Arduino 和 FastLED多彩音乐节拍灯

  1. /*
  2.   【花雕动手做】有趣好玩音乐可视化(15)--横排LED方管灯
  3.   项目之一:Arduino 和 FastLED多彩音乐节拍灯
  4. */
  5. #include <FastLED.h>
  6. #define SAMPLEPERIODUS 200
  7. #define MIC_PIN A0
  8. #define LED_DT 6
  9. #define COLOR_ORDER GRB
  10. #define LED_TYPE WS2812
  11. #define NUM_LEDS 24
  12. uint8_t max_bright = 77;
  13. struct CRGB leds[NUM_LEDS];
  14. CRGBPalette16 currentPalette = RainbowColors_p;
  15. CRGBPalette16 targetPalette;
  16. void setup() {
  17.   pinMode(LED_BUILTIN, OUTPUT);
  18.   LEDS.addLeds<LED_TYPE, LED_DT, COLOR_ORDER>(leds, NUM_LEDS);
  19.   FastLED.setBrightness(max_bright);
  20. }
  21. float bassFilter(float sample) {
  22.   static float xv[3] = {0, 0, 0}, yv[3] = {0, 0, 0};
  23.   xv[0] = xv[1]; xv[1] = xv[2];
  24.   xv[2] = sample / 9.1f;
  25.   yv[0] = yv[1]; yv[1] = yv[2];
  26.   yv[2] = (xv[2] - xv[0]) + (-0.7960060012f * yv[0]) + (1.7903124146f * yv[1]);
  27.   return yv[2];
  28. }
  29. float envelopeFilter(float sample) {
  30.   static float xv[2] = {0, 0}, yv[2] = {0, 0};
  31.   xv[0] = xv[1];
  32.   xv[1] = sample / 160.f;
  33.   yv[0] = yv[1];
  34.   yv[1] = (xv[0] + xv[1]) + (0.9875119299f * yv[0]);
  35.   return yv[1];
  36. }
  37. float beatFilter(float sample) {
  38.   static float xv[3] = {0, 0, 0}, yv[3] = {0, 0, 0};
  39.   xv[0] = xv[1]; xv[1] = xv[2];
  40.   xv[2] = sample / 7.015f;
  41.   yv[0] = yv[1]; yv[1] = yv[2];
  42.   yv[2] = (xv[2] - xv[0]) + (-0.7169861741f * yv[0]) + (1.4453653501f * yv[1]);
  43.   return yv[2];
  44. }
  45. void loop() {
  46.   unsigned long time = micros();
  47.   float sample, value, envelope, beat, thresh, micLev;
  48.   for (uint8_t i = 0; ; ++i) {
  49.     sample = (float)analogRead(MIC_PIN);
  50.     micLev = ((micLev * 31) + sample) / 32;
  51.     sample -= micLev;
  52.     value = bassFilter(sample);
  53.     value = abs(value);
  54.     envelope = envelopeFilter(value);
  55.     if (i == 200) {
  56.       beat = beatFilter(envelope);
  57.       thresh = 0.02f * 75.;
  58.       if (beat > thresh) {
  59.         digitalWrite(LED_BUILTIN, LOW);
  60.         int strt = random8(NUM_LEDS / 2);
  61.         int ende = strt + random8(NUM_LEDS / 2);
  62.         for (int i = strt; i < ende; i++) {
  63.           uint8_t index = inoise8(i * 30, millis() + i * 30);
  64.           leds[i] = ColorFromPalette(currentPalette, index, 255, LINEARBLEND);
  65.         }
  66.       } else {
  67.         digitalWrite(LED_BUILTIN, HIGH);
  68.       }
  69.       i = 0;
  70.     }
  71.     EVERY_N_SECONDS(5) {
  72.       uint8_t baseC = random8();
  73.       targetPalette = CRGBPalette16(CHSV(baseC + random8(32), 255, random8(128, 255)),
  74.                                     CHSV(baseC + random8(64), 255, random8(128, 255)),
  75.                                     CHSV(baseC + random8(64), 192, random8(128, 255)),
  76.                                     CHSV(baseC + random8(),   255, random8(128, 255)));
  77.     }
  78.     EVERY_N_MILLISECONDS(50) {
  79.       uint8_t maxChanges = 24;
  80.       nblendPaletteTowardPalette(currentPalette, targetPalette, maxChanges);
  81.     }
  82.     EVERY_N_MILLIS(50) {
  83.       fadeToBlackBy(leds, NUM_LEDS, 64);
  84.       FastLED.show();
  85.     }
  86.     for (unsigned long up = time + SAMPLEPERIODUS; time > 20 && time < up; time = micros()) {  }
  87.   } // for i
  88. } // loop()
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 13:08:48

实验场景图  动态图

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 18:29:00

多次测试调整

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 18:34:03

对外只有5V电源接口,外露声音传感器唛头

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 18:37:29

使用充电宝,或者手机充电头供电,大于1A即可

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 18:40:43

实验场景图

【花雕动手做】看见声音,基于Arduino系列音乐可视器(15)图1

回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-11 19:25:22

项目实验的视频记录(4分43秒)

https://v.youku.com/v_show/id_XN ... hcb.playlsit.page.1




回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-12 17:25:11

  【花雕动手做】有趣好玩音乐可视化(15)--横排LED方管灯
  项目之二:MegunoLink柱状音乐灯

  1. /*
  2.   【花雕动手做】有趣好玩音乐可视化(15)--横排LED方管灯
  3.   项目之二:MegunoLink柱状音乐灯
  4. */
  5. #include<FastLED.h>
  6. #include<MegunoLink.h>
  7. #include<Filter.h>
  8. #define N_PIXELS  69
  9. #define MIC_PIN   A5
  10. #define LED_PIN   12
  11. #define NOISE 10
  12. #define TOP   (N_PIXELS+2)
  13. #define LED_TYPE  WS2811
  14. #define BRIGHTNESS  22
  15. #define COLOR_ORDER GRB
  16. CRGB leds[N_PIXELS];
  17. int lvl = 0, minLvl = 0, maxLvl = 10;
  18. ExponentialFilter<long> ADCFilter(5, 0);
  19. void setup() {
  20.   FastLED.addLeds<LED_TYPE, LED_PIN, COLOR_ORDER>(leds, N_PIXELS).setCorrection(TypicalLEDStrip);
  21.   FastLED.setBrightness(BRIGHTNESS);
  22. }
  23. void loop() {
  24.   int n, height;
  25.   n = analogRead(MIC_PIN);
  26.   n = abs(1023 - n);
  27.   n = (n <= NOISE) ? 0 : abs(n - NOISE);
  28.   ADCFilter.Filter(n);
  29.   lvl = ADCFilter.Current();
  30.   //  Serial.print(n);
  31.   //  Serial.print(" ");
  32.   //  Serial.println(lvl);
  33.   height = TOP * (lvl - minLvl) / (long)(maxLvl - minLvl);
  34.   if (height < 0L) height = 0;
  35.   else if (height > TOP) height = TOP;
  36.   for (uint8_t i = 0; i < N_PIXELS; i++) {
  37.     if (i >= height) leds[i] = CRGB(0, 0, 0);
  38.     else leds[i] = Wheel( map( i, 0, N_PIXELS - 1, 30, 150 ) );
  39.   }
  40.   FastLED.show();
  41. }
  42. CRGB Wheel(byte WheelPos) {
  43.   if (WheelPos < 85)
  44.     return CRGB(WheelPos * 3, 255 - WheelPos * 3, 0);
  45.   else if (WheelPos < 170) {
  46.     WheelPos -= 85;
  47.     return CRGB(255 - WheelPos * 3, 0, WheelPos * 3);
  48.   } else {
  49.     WheelPos -= 170;
  50.     return CRGB(0, WheelPos * 3, 255 - WheelPos * 3);
  51.   }
  52. }
复制代码


回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-12 17:33:45

实验的视频记录之一(1分50秒)

https://v.youku.com/v_show/id_XN ... hcb.playlsit.page.3



回复

使用道具 举报

驴友花雕  中级技神
 楼主|

发表于 2022-8-12 17:38:31

实验的视频记录之二(50秒)

https://v.youku.com/v_show/id_XN ... hcb.playlsit.page.1



回复

使用道具 举报

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

本版积分规则

为本项目制作心愿单
购买心愿单
心愿单 编辑
[[wsData.name]]

硬件清单

  • [[d.name]]
btnicon
我也要做!
点击进入购买页面
上海智位机器人股份有限公司 沪ICP备09038501号-4

© 2013-2024 Comsenz Inc. Powered by Discuz! X3.4 Licensed

mail