AudioAnalyser.html 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <!DOCTYPE html>
  2. <html lang="zh">
  3. <head>
  4. <meta charset="utf-8" />
  5. <base href="../../../" />
  6. <script src="list.js"></script>
  7. <script src="page.js"></script>
  8. <link type="text/css" rel="stylesheet" href="page.css" />
  9. </head>
  10. <body>
  11. <h1>[name]</h1>
  12. <p class="desc">
  13. 创建AudioAnalyser对象, 使用[link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode AnalyserNode]
  14. 去分析音频数据.<br /><br />
  15. 使用了 [link:https://developer.mozilla.org/en-US/docs/Web/API/Web_Audio_API Web Audio API].
  16. </p>
  17. <h2>代码示例</h2>
  18. <code>
  19. // create an AudioListener and add it to the camera
  20. var listener = new THREE.AudioListener();
  21. camera.add( listener );
  22. // create an Audio source
  23. var sound = new THREE.Audio( listener );
  24. // load a sound and set it as the Audio object's buffer
  25. var audioLoader = new THREE.AudioLoader();
  26. audioLoader.load( 'sounds/ambient.ogg', function( buffer ) {
  27. sound.setBuffer( buffer );
  28. sound.setLoop(true);
  29. sound.setVolume(0.5);
  30. sound.play();
  31. });
  32. // create an AudioAnalyser, passing in the sound and desired fftSize
  33. var analyser = new THREE.AudioAnalyser( sound, 32 );
  34. // get the average frequency of the sound
  35. var data = analyser.getAverageFrequency();
  36. </code>
  37. <h2>例子</h2>
  38. <p>
  39. [example:webaudio_sandbox webaudio / sandbox ]<br />
  40. [example:webaudio_visualizer webaudio / visualizer ]
  41. </p>
  42. <h2>构造函数</h2>
  43. <h3>[name]( audio, [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/fftSize fftSize] )</h3>
  44. <p>
  45. 创建[page:AudioAnalyser AudioAnalyser].
  46. </p>
  47. <h2>属性</h2>
  48. <h3>[property:AnalyserNode analyser]</h3>
  49. <p>[link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode AnalyserNode]用来分析音频数据.</p>
  50. <h3>[property:Integer fftSize]</h3>
  51. <p>
  52. 2的幂次方最高为2048, 用来表示确定频域的FFT (傅立叶变换)大小.
  53. 这个[link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/fftSize page]有详细信息.
  54. </p>
  55. <h3>[property:Uint8Array data]</h3>
  56. <p>
  57. 用来分析数据的Uint8Array的大小由[link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/frequencyBinCount analyser.frequencyBinCount]
  58. 确定.
  59. </p>
  60. <h2>方法</h2>
  61. <h3>[method:Uint8Array getFrequencyData]()</h3>
  62. <p>
  63. 使用网络音频的[link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/getByteFrequencyData getByteFrequencyData] 方法.
  64. 看这个页面.
  65. </p>
  66. <h3>[method:Number getAverageFrequency]()</h3>
  67. <p>
  68. 通过方法[page:AudioAnalyser.getFrequencyData getFrequencyData]获取平均频率.
  69. </p>
  70. <h2>源码</h2>
  71. <p>
  72. [link:https://github.com/mrdoob/three.js/blob/master/src/[path].js src/[path].js]
  73. </p>
  74. </body>
  75. </html>