| 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 8c0f1083541509794c61c292e4bc9b1401602d05..639242cad9fdaa1d88952373df192c68b6c034ca 100644
|
| --- a/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
|
| +++ b/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
|
| @@ -42,6 +42,9 @@ namespace blink {
|
| // LayoutTests/media/media-controls.js.
|
| static const double timeWithoutMouseMovementBeforeHidingMediaControls = 3;
|
|
|
| +// We only want to show the overflow menu if it contains at least two buttons
|
| +static const int minOverflowMenuControlElementsNum = 2;
|
| +
|
| static bool shouldShowFullscreenButton(const HTMLMediaElement& mediaElement)
|
| {
|
| // Unconditionally allow the user to exit fullscreen if we are in it
|
| @@ -117,6 +120,11 @@ MediaControls::MediaControls(HTMLMediaElement& mediaElement)
|
| , m_volumeSlider(nullptr)
|
| , m_toggleClosedCaptionsButton(nullptr)
|
| , m_textTrackList(nullptr)
|
| + , m_overflowList(nullptr)
|
| + , m_muteOverflowButton(nullptr)
|
| + , m_castOverflowButton(nullptr)
|
| + , m_closedCaptionsOverflowButton(nullptr)
|
| + , m_fullscreenOverflowButton(nullptr)
|
| , m_castButton(nullptr)
|
| , m_fullScreenButton(nullptr)
|
| , m_hideMediaControlsTimer(this, &MediaControls::hideMediaControlsTimerFired)
|
| @@ -242,6 +250,26 @@ void MediaControls::initializeControls()
|
| MediaControlTextTrackListElement* textTrackList = MediaControlTextTrackListElement::create(*this);
|
| m_textTrackList = textTrackList;
|
| appendChild(textTrackList);
|
| +
|
| + MediaControlOverflowMenu* overflowMenu = MediaControlOverflowMenu::create(*this);
|
| + m_overflowMenu = overflowMenu;
|
| + panel->appendChild(overflowMenu);
|
| +
|
| + MediaControlOverflowMenuListElement* overflowList = MediaControlOverflowMenuListElement::create(*this);
|
| + m_overflowList = overflowList;
|
| + appendChild(overflowList);
|
| +
|
| + m_muteOverflowButton = MediaControlMuteButtonElement::create(*this);
|
| + m_castOverflowButton = MediaControlCastButtonElement::create(*this, false);
|
| + m_closedCaptionsOverflowButton = MediaControlToggleClosedCaptionsButtonElement::create(*this);
|
| + m_fullscreenOverflowButton = MediaControlFullscreenButtonElement::create(*this);
|
| +
|
| + m_muteOverflowButton->setShadowPseudoId(AtomicString("-internal-media-controls-overflow-menu-list-item-element"));
|
| + m_castOverflowButton->setShadowPseudoId(AtomicString("-internal-media-controls-overflow-menu-list-item-element"));
|
| + m_closedCaptionsOverflowButton->setShadowPseudoId(AtomicString("-internal-media-controls-overflow-menu-list-item-element"));
|
| + m_fullscreenOverflowButton->setShadowPseudoId(AtomicString("-internal-media-controls-overflow-menu-list-item-element"));
|
| +
|
| + controlsListOverflow = { m_muteOverflowButton, m_closedCaptionsOverflowButton, m_castOverflowButton, m_fullscreenOverflowButton };
|
| }
|
|
|
| void MediaControls::reset()
|
| @@ -433,6 +461,8 @@ void MediaControls::updateCurrentTimeDisplay()
|
| void MediaControls::updateVolume()
|
| {
|
| m_muteButton->updateDisplayType();
|
| + m_muteOverflowButton->updateDisplayType();
|
| +
|
| // Invalidate the mute button because it paints differently according to volume.
|
| invalidate(m_muteButton);
|
|
|
| @@ -466,6 +496,7 @@ void MediaControls::updateVolume()
|
| void MediaControls::changedClosedCaptionsVisibility()
|
| {
|
| m_toggleClosedCaptionsButton->updateDisplayType();
|
| + m_closedCaptionsOverflowButton->updateDisplayType();
|
| }
|
|
|
| void MediaControls::refreshClosedCaptionsButtonVisibility()
|
| @@ -730,6 +761,10 @@ void MediaControls::computeWhichControlsFit()
|
| return;
|
| }
|
|
|
| + // Controls that don't fit within the media player that could be included
|
| + // in an overflow menu.
|
| + std::set<MediaControlElementType> overflowControls;
|
| +
|
| // For each control that fits, enable it in order of decreasing priority.
|
| bool droppedCastButton = false;
|
| for (MediaControlElement* element : elements) {
|
| @@ -744,10 +779,21 @@ void MediaControls::computeWhichControlsFit()
|
| element->setDoesFit(false);
|
| if (element == m_castButton.get())
|
| droppedCastButton = true;
|
| + overflowControls.insert(element->displayType());
|
| }
|
| }
|
| }
|
|
|
| + // We display an overflow menu only when we have at least two items
|
| + // within it.
|
| + if (overflowControls.size() >= minOverflowMenuControlElementsNum) {
|
| + m_overflowList->setOverflowMenuControls(&overflowControls);
|
| + m_overflowMenu->setIsWanted(true);
|
| + } else {
|
| + m_overflowMenu->setIsWanted(false);
|
| + m_overflowList->showOverflowMenu(false);
|
| + }
|
| +
|
| // Special case for cast: if we want a cast button but dropped it, then
|
| // show the overlay cast button instead.
|
| if (m_castButton->isWanted()) {
|
| @@ -784,6 +830,21 @@ void MediaControls::networkStateChanged()
|
| invalidate(m_volumeSlider);
|
| }
|
|
|
| +bool MediaControls::overflowMenuVisible()
|
| +{
|
| + return m_overflowList->isWanted();
|
| +}
|
| +
|
| +void MediaControls::toggleOverflowMenu()
|
| +{
|
| + m_overflowList->showOverflowMenu(!m_overflowList->isWanted());
|
| +}
|
| +
|
| +std::vector<MediaControlInputElement*> MediaControls::getOverflowMenuButtons()
|
| +{
|
| + return controlsListOverflow;
|
| +}
|
| +
|
| DEFINE_TRACE(MediaControls)
|
| {
|
| visitor->trace(m_mediaElement);
|
| @@ -800,6 +861,12 @@ DEFINE_TRACE(MediaControls)
|
| visitor->trace(m_durationDisplay);
|
| visitor->trace(m_enclosure);
|
| visitor->trace(m_textTrackList);
|
| + visitor->trace(m_overflowMenu);
|
| + visitor->trace(m_overflowList);
|
| + visitor->trace(m_muteOverflowButton);
|
| + visitor->trace(m_castOverflowButton);
|
| + visitor->trace(m_closedCaptionsOverflowButton);
|
| + visitor->trace(m_fullscreenOverflowButton);
|
| visitor->trace(m_castButton);
|
| visitor->trace(m_overlayCastButton);
|
| HTMLDivElement::trace(visitor);
|
|
|