aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/audiocontext.rs
diff options
context:
space:
mode:
authorFernando Jiménez Moreno <ferjmoreno@gmail.com>2018-06-22 11:04:01 +0200
committerFernando Jiménez Moreno <ferjmoreno@gmail.com>2018-07-30 14:21:38 +0200
commitdb52d1f65c6fe154812b682a604b00db3a78eed5 (patch)
tree74fa3b095ee2211fe9a2337d1314fe735a914a4e /components/script/dom/audiocontext.rs
parentba9dfb0293c6385753221ab7a1515a1c552594ce (diff)
downloadservo-db52d1f65c6fe154812b682a604b00db3a78eed5.tar.gz
servo-db52d1f65c6fe154812b682a604b00db3a78eed5.zip
Audio context options
Diffstat (limited to 'components/script/dom/audiocontext.rs')
-rw-r--r--components/script/dom/audiocontext.rs32
1 files changed, 26 insertions, 6 deletions
diff --git a/components/script/dom/audiocontext.rs b/components/script/dom/audiocontext.rs
index 9b767a6da05..3ed6f3947ad 100644
--- a/components/script/dom/audiocontext.rs
+++ b/components/script/dom/audiocontext.rs
@@ -2,10 +2,10 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-use dom::baseaudiocontext::BaseAudioContext;
+use dom::baseaudiocontext::{BaseAudioContext, BaseAudioContextOptions};
use dom::bindings::codegen::Bindings::AudioContextBinding;
-use dom::bindings::codegen::Bindings::AudioContextBinding::AudioContextMethods;
-use dom::bindings::codegen::Bindings::AudioContextBinding::{AudioContextOptions, AudioTimestamp};
+use dom::bindings::codegen::Bindings::AudioContextBinding::{AudioContextMethods, AudioContextOptions};
+use dom::bindings::codegen::Bindings::AudioContextBinding::{AudioContextLatencyCategory, AudioTimestamp};
use dom::bindings::error::Fallible;
use dom::bindings::inheritance::Castable;
use dom::bindings::num::Finite;
@@ -15,6 +15,7 @@ use dom::globalscope::GlobalScope;
use dom::promise::Promise;
use dom::window::Window;
use dom_struct::dom_struct;
+use servo_media::audio::graph::{LatencyCategory, RealTimeAudioGraphOptions};
use std::rc::Rc;
#[dom_struct]
@@ -25,9 +26,9 @@ pub struct AudioContext {
}
impl AudioContext {
- fn new_inherited(global: &GlobalScope, sample_rate: f32) -> AudioContext {
+ fn new_inherited(global: &GlobalScope, options: &AudioContextOptions) -> AudioContext {
AudioContext {
- context: BaseAudioContext::new_inherited(global, 2 /* channel_count */, sample_rate),
+ context: BaseAudioContext::new_inherited(global, BaseAudioContextOptions::AudioContext(options.into())),
base_latency: 0., // TODO
output_latency: 0., // TODO
}
@@ -38,7 +39,7 @@ impl AudioContext {
options: &AudioContextOptions) -> DomRoot<AudioContext> {
let context = AudioContext::new_inherited(
global,
- *options.sampleRate.unwrap_or(Finite::wrap(0.)),
+ options,
); // TODO
reflect_dom_object(Box::new(context), global, AudioContextBinding::Wrap)
}
@@ -79,3 +80,22 @@ impl AudioContextMethods for AudioContext {
Promise::new(&self.global())
}
}
+
+impl From<AudioContextLatencyCategory> for LatencyCategory {
+ fn from(category: AudioContextLatencyCategory) -> Self {
+ match category {
+ AudioContextLatencyCategory::Balanced => LatencyCategory::Balanced,
+ AudioContextLatencyCategory::Interactive => LatencyCategory::Interactive,
+ AudioContextLatencyCategory::Playback => LatencyCategory::Playback,
+ }
+ }
+}
+
+impl<'a> From<&'a AudioContextOptions> for RealTimeAudioGraphOptions {
+ fn from(options: &AudioContextOptions) -> Self {
+ Self {
+ sample_rate: *options.sampleRate.unwrap_or(Finite::wrap(48000.)),
+ latency_hint: options.latencyHint.into(),
+ }
+ }
+}