Chromium Code Reviews| 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 |