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

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

Issue 2243473002: Adding overflow menu to media player (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 4 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 439d99210e77e9af92bf438d7df587fef0aa61a0..1fd533eb97e38c99b37adeaa4239f4f77ab91cf3 100644
--- a/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
+++ b/third_party/WebKit/Source/core/html/shadow/MediaControls.cpp
@@ -117,6 +117,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 +247,24 @@ 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"));
whywhat 2016/08/19 23:56:55 do we have these elements in the media element's d
kdsilva 2016/08/24 05:33:27 liberato@, Anton mentioned you might have recommen
liberato (no reviews please) 2016/08/24 16:44:22 i've had bad luck doing anything too complicated i
}
void MediaControls::reset()
@@ -433,6 +456,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 +491,7 @@ void MediaControls::updateVolume()
void MediaControls::changedClosedCaptionsVisibility()
{
m_toggleClosedCaptionsButton->updateDisplayType();
+ m_ClosedCaptionsOverflowButton->updateDisplayType();
}
void MediaControls::refreshClosedCaptionsButtonVisibility()
@@ -689,8 +715,8 @@ void MediaControls::computeWhichControlsFit()
// Controls that we'll hide / show, in order of decreasing priority.
MediaControlElement* elements[] = {
// Exclude m_playButton; we handle it specially.
- m_toggleClosedCaptionsButton.get(),
m_fullScreenButton.get(),
+ m_toggleClosedCaptionsButton.get(),
whywhat 2016/08/19 23:56:55 I thought this was fixed by another cl? Do you nee
kdsilva 2016/08/24 05:33:26 Done.
m_timeline.get(),
m_currentTimeDisplay.get(),
m_volumeSlider.get(),
@@ -730,6 +756,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 +774,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() >= 2 && !mediaElement().isFullscreen()) {
whywhat 2016/08/19 23:56:55 2 is a magic constant (which is not 0 or 1). pleas
kdsilva 2016/08/24 05:33:26 Done.
+ m_overflowList->setOverflowMenuControls(overflowControls);
+ m_overflowMenu->setIsWanted(true);
+ } else {
+ m_overflowMenu->setIsWanted(false);
+ m_overflowList->setVisible(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 +825,22 @@ void MediaControls::networkStateChanged()
invalidate(m_volumeSlider);
}
+bool MediaControls::overflowMenuVisible()
+{
+ return m_overflowList->isWanted();
+}
+
+void MediaControls::toggleOverflowMenu()
+{
+ m_overflowList->setVisible(!m_overflowList->isWanted());
+}
+
+std::vector<MediaControlInputElement*> MediaControls::getOverflowMenuButtons()
+{
+ std::vector<MediaControlInputElement*> controlsListOverflow = { m_muteOverflowButton, m_ClosedCaptionsOverflowButton, m_castOverflowButton, m_fullscreenOverflowButton };
whywhat 2016/08/19 23:56:55 creating a new vector and passing it around seems
kdsilva 2016/08/24 05:33:27 Done. I made controlsListOverflow a private member
+ return controlsListOverflow;
+}
+
DEFINE_TRACE(MediaControls)
{
visitor->trace(m_mediaElement);
@@ -800,6 +857,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);

Powered by Google App Engine
This is Rietveld 408576698