Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(484)

Unified Diff: third_party/WebKit/Source/core/html/shadow/MediaControls.cpp

Issue 1079323002: Support text track selection in video controls (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed comments from fs Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
diff --git a/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp b/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
index e78e237e5fd378fe3dd1430bdd455906ad4f9cad..359be394b98a466d6695fbb0c612579531ab2fcc 100644
--- a/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
+++ b/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
@@ -112,6 +112,7 @@ MediaControls::MediaControls(HTMLMediaElement& mediaElement)
, m_muteButton(nullptr)
, m_volumeSlider(nullptr)
, m_toggleClosedCaptionsButton(nullptr)
+ , m_textTrackList(nullptr)
, m_castButton(nullptr)
, m_fullScreenButton(nullptr)
, m_hideMediaControlsTimer(this, &MediaControls::hideMediaControlsTimerFired)
@@ -151,6 +152,12 @@ PassRefPtrWillBeRawPtr<MediaControls> MediaControls::create(HTMLMediaElement& me
// +-MediaControlMuteButtonElement (-webkit-media-controls-mute-button)
// +-MediaControlVolumeSliderElement (-webkit-media-controls-volume-slider)
// +-MediaControlToggleClosedCaptionsButtonElement (-webkit-media-controls-toggle-closed-captions-button)
+// +-MediaControlTextTrackListElement (-internal-media-controls-text-track-list)
philipj_slow 2016/03/01 13:01:17 This doesn't match initializeControls(), the Media
srivats 2016/03/30 00:46:43 I moved track list element under MediaControls dir
+// | {for each renderable text track}
+// \-MediaControlTextTrackListItem (-internal-media-controls-text-track-list-item)
+// +-MediaControlTextTrackListItemInput (-internal-media-controls-text-track-list-item-input)
+// +-MediaControlTextTrackListItemCaptions (-internal-media-controls-text-track-list-kind-captions)
+// +-MediaControlTextTrackListItemSubtitles (-internal-media-controls-text-track-list-kind-subtitles)
// +-MediaControlCastButtonElement (-internal-media-controls-cast-button)
// \-MediaControlFullscreenButtonElement (-webkit-media-controls-fullscreen-button)
void MediaControls::initializeControls()
@@ -225,6 +232,10 @@ void MediaControls::initializeControls()
m_panel = panel.get();
enclosure->appendChild(panel.release());
+ RefPtrWillBeRawPtr<MediaControlTextTrackListElement> textTrackList = MediaControlTextTrackListElement::create(*this);
+ m_textTrackList = textTrackList.get();
+ enclosure->appendChild(textTrackList.release());
+
m_enclosure = enclosure.get();
appendChild(enclosure.release());
}
@@ -451,6 +462,14 @@ void MediaControls::refreshClosedCaptionsButtonVisibility()
BatchedControlUpdate batch(this);
}
+void MediaControls::toggleTextTrackList()
+{
+ if (!mediaElement().hasClosedCaptions())
+ return;
philipj_slow 2016/03/01 13:01:16 Won't this early return leave the track list perpe
srivats 2016/03/30 00:46:43 Good catch! I set the visibility to false before r
+
+ m_textTrackList->changeVisibility(m_textTrackList->isHidden());
+}
+
void MediaControls::refreshCastButtonVisibility()
{
refreshCastButtonVisibilityWithoutUpdate();
@@ -750,6 +769,7 @@ DEFINE_TRACE(MediaControls)
visitor->trace(m_fullScreenButton);
visitor->trace(m_durationDisplay);
visitor->trace(m_enclosure);
+ visitor->trace(m_textTrackList);
visitor->trace(m_castButton);
visitor->trace(m_overlayCastButton);
HTMLDivElement::trace(visitor);

Powered by Google App Engine
This is Rietveld 408576698