mirror of
https://github.com/servo/servo.git
synced 2025-08-07 14:35:33 +01:00
Integrates media track selection
This commit is contained in:
parent
4fe8238b14
commit
5ea79c64f9
5 changed files with 88 additions and 14 deletions
|
@ -4,8 +4,9 @@
|
|||
|
||||
use crate::dom::bindings::codegen::Bindings::VideoTrackBinding::{self, VideoTrackMethods};
|
||||
use crate::dom::bindings::reflector::{reflect_dom_object, Reflector};
|
||||
use crate::dom::bindings::root::DomRoot;
|
||||
use crate::dom::bindings::root::{Dom, DomRoot};
|
||||
use crate::dom::bindings::str::DOMString;
|
||||
use crate::dom::videotracklist::VideoTrackList;
|
||||
use crate::dom::window::Window;
|
||||
use dom_struct::dom_struct;
|
||||
use std::cell::Cell;
|
||||
|
@ -18,6 +19,7 @@ pub struct VideoTrack {
|
|||
label: DOMString,
|
||||
language: DOMString,
|
||||
selected: Cell<bool>,
|
||||
track_list: Option<Dom<VideoTrackList>>,
|
||||
}
|
||||
|
||||
impl VideoTrack {
|
||||
|
@ -26,6 +28,7 @@ impl VideoTrack {
|
|||
kind: DOMString,
|
||||
label: DOMString,
|
||||
language: DOMString,
|
||||
track_list: Option<&VideoTrackList>,
|
||||
) -> VideoTrack {
|
||||
VideoTrack {
|
||||
reflector_: Reflector::new(),
|
||||
|
@ -34,6 +37,7 @@ impl VideoTrack {
|
|||
label: label.into(),
|
||||
language: language.into(),
|
||||
selected: Cell::new(false),
|
||||
track_list: track_list.map(|t| Dom::from_ref(t)),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -43,9 +47,12 @@ impl VideoTrack {
|
|||
kind: DOMString,
|
||||
label: DOMString,
|
||||
language: DOMString,
|
||||
track_list: Option<&VideoTrackList>,
|
||||
) -> DomRoot<VideoTrack> {
|
||||
reflect_dom_object(
|
||||
Box::new(VideoTrack::new_inherited(id, kind, label, language)),
|
||||
Box::new(VideoTrack::new_inherited(
|
||||
id, kind, label, language, track_list,
|
||||
)),
|
||||
window,
|
||||
VideoTrackBinding::Wrap,
|
||||
)
|
||||
|
@ -96,6 +103,11 @@ impl VideoTrackMethods for VideoTrack {
|
|||
|
||||
// https://html.spec.whatwg.org/multipage/#dom-videotrack-selected
|
||||
fn SetSelected(&self, value: bool) {
|
||||
if let Some(list) = self.track_list.as_ref() {
|
||||
if let Some(idx) = list.find(self) {
|
||||
list.set_selected(idx, value);
|
||||
}
|
||||
}
|
||||
self.set_selected(value);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue