mirror of
https://github.com/servo/servo.git
synced 2025-07-22 14:53:49 +01:00
Add stream types to tracks, add MediaStreamTrack.id and MediaStreamTrack.kind
This commit is contained in:
parent
a9ab13b279
commit
36abbca0a6
4 changed files with 41 additions and 9 deletions
|
@ -105,6 +105,7 @@ use servo_media::audio::panner_node::{DistanceModel, PanningModel};
|
||||||
use servo_media::audio::param::ParamType;
|
use servo_media::audio::param::ParamType;
|
||||||
use servo_media::player::Player;
|
use servo_media::player::Player;
|
||||||
use servo_media::streams::registry::MediaStreamId;
|
use servo_media::streams::registry::MediaStreamId;
|
||||||
|
use servo_media::streams::MediaStreamType;
|
||||||
use servo_media::webrtc::WebRtcController;
|
use servo_media::webrtc::WebRtcController;
|
||||||
use servo_url::{ImmutableOrigin, MutableOrigin, ServoUrl};
|
use servo_url::{ImmutableOrigin, MutableOrigin, ServoUrl};
|
||||||
use smallvec::SmallVec;
|
use smallvec::SmallVec;
|
||||||
|
@ -490,7 +491,7 @@ unsafe_no_jsmanaged_fields!(NodeId);
|
||||||
unsafe_no_jsmanaged_fields!(AnalysisEngine, DistanceModel, PanningModel, ParamType);
|
unsafe_no_jsmanaged_fields!(AnalysisEngine, DistanceModel, PanningModel, ParamType);
|
||||||
unsafe_no_jsmanaged_fields!(dyn Player);
|
unsafe_no_jsmanaged_fields!(dyn Player);
|
||||||
unsafe_no_jsmanaged_fields!(WebRtcController);
|
unsafe_no_jsmanaged_fields!(WebRtcController);
|
||||||
unsafe_no_jsmanaged_fields!(MediaStreamId);
|
unsafe_no_jsmanaged_fields!(MediaStreamId, MediaStreamType);
|
||||||
unsafe_no_jsmanaged_fields!(Mutex<MediaFrameRenderer>);
|
unsafe_no_jsmanaged_fields!(Mutex<MediaFrameRenderer>);
|
||||||
unsafe_no_jsmanaged_fields!(RenderApiSender);
|
unsafe_no_jsmanaged_fields!(RenderApiSender);
|
||||||
unsafe_no_jsmanaged_fields!(ResourceFetchTiming);
|
unsafe_no_jsmanaged_fields!(ResourceFetchTiming);
|
||||||
|
|
|
@ -18,6 +18,7 @@ use crate::dom::mediastreamtrack::MediaStreamTrack;
|
||||||
use crate::dom::promise::Promise;
|
use crate::dom::promise::Promise;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
use servo_media::streams::capture::{Constrain, ConstrainRange, MediaTrackConstraintSet};
|
use servo_media::streams::capture::{Constrain, ConstrainRange, MediaTrackConstraintSet};
|
||||||
|
use servo_media::streams::MediaStreamType;
|
||||||
use servo_media::ServoMedia;
|
use servo_media::ServoMedia;
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
|
|
||||||
|
@ -55,13 +56,13 @@ impl MediaDevicesMethods for MediaDevices {
|
||||||
let stream = MediaStream::new(&self.global());
|
let stream = MediaStream::new(&self.global());
|
||||||
if let Some(constraints) = convert_constraints(&constraints.audio) {
|
if let Some(constraints) = convert_constraints(&constraints.audio) {
|
||||||
if let Some(audio) = media.create_audioinput_stream(constraints) {
|
if let Some(audio) = media.create_audioinput_stream(constraints) {
|
||||||
let track = MediaStreamTrack::new(&self.global(), audio);
|
let track = MediaStreamTrack::new(&self.global(), audio, MediaStreamType::Audio);
|
||||||
stream.add_track(&track);
|
stream.add_track(&track);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if let Some(constraints) = convert_constraints(&constraints.video) {
|
if let Some(constraints) = convert_constraints(&constraints.video) {
|
||||||
if let Some(video) = media.create_videoinput_stream(constraints) {
|
if let Some(video) = media.create_videoinput_stream(constraints) {
|
||||||
let track = MediaStreamTrack::new(&self.global(), video);
|
let track = MediaStreamTrack::new(&self.global(), video, MediaStreamType::Video);
|
||||||
stream.add_track(&track);
|
stream.add_track(&track);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,32 +2,43 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* 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/. */
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use crate::dom::bindings::codegen::Bindings::MediaStreamTrackBinding;
|
use crate::dom::bindings::codegen::Bindings::MediaStreamTrackBinding::{
|
||||||
|
self, MediaStreamTrackMethods,
|
||||||
|
};
|
||||||
use crate::dom::bindings::reflector::reflect_dom_object;
|
use crate::dom::bindings::reflector::reflect_dom_object;
|
||||||
use crate::dom::bindings::root::DomRoot;
|
use crate::dom::bindings::root::DomRoot;
|
||||||
|
use crate::dom::bindings::str::DOMString;
|
||||||
use crate::dom::eventtarget::EventTarget;
|
use crate::dom::eventtarget::EventTarget;
|
||||||
use crate::dom::globalscope::GlobalScope;
|
use crate::dom::globalscope::GlobalScope;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
use servo_media::streams::registry::MediaStreamId;
|
use servo_media::streams::registry::MediaStreamId;
|
||||||
|
use servo_media::streams::MediaStreamType;
|
||||||
|
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
pub struct MediaStreamTrack {
|
pub struct MediaStreamTrack {
|
||||||
eventtarget: EventTarget,
|
eventtarget: EventTarget,
|
||||||
#[ignore_malloc_size_of = "defined in servo-media"]
|
#[ignore_malloc_size_of = "defined in servo-media"]
|
||||||
id: MediaStreamId,
|
id: MediaStreamId,
|
||||||
|
#[ignore_malloc_size_of = "defined in servo-media"]
|
||||||
|
ty: MediaStreamType,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MediaStreamTrack {
|
impl MediaStreamTrack {
|
||||||
pub fn new_inherited(id: MediaStreamId) -> MediaStreamTrack {
|
pub fn new_inherited(id: MediaStreamId, ty: MediaStreamType) -> MediaStreamTrack {
|
||||||
MediaStreamTrack {
|
MediaStreamTrack {
|
||||||
eventtarget: EventTarget::new_inherited(),
|
eventtarget: EventTarget::new_inherited(),
|
||||||
id,
|
id,
|
||||||
|
ty,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new(global: &GlobalScope, id: MediaStreamId) -> DomRoot<MediaStreamTrack> {
|
pub fn new(
|
||||||
|
global: &GlobalScope,
|
||||||
|
id: MediaStreamId,
|
||||||
|
ty: MediaStreamType,
|
||||||
|
) -> DomRoot<MediaStreamTrack> {
|
||||||
reflect_dom_object(
|
reflect_dom_object(
|
||||||
Box::new(MediaStreamTrack::new_inherited(id)),
|
Box::new(MediaStreamTrack::new_inherited(id, ty)),
|
||||||
global,
|
global,
|
||||||
MediaStreamTrackBinding::Wrap,
|
MediaStreamTrackBinding::Wrap,
|
||||||
)
|
)
|
||||||
|
@ -36,4 +47,23 @@ impl MediaStreamTrack {
|
||||||
pub fn id(&self) -> MediaStreamId {
|
pub fn id(&self) -> MediaStreamId {
|
||||||
self.id
|
self.id
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn ty(&self) -> MediaStreamType {
|
||||||
|
self.ty
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl MediaStreamTrackMethods for MediaStreamTrack {
|
||||||
|
/// https://w3c.github.io/mediacapture-main/#dom-mediastreamtrack-kind
|
||||||
|
fn Kind(&self) -> DOMString {
|
||||||
|
match self.ty {
|
||||||
|
MediaStreamType::Video => "video".into(),
|
||||||
|
MediaStreamType::Audio => "audio".into(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// https://w3c.github.io/mediacapture-main/#dom-mediastreamtrack-id
|
||||||
|
fn Id(&self) -> DOMString {
|
||||||
|
self.id.id().to_string().into()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
|
|
||||||
[Exposed=Window, Pref="dom.webrtc.enabled"]
|
[Exposed=Window, Pref="dom.webrtc.enabled"]
|
||||||
interface MediaStreamTrack : EventTarget {
|
interface MediaStreamTrack : EventTarget {
|
||||||
// readonly attribute DOMString kind;
|
readonly attribute DOMString kind;
|
||||||
// readonly attribute DOMString id;
|
readonly attribute DOMString id;
|
||||||
// readonly attribute DOMString label;
|
// readonly attribute DOMString label;
|
||||||
// attribute boolean enabled;
|
// attribute boolean enabled;
|
||||||
// readonly attribute boolean muted;
|
// readonly attribute boolean muted;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue