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 2457498280867bd3c37567c36fd2aaca50e49adb..b2ba2c988428d6c4a61ef158a703fa64435973af 100644 |
--- a/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp |
+++ b/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp |
@@ -113,6 +113,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) |
@@ -154,6 +155,12 @@ MediaControls* MediaControls::create(HTMLMediaElement& mediaElement) |
// +-MediaControlToggleClosedCaptionsButtonElement (-webkit-media-controls-toggle-closed-captions-button) |
// +-MediaControlCastButtonElement (-internal-media-controls-cast-button) |
// \-MediaControlFullscreenButtonElement (-webkit-media-controls-fullscreen-button) |
+// +-MediaControlTextTrackListElement (-internal-media-controls-text-track-list) |
+// | {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) |
void MediaControls::initializeControls() |
{ |
const bool useNewUi = RuntimeEnabledFeatures::newMediaPlaybackUiEnabled(); |
@@ -228,6 +235,10 @@ void MediaControls::initializeControls() |
m_enclosure = enclosure; |
appendChild(enclosure); |
+ |
+ MediaControlTextTrackListElement* textTrackList = MediaControlTextTrackListElement::create(*this); |
+ m_textTrackList = textTrackList; |
+ appendChild(textTrackList); |
} |
void MediaControls::reset() |
@@ -331,6 +342,9 @@ bool MediaControls::shouldHideMediaControls(unsigned behaviorFlags) const |
const bool ignoreFocus = behaviorFlags & IgnoreFocus; |
if (!ignoreFocus && (mediaElement().focused() || contains(document().focusedElement()))) |
return false; |
+ // Don't hide the media controls when the text track list is showing. |
+ if (m_textTrackList->isWanted()) |
+ return false; |
return true; |
} |
@@ -457,6 +471,16 @@ void MediaControls::refreshClosedCaptionsButtonVisibility() |
BatchedControlUpdate batch(this); |
} |
+void MediaControls::toggleTextTrackList() |
+{ |
+ if (!mediaElement().hasClosedCaptions()) { |
+ m_textTrackList->setVisible(false); |
+ return; |
+ } |
+ |
+ m_textTrackList->setVisible(!m_textTrackList->isWanted()); |
+} |
+ |
void MediaControls::refreshCastButtonVisibility() |
{ |
refreshCastButtonVisibilityWithoutUpdate(); |
@@ -756,6 +780,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); |