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

Side by Side Diff: android_webview/renderer/aw_render_view_ext.cc

Issue 12041009: [Android WebView] Migrate the rendering code to a separate set of classes. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "android_webview/renderer/aw_render_view_ext.h" 5 #include "android_webview/renderer/aw_render_view_ext.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "android_webview/common/aw_hit_test_data.h" 9 #include "android_webview/common/aw_hit_test_data.h"
10 #include "android_webview/common/render_view_messages.h" 10 #include "android_webview/common/render_view_messages.h"
(...skipping 30 matching lines...) Expand all
41 return true; 41 return true;
42 } 42 }
43 return false; 43 return false;
44 } 44 }
45 45
46 } 46 }
47 47
48 AwRenderViewExt::AwRenderViewExt(content::RenderView* render_view) 48 AwRenderViewExt::AwRenderViewExt(content::RenderView* render_view)
49 : content::RenderViewObserver(render_view) { 49 : content::RenderViewObserver(render_view) {
50 render_view->GetWebView()->setPermissionClient(this); 50 render_view->GetWebView()->setPermissionClient(this);
51 // TODO(leandrogracia): enable once the feature is available in RenderView.
52 //render_view->SetCapturePictureCallback(
53 // base::Bind(&AwRenderViewExt::OnPictureUpdate, AsWeakPtr()));
54 } 51 }
55 52
56 AwRenderViewExt::~AwRenderViewExt() { 53 AwRenderViewExt::~AwRenderViewExt() {
57 // TODO(leandrogracia): enable once the feature is available in RenderView.
58 //render_view()->SetCapturePictureCallback(
59 // content::RenderView::CapturePictureCallback());
60 RendererPictureMap::GetInstance()->ClearRendererPicture(routing_id());
61 } 54 }
62 55
63 // static 56 // static
64 void AwRenderViewExt::RenderViewCreated(content::RenderView* render_view) { 57 void AwRenderViewExt::RenderViewCreated(content::RenderView* render_view) {
65 new AwRenderViewExt(render_view); // |render_view| takes ownership. 58 new AwRenderViewExt(render_view); // |render_view| takes ownership.
66 } 59 }
67 60
68 bool AwRenderViewExt::OnMessageReceived(const IPC::Message& message) { 61 bool AwRenderViewExt::OnMessageReceived(const IPC::Message& message) {
69 bool handled = true; 62 bool handled = true;
70 IPC_BEGIN_MESSAGE_MAP(AwRenderViewExt, message) 63 IPC_BEGIN_MESSAGE_MAP(AwRenderViewExt, message)
71 IPC_MESSAGE_HANDLER(AwViewMsg_DocumentHasImages, OnDocumentHasImagesRequest) 64 IPC_MESSAGE_HANDLER(AwViewMsg_DocumentHasImages, OnDocumentHasImagesRequest)
72 IPC_MESSAGE_HANDLER(AwViewMsg_DoHitTest, OnDoHitTest) 65 IPC_MESSAGE_HANDLER(AwViewMsg_DoHitTest, OnDoHitTest)
73 IPC_MESSAGE_HANDLER(AwViewMsg_EnableCapturePictureCallback,
74 OnEnableCapturePictureCallback)
75 IPC_MESSAGE_UNHANDLED(handled = false) 66 IPC_MESSAGE_UNHANDLED(handled = false)
76 IPC_END_MESSAGE_MAP() 67 IPC_END_MESSAGE_MAP()
77 return handled; 68 return handled;
78 } 69 }
79 70
80 void AwRenderViewExt::OnDocumentHasImagesRequest(int id) { 71 void AwRenderViewExt::OnDocumentHasImagesRequest(int id) {
81 bool hasImages = false; 72 bool hasImages = false;
82 if (render_view()) { 73 if (render_view()) {
83 WebKit::WebView* webview = render_view()->GetWebView(); 74 WebKit::WebView* webview = render_view()->GetWebView();
84 if (webview) { 75 if (webview) {
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after
186 data.type = AwHitTestData::IMAGE_TYPE; 177 data.type = AwHitTestData::IMAGE_TYPE;
187 data.extra_data_for_type = data.img_src.spec(); 178 data.extra_data_for_type = data.img_src.spec();
188 } else if (result.isContentEditable()) { 179 } else if (result.isContentEditable()) {
189 data.type = AwHitTestData::EDIT_TEXT_TYPE; 180 data.type = AwHitTestData::EDIT_TEXT_TYPE;
190 DCHECK(data.extra_data_for_type.length() == 0); 181 DCHECK(data.extra_data_for_type.length() == 0);
191 } 182 }
192 183
193 Send(new AwViewHostMsg_UpdateHitTestData(routing_id(), data)); 184 Send(new AwViewHostMsg_UpdateHitTestData(routing_id(), data));
194 } 185 }
195 186
196 void AwRenderViewExt::OnEnableCapturePictureCallback(bool enable) {
197 // TODO(leandrogracia): enable once the feature is available in RenderView.
198 //render_view()->SetCapturePictureCallback(enable ?
199 // base::Bind(&AwRenderViewExt::OnPictureUpdate, AsWeakPtr()) :
200 // content::RenderView::CapturePictureCallback());
201 }
202
203 void AwRenderViewExt::OnPictureUpdate(skia::RefPtr<SkPicture> picture) {
204 RendererPictureMap::GetInstance()->SetRendererPicture(routing_id(), picture);
205 Send(new AwViewHostMsg_PictureUpdated(routing_id()));
206 }
207
208 } // namespace android_webview 187 } // namespace android_webview
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698