diff options
Diffstat (limited to 'files/ko/web/api/audioparam/value')
-rw-r--r-- | files/ko/web/api/audioparam/value/index.md | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/files/ko/web/api/audioparam/value/index.md b/files/ko/web/api/audioparam/value/index.md new file mode 100644 index 0000000000..ebf07912ec --- /dev/null +++ b/files/ko/web/api/audioparam/value/index.md @@ -0,0 +1,100 @@ +--- +title: AudioParam.value +slug: Web/API/AudioParam/value +tags: + - API + - AudioParam + - Parameter + - Property + - Reference + - Web Audio API + - sound + - value +browser-compat: api.AudioParam.value +--- +{{APIRef("Web Audio API")}} + +[Web Audio API](/ko/docs/Web/API/Web_Audio_API) {{domxref("AudioParam")}} 인터페이스의 **`value`** 속성은 현재 시간에서의 해당 {{domxref("AudioParam")}}의 값을 get하거나 set합니다. 초기 값은 {{domxref("AudioParam.defaultValue")}}으로 설정됩니다. + +`value` 를 설정하는 것은 `AudioContext` 의 {{domxref("BaseAudioContext/currentTime", "currentTime")}} 속성에 의해 반환된 시간과 함께 {{domxref("AudioParam.setValueAtTime")}}를 호출하는 것과 같은 효과를 가지고 있습니다. + +## 구문 + +```js +var curValue = audioParam.value; +audioParam.value = newValue; +``` + +### 값 + +현재 시간에서의 매개변수의 값을 나타내는 부동점 {{jsxref("Number")}}. 이 값은 {{domxref("AudioParam.minValue", "minValue")}}와 {{domxref("AudioParam.maxValue", + "maxValue")}} 속성에 의해 명시된 값 사이에 있을 것입니다. + +## 사용 일람 + +### 값 정밀도과 변화 + +`value` 를 저장하기 위해 내부적으로 사용되는 데이터 타입은 단일 정밀도 (32비트) 부동점 number인 반면, JavaScript는 64비트 배정밀도 부동점 number를 사용합니다. 그 결과로, `value` 속성에서 읽은 값이 항상 설정한 것과 정확히 같지 않을 수 있습니다. + +아래의 예시를 고려해 보세요. + +```js +const source = new AudioBufferSourceNode(...); +const rate = 5.3; +source.playbackRate.value = rate; +console.log(source.playbackRate.value === rate); +``` + +출력된 로그는 `false` 일 것인데, 왜냐하면 playback rate 매개변수 `rate` 는 5.3에 가장 가까운 32비트 부동점 number로 전환되고, 이 값은 5.300000190734863이기 때문입니다. 한 가지 해결 방법은 `value` 를 설정할 때 다음과 같이 {{jsxref("Math.fround()")}} 메서드를 사용하는 것인데, 이 메서드는 명시된 64비트 JavaScript 값과 같은 단일 정밀도 값을 반환합니다. + + const source = new AudioBufferSourceNode(...); + const rate = Math.fround(5.3); + source.playbackRate.value = rate; + console.log(source.playbackRate.value === rate); + +이 경우, 출력된 로그는 `true` 일 것입니다. + +### 시간에 따라 변화하는 속성의 값 + +`AudioParam` 의 `value` 는 고정되어 있을 수도 있고 시간에 따라 달라질 수도 있습니다. 이는 `value` getter에 의해 반영되는데, 이것은 오디오 렌더링 엔진의 가장 최근의 **render +quantum** , 즉 오디오 버퍼가 처리되고 갱신되는 순간에서의 매개변수의 값을 반환합니다. 오디오 버퍼를 처리하는 것에 덧붙여, 각각의 render quantum은 현재 시간과 설정된 시간 기반의 매개변수 값이 변화한다면 필요할 때 각 `AudioParam` 의 `value` 를 갱신합니다. + +매개변수를 처음 생성했을 때, 매개변수의 값은 {{domxref("AudioParam.defaultValue")}}에 의해 주어지는 기본 값으로 설정됩니다. 이것은 0.0초에서의 이 매개변수의 값이고, 값이 변경되는 첫번째 render quantum 전까지 계속 유지될 것입니다. + +각 render quantum 도중에, 브라우저는 매개변수의 값을 관리하는 것에 관련된 다음의 일들을 합니다. + +- 만약 `value` setter가 사용되었다면, 매개변수의 값은 주어진 값으로 변경됩니다. +- 만약 현재 시간이 {{domxref("AudioParam.setValueAtTime", "setValueAtTime()")}}의 이전 호출에 의해 명시된 시간과 같거나 초과한다면, `value` 는 `setValueAtTime()` 에 전달된 값으로 변경됩니다. +- 만약 graduated나 ramped 방식의 값 변경 메서드가 호출되었고 현재 시간이 graduated된 변화가 발생해야 하는 시간 범위 내에 있다면, 값은 적절한 알고리즘에 기반해 갱신됩니다. ramped나 graduated 값 변화 메서드에는 {{domxref("AudioParam.linearRampToValueAtTime", + "linearRampToValueAtTime()")}}, {{domxref("AudioParam.setTargetAtTime", + "setTargetAtTime()")}}, {{domxref("AudioParam.setValueCurveAtTime", + "setValueCurveAtTime()")}}이 있습니다. + +이렇게 하여, 매개변수의 `value` 는 시간에 따른 매개변수의 상태를 정밀하게 반영하도록 유지됩니다. + +## 예제 + +이 예제는 {{domxref("GainNode")}}의 볼륨을 즉시 40%로 변경합니다. + +```js +const audioCtx = new AudioContext(); +const gainNode = audioCtx.createGain(); +gainNode.gain.value = 0.4; +// 위는 아래와 같습니다. +gainNode.gain.setValueAtTime(0.4, audioCtx.currentTime); +``` + +## 명세서 + +{{Specifications}} + +## 브라우저 호환성 + +{{Compat}} + +{{domxref("GainNode")}}의 gain 값을 변경할 때, 버전 64 (2018년 1월) 이전의 Google Chrome은 dezippering을 방지하기 위해 부드러운 보간(interpolation)을 수행할 것입니다. 버전 64부터, Web Audio 명세서와 일치하도록 값은 즉시 변경됩니다. 자세한 정보를 보려면 [Chrome Platform +Status](https://www.chromestatus.com/feature/5287995770929152)를 참고하세요. + +## 같이 보기 + +- [Web Audio API 사용하기](/ko/docs/Web/API/Web_Audio_API/Using_Web_Audio_API) |