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

Unified Diff: third_party/WebKit/Source/core/html/HTMLMediaElement.cpp

Issue 2466273006: Allow metadata preload on cellular connections and disallow autoplay muted for low end devices. (Closed)
Patch Set: Created 4 years, 1 month 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/HTMLMediaElement.cpp
diff --git a/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp b/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp
index 56ad755a6e9c9743151d0a62dc99d5335758bdd9..c63b9404b7952a764b59888a601cad7356ea4448 100644
--- a/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp
+++ b/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp
@@ -2065,26 +2065,33 @@ void HTMLMediaElement::setPreload(const AtomicString& preload) {
}
WebMediaPlayer::Preload HTMLMediaElement::preloadType() const {
- // Force preload to none for cellular connections or when data saver is
- // explicitly set.
- if (networkStateNotifier().isCellularConnectionType() ||
- (document().settings() &&
- (document().settings()->dataSaverEnabled() ||
- document().settings()->forcePreloadNoneForMediaElements()))) {
- UseCounter::count(document(),
- UseCounter::HTMLMediaElementPreloadForcedNone);
- return WebMediaPlayer::PreloadNone;
- }
-
const AtomicString& preload = fastGetAttribute(preloadAttr);
if (equalIgnoringCase(preload, "none")) {
UseCounter::count(document(), UseCounter::HTMLMediaElementPreloadNone);
return WebMediaPlayer::PreloadNone;
}
+
+ // Force preload to 'none' on Data Saver and for low end devices.
+ if (document().settings() &&
+ (document().settings()->dataSaverEnabled() ||
+ document().settings()->forcePreloadNoneForMediaElements())) {
+ UseCounter::count(document(),
+ UseCounter::HTMLMediaElementPreloadForcedNone);
+ return WebMediaPlayer::PreloadNone;
+ }
+
if (equalIgnoringCase(preload, "metadata")) {
UseCounter::count(document(), UseCounter::HTMLMediaElementPreloadMetadata);
return WebMediaPlayer::PreloadMetaData;
}
+
+ // Force preload to 'metadata' on cellular connections.
+ if (networkStateNotifier().isCellularConnectionType()) {
+ UseCounter::count(document(),
+ UseCounter::HTMLMediaElementPreloadForcedMetadata);
+ return WebMediaPlayer::PreloadMetaData;
+ }
+
if (equalIgnoringCase(preload, "auto")) {
UseCounter::count(document(), UseCounter::HTMLMediaElementPreloadAuto);
return WebMediaPlayer::PreloadAuto;
@@ -3806,10 +3813,13 @@ bool HTMLMediaElement::isGestureNeededForPlayback() const {
// We want to allow muted video to autoplay if:
// - the flag is enabled;
// - Data Saver is not enabled;
+ // - Preload was not disabled (low end devices);
// - Autoplay is enabled in settings;
if (isHTMLVideoElement() && muted() &&
RuntimeEnabledFeatures::autoplayMutedVideosEnabled() &&
!(document().settings() && document().settings()->dataSaverEnabled()) &&
+ !(document().settings() &&
+ document().settings()->forcePreloadNoneForMediaElements()) &&
isAutoplayAllowedPerSettings()) {
return false;
}

Powered by Google App Engine
This is Rietveld 408576698