| OLD | NEW |
| 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 #ifndef CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ | 5 #ifndef CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ |
| 6 #define CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ | 6 #define CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ |
| 7 | 7 |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "content/common/content_export.h" | 9 #include "content/common/content_export.h" |
| 10 #include "content/public/browser/native_web_keyboard_event.h" | 10 #include "content/public/browser/native_web_keyboard_event.h" |
| (...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 283 const KeyPressEventCallback& callback) = 0; | 283 const KeyPressEventCallback& callback) = 0; |
| 284 | 284 |
| 285 // Add/remove a callback that can handle all kinds of mouse events. | 285 // Add/remove a callback that can handle all kinds of mouse events. |
| 286 typedef base::Callback<bool(const blink::WebMouseEvent&)> MouseEventCallback; | 286 typedef base::Callback<bool(const blink::WebMouseEvent&)> MouseEventCallback; |
| 287 virtual void AddMouseEventCallback(const MouseEventCallback& callback) = 0; | 287 virtual void AddMouseEventCallback(const MouseEventCallback& callback) = 0; |
| 288 virtual void RemoveMouseEventCallback(const MouseEventCallback& callback) = 0; | 288 virtual void RemoveMouseEventCallback(const MouseEventCallback& callback) = 0; |
| 289 | 289 |
| 290 // Get the screen info corresponding to this render widget. | 290 // Get the screen info corresponding to this render widget. |
| 291 virtual void GetWebScreenInfo(blink::WebScreenInfo* result) = 0; | 291 virtual void GetWebScreenInfo(blink::WebScreenInfo* result) = 0; |
| 292 | 292 |
| 293 // Grabs snapshot from renderer side and returns the bitmap to a callback. | |
| 294 // If |src_rect| is empty, the whole contents is copied. This is an expensive | |
| 295 // operation due to the IPC, but it can be used as a fallback method when | |
| 296 // CopyFromBackingStore fails due to the backing store not being available or, | |
| 297 // in composited mode, when the accelerated surface is not available to the | |
| 298 // browser side. | |
| 299 virtual void GetSnapshotFromRenderer( | |
| 300 const gfx::Rect& src_subrect, | |
| 301 const base::Callback<void(bool, const SkBitmap&)>& callback) = 0; | |
| 302 | |
| 303 virtual SkBitmap::Config PreferredReadbackFormat() = 0; | 293 virtual SkBitmap::Config PreferredReadbackFormat() = 0; |
| 304 | 294 |
| 305 protected: | 295 protected: |
| 306 friend class RenderWidgetHostImpl; | 296 friend class RenderWidgetHostImpl; |
| 307 | 297 |
| 308 // Retrieves the implementation class. Intended only for code | 298 // Retrieves the implementation class. Intended only for code |
| 309 // within content/. This method is necessary because | 299 // within content/. This method is necessary because |
| 310 // RenderWidgetHost is the root of a diamond inheritance pattern, so | 300 // RenderWidgetHost is the root of a diamond inheritance pattern, so |
| 311 // subclasses inherit it virtually, which removes our ability to | 301 // subclasses inherit it virtually, which removes our ability to |
| 312 // static_cast to the subclass. | 302 // static_cast to the subclass. |
| 313 virtual RenderWidgetHostImpl* AsRenderWidgetHostImpl() = 0; | 303 virtual RenderWidgetHostImpl* AsRenderWidgetHostImpl() = 0; |
| 314 }; | 304 }; |
| 315 | 305 |
| 316 } // namespace content | 306 } // namespace content |
| 317 | 307 |
| 318 #endif // CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ | 308 #endif // CONTENT_PUBLIC_BROWSER_RENDER_WIDGET_HOST_H_ |
| OLD | NEW |