Index: android_webview/renderer/view_renderer.cc |
diff --git a/android_webview/renderer/view_renderer.cc b/android_webview/renderer/view_renderer.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..26c9ccce61199cef9ee3c5bb6818e06e8c37f10f |
--- /dev/null |
+++ b/android_webview/renderer/view_renderer.cc |
@@ -0,0 +1,61 @@ |
+// Copyright (c) 2013 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 "android_webview/renderer/view_renderer.h" |
+ |
+#include "android_webview/common/render_view_messages.h" |
+#include "android_webview/common/renderer_picture_map.h" |
+#include "content/public/renderer/render_view.h" |
+#include "skia/ext/refptr.h" |
+ |
+namespace android_webview { |
+ |
+// static |
+void ViewRenderer::RenderViewCreated(content::RenderView* render_view) { |
+ new ViewRenderer(render_view); // |render_view| takes ownership. |
+} |
+ |
+ViewRenderer::ViewRenderer(content::RenderView* render_view) |
+ : content::RenderViewObserver(render_view), |
+ // TODO(leandrogracia): default to false when SW mode uses Ubercompositor. |
+ // Until then we need picture updates enabled for SW mode invalidation. |
+ // http://crbug.com/170086. |
+ capture_picture_enabled_(true) { |
joth
2013/02/06 20:26:31
unindent
Leandro Graciá Gil
2013/02/07 12:43:56
That's still part of the constructor initializatio
|
+} |
+ |
+ViewRenderer::~ViewRenderer() { |
+ RendererPictureMap::GetInstance()->ClearRendererPicture(routing_id()); |
+} |
+ |
+bool ViewRenderer::OnMessageReceived(const IPC::Message& message) { |
+ bool handled = true; |
+ IPC_BEGIN_MESSAGE_MAP(ViewRenderer, message) |
+ IPC_MESSAGE_HANDLER(AwViewMsg_EnableCapturePictureCallback, |
+ OnEnableCapturePictureCallback) |
+ IPC_MESSAGE_HANDLER(AwViewMsg_CapturePictureSync, |
+ OnCapturePictureSync) |
+ IPC_MESSAGE_UNHANDLED(handled = false) |
+ IPC_END_MESSAGE_MAP() |
+ return handled; |
+} |
+ |
+void ViewRenderer::DidCommitCompositorFrame() { |
+ if (!capture_picture_enabled_) |
+ return; |
+ |
+ //skia::RefPtr<SkPicture> picture = render_view()->CapturePicture(); |
+ //RendererPictureMap::GetInstance()->SetRendererPicture(routing_id(), picture); |
joth
2013/02/06 20:26:31
comment? or remove.
Leandro Graciá Gil
2013/02/07 12:43:56
This is the part of the patch depending on https:/
|
+ Send(new AwViewHostMsg_PictureUpdated(routing_id())); |
+} |
+ |
+void ViewRenderer::OnEnableCapturePictureCallback(bool enable) { |
+ capture_picture_enabled_ = enable; |
+} |
+ |
+void ViewRenderer::OnCapturePictureSync() { |
+ /*RendererPictureMap::GetInstance()->SetRendererPicture( |
+ routing_id(), render_view()->CapturePicture());*/ |
joth
2013/02/06 20:26:31
ditto
Leandro Graciá Gil
2013/02/07 12:43:56
Same as above.
|
+} |
+ |
+} // namespace android_webview |