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/HTMLMediaElement.cpp

Issue 2466273006: Allow metadata preload on cellular connections and disallow autoplay muted for low end devices. (Closed)
Patch Set: add not allowed value 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
« no previous file with comments | « third_party/WebKit/Source/core/frame/UseCounter.h ('k') | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 8da456fa48e3c9d72688c3ec15b23a0fa74c0947..1d90b0d8fedb9d495cd032a65a8c456d2a276532 100644
--- a/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp
+++ b/third_party/WebKit/Source/core/html/HTMLMediaElement.cpp
@@ -2136,26 +2136,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;
@@ -3899,10 +3906,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;
}
« no previous file with comments | « third_party/WebKit/Source/core/frame/UseCounter.h ('k') | tools/metrics/histograms/histograms.xml » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698