Skip to content

Commit

Permalink
Add MediaDevices::GetUserMedia
Browse files Browse the repository at this point in the history
  • Loading branch information
Manishearth committed Jan 29, 2019
1 parent eee183d commit 8b0719a
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 12 deletions.
3 changes: 2 additions & 1 deletion components/script/dom/bindings/trace.rs
Expand Up @@ -101,7 +101,7 @@ use servo_media::audio::graph::NodeId;
use servo_media::audio::panner_node::{DistanceModel, PanningModel};
use servo_media::audio::param::ParamType;
use servo_media::player::Player;
use servo_media::webrtc::WebRtcController;
use servo_media::webrtc::{MediaStream as BackendMediaStream, WebRtcController};
use servo_media::Backend;
use servo_url::{ImmutableOrigin, MutableOrigin, ServoUrl};
use smallvec::SmallVec;
Expand Down Expand Up @@ -485,6 +485,7 @@ unsafe_no_jsmanaged_fields!(NodeId);
unsafe_no_jsmanaged_fields!(AnalysisEngine, DistanceModel, PanningModel, ParamType);
unsafe_no_jsmanaged_fields!(dyn Player);
unsafe_no_jsmanaged_fields!(WebRtcController);
unsafe_no_jsmanaged_fields!(dyn BackendMediaStream);
unsafe_no_jsmanaged_fields!(Mutex<MediaFrameRenderer>);
unsafe_no_jsmanaged_fields!(RenderApiSender);
unsafe_no_jsmanaged_fields!(ResourceFetchTiming);
Expand Down
31 changes: 28 additions & 3 deletions components/script/dom/mediadevices.rs
Expand Up @@ -2,15 +2,18 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */

use crate::dom::bindings::codegen::Bindings::MediaDevicesBinding;
use crate::dom::bindings::error::Fallible;
use crate::dom::bindings::codegen::Bindings::MediaDevicesBinding::MediaStreamConstraints;
use crate::dom::bindings::codegen::Bindings::MediaDevicesBinding::{self, MediaDevicesMethods};
use crate::dom::bindings::reflector::reflect_dom_object;
use crate::dom::bindings::reflector::DomObject;
use crate::dom::bindings::root::DomRoot;
use crate::dom::eventtarget::EventTarget;
use crate::dom::globalscope::GlobalScope;
use crate::dom::window::Window;
use crate::dom::mediastream::MediaStream;
use crate::dom::promise::Promise;
use dom_struct::dom_struct;
use servo_media::ServoMedia;
use std::rc::Rc;

#[dom_struct]
pub struct MediaDevices {
Expand All @@ -32,3 +35,25 @@ impl MediaDevices {
)
}
}

impl MediaDevicesMethods for MediaDevices {
/// https://w3c.github.io/mediacapture-main/#dom-mediadevices-getusermedia
fn GetUserMedia(&self, constraints: &MediaStreamConstraints) -> Rc<Promise> {
let p = Promise::new(&self.global());
let media = ServoMedia::get().unwrap();
let mut tracks = vec![];
if constraints.audio {
if let Some(audio) = media.create_audioinput_stream() {
tracks.push(audio)
}
}
if constraints.video {
if let Some(video) = media.create_videoinput_stream() {
tracks.push(video)
}
}
let stream = MediaStream::new(&self.global(), tracks);
p.resolve_native(&stream);
p
}
}
13 changes: 7 additions & 6 deletions components/script/dom/mediastream.rs
Expand Up @@ -3,30 +3,31 @@
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */

use crate::dom::bindings::codegen::Bindings::MediaStreamBinding;
use crate::dom::bindings::error::Fallible;
use crate::dom::bindings::reflector::reflect_dom_object;
use crate::dom::bindings::reflector::DomObject;
use crate::dom::bindings::root::DomRoot;
use crate::dom::eventtarget::EventTarget;
use crate::dom::globalscope::GlobalScope;
use crate::dom::window::Window;
use dom_struct::dom_struct;
use servo_media::webrtc::MediaStream as BackendMediaStream;

#[dom_struct]
pub struct MediaStream {
eventtarget: EventTarget,
#[ignore_malloc_size_of = "defined in servo-media"]
tracks: Vec<Box<BackendMediaStream>>,
}

impl MediaStream {
pub fn new_inherited() -> MediaStream {
pub fn new_inherited(tracks: Vec<Box<BackendMediaStream>>) -> MediaStream {
MediaStream {
eventtarget: EventTarget::new_inherited(),
tracks,
}
}

pub fn new(global: &GlobalScope) -> DomRoot<MediaStream> {
pub fn new(global: &GlobalScope, tracks: Vec<Box<BackendMediaStream>>) -> DomRoot<MediaStream> {
reflect_dom_object(
Box::new(MediaStream::new_inherited()),
Box::new(MediaStream::new_inherited(tracks)),
global,
MediaStreamBinding::Wrap,
)
Expand Down
3 changes: 2 additions & 1 deletion components/script/dom/navigator.rs
Expand Up @@ -167,6 +167,7 @@ impl NavigatorMethods for Navigator {

/// https://w3c.github.io/mediacapture-main/#dom-navigator-mediadevices
fn MediaDevices(&self) -> DomRoot<MediaDevices> {
self.mediadevices.or_init(|| MediaDevices::new(&self.global()))
self.mediadevices
.or_init(|| MediaDevices::new(&self.global()))
}
}
2 changes: 1 addition & 1 deletion components/script/dom/webidls/MediaDevices.webidl
Expand Up @@ -18,7 +18,7 @@ partial interface Navigator {

partial interface MediaDevices {
// MediaTrackSupportedConstraints getSupportedConstraints();
// Promise<MediaStream> getUserMedia(optional MediaStreamConstraints constraints);
Promise<MediaStream> getUserMedia(optional MediaStreamConstraints constraints);
};


Expand Down

0 comments on commit 8b0719a

Please sign in to comment.