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

Unified Diff: chrome/renderer/plugins/plugin_preroller.cc

Issue 866173002: Plugin Power Saver: Add UI Overlay to throttled plugin using placeholder. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 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
« no previous file with comments | « chrome/renderer/plugins/plugin_preroller.h ('k') | chrome/renderer/resources/plugin_poster.html » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/renderer/plugins/plugin_preroller.cc
diff --git a/chrome/renderer/plugins/plugin_preroller.cc b/chrome/renderer/plugins/plugin_preroller.cc
new file mode 100644
index 0000000000000000000000000000000000000000..85ca08a7b4fada0eba47f1aa437705d652fceb38
--- /dev/null
+++ b/chrome/renderer/plugins/plugin_preroller.cc
@@ -0,0 +1,93 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/renderer/plugins/plugin_preroller.h"
+
+#include "base/base64.h"
+#include "chrome/grit/renderer_resources.h"
+#include "chrome/renderer/plugins/chrome_plugin_placeholder.h"
+#include "third_party/WebKit/public/platform/WebRect.h"
+#include "third_party/WebKit/public/web/WebElement.h"
+#include "third_party/WebKit/public/web/WebPlugin.h"
+#include "third_party/WebKit/public/web/WebPluginContainer.h"
+#include "ui/gfx/codec/png_codec.h"
+
+PluginPreroller::PluginPreroller(content::RenderFrame* render_frame,
+ blink::WebLocalFrame* frame,
+ const blink::WebPluginParams& params,
+ const content::WebPluginInfo& info,
+ const std::string& identifier,
+ const base::string16& name,
+ const base::string16& message,
+ blink::WebPlugin* plugin,
+ content::PluginInstanceThrottler* throttler)
+ : render_frame_(render_frame),
+ frame_(frame),
+ params_(params),
+ info_(info),
+ identifier_(identifier),
+ name_(name),
+ message_(message),
+ plugin_(plugin),
+ throttler_(throttler) {
+ DCHECK(plugin);
+ DCHECK(throttler);
+ throttler_->AddObserver(this);
+}
+
+PluginPreroller::~PluginPreroller() {
+ if (throttler_)
+ throttler_->RemoveObserver(this);
+}
+
+void PluginPreroller::OnKeyframeExtracted(const SkBitmap* bitmap) {
+ std::vector<unsigned char> png_data;
+ if (!gfx::PNGCodec::EncodeBGRASkBitmap(*bitmap, false, &png_data)) {
+ DLOG(ERROR) << "Provided keyframe could not be encoded as PNG.";
+ }
+
+ std::string png_as_string(reinterpret_cast<char*>(&png_data[0]),
+ png_data.size());
+
+ std::string data_url_header = "data:image/png;base64,";
+ std::string data_url_body;
+ base::Base64Encode(png_as_string, &data_url_body);
+ keyframe_data_url_ = data_url_header + data_url_body;
+}
+
+void PluginPreroller::OnThrottleStateChange() {
tommycli 2015/01/29 20:02:43 bauerb: Extra scrutiny here. I based this code on
Bernhard Bauer 2015/01/30 14:12:56 Yeah... I'll add some comments below.
+ if (throttler_->IsThrottled()) {
+ ChromePluginPlaceholder* placeholder =
+ ChromePluginPlaceholder::CreateBlockedPlugin(
+ render_frame_, frame_, params_, info_, identifier_, name_,
+ IDR_PLUGIN_POSTER_HTML, message_, GURL(keyframe_data_url_), plugin_,
+ throttler_);
+ placeholder->set_power_saver_mode(
+ content::PluginPowerSaverMode::POWER_SAVER_MODE_PERIPHERAL_THROTTLED);
+ placeholder->set_allow_loading(true);
+
+ // Set the new plug-in on the container before initializing it.
+ blink::WebPluginContainer* container = plugin_->container();
+ container->setPlugin(placeholder->plugin());
+
+ if (!placeholder->plugin()->initialize(container)) {
+ // We couldn't initialize the new plug-in. Restore the old one and abort.
+ container->setPlugin(plugin_);
+ placeholder->plugin()->destroy();
+ delete this;
+ return;
+ }
+
+ placeholder->plugin()->RestoreTitleText();
+ container->invalidate();
+ container->reportGeometry();
+
+ delete this;
+ }
+}
+
+void PluginPreroller::OnThrottlerDestroyed() {
tommycli 2015/01/29 20:02:43 Relying on the fact that when the plugin gets dest
groby-ooo-7-16 2015/01/30 02:22:44 If the throttler's lifetime controls the preroller
Bernhard Bauer 2015/01/30 14:12:56 The Preroller is just an observer of the throttler
groby-ooo-7-16 2015/01/30 15:16:37 Indeed it is. I missed the call to "delete this" i
+ throttler_ = nullptr;
+ delete this;
+}
« no previous file with comments | « chrome/renderer/plugins/plugin_preroller.h ('k') | chrome/renderer/resources/plugin_poster.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698