AudioAnalyser.html 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <!DOCTYPE html>
  2. <html lang="ko">
  3. <head>
  4. <meta charset="utf-8" />
  5. <base href="../../../" />
  6. <script src="page.js"></script>
  7. <link type="text/css" rel="stylesheet" href="page.css" />
  8. </head>
  9. <body>
  10. <h1>[name]</h1>
  11. <p class="desc">
  12. 오디오 데이터를 분석하기 위해 [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode AnalyserNode]를 사용하는
  13. AudioAnalyser 오브젝트를 만듭니다.<br /><br />
  14. [link:https://developer.mozilla.org/en-US/docs/Web/API/Web_Audio_API Web Audio API]를 사용합니다.
  15. </p>
  16. <h2>코드 예제</h2>
  17. <code>
  18. // create an AudioListener and add it to the camera
  19. const listener = new THREE.AudioListener();
  20. camera.add( listener );
  21. // create an Audio source
  22. const sound = new THREE.Audio( listener );
  23. // load a sound and set it as the Audio object's buffer
  24. const audioLoader = new THREE.AudioLoader();
  25. audioLoader.load( 'sounds/ambient.ogg', function( buffer ) {
  26. sound.setBuffer( buffer );
  27. sound.setLoop(true);
  28. sound.setVolume(0.5);
  29. sound.play();
  30. });
  31. // create an AudioAnalyser, passing in the sound and desired fftSize
  32. const analyser = new THREE.AudioAnalyser( sound, 32 );
  33. // get the average frequency of the sound
  34. const data = analyser.getAverageFrequency();
  35. </code>
  36. <h2>예제</h2>
  37. <p>
  38. [example:webaudio_sandbox webaudio / sandbox ]<br />
  39. [example:webaudio_visualizer webaudio / visualizer ]
  40. </p>
  41. <h2>생성자</h2>
  42. <h3>[name]( audio, [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/fftSize fftSize] )</h3>
  43. <p>
  44. 새 [page:AudioAnalyser AudioAnalyser]를 만듭니다.
  45. </p>
  46. <h2>프로퍼티</h2>
  47. <h3>[property:AnalyserNode analyser]</h3>
  48. <p>오디오를 분석하는데 사용하는 [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode AnalyserNode]입니다.</p>
  49. <h3>[property:Integer fftSize]</h3>
  50. <p>
  51. 주파수 영역을 결정하는 데 사용되는 FFT(고속 푸리에 변환)의 크기를 나타내는 최대 2048까지의 0이 아닌 두 개의 크기.
  52. 자세한 내용은 [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/fftSize this page]를 참고하세요.
  53. </p>
  54. <h3>[property:Uint8Array data]</h3>
  55. <p>
  56. A Uint8Array with size determined by
  57. 분석 데이터 저장에 사용되는 [link:https://developer.mozilla.org/en-US/docs/Web/API/AnalyserNode/frequencyBinCount analyser.frequencyBinCount]로
  58. 결정된 크기의 Uint8Array.
  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>