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_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ |
6 #define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ |
7 | 7 |
8 #import <Cocoa/Cocoa.h> | 8 #import <Cocoa/Cocoa.h> |
9 #include <list> | 9 #include <list> |
10 #include <map> | 10 #include <map> |
11 #include <string> | 11 #include <string> |
12 #include <utility> | 12 #include <utility> |
13 #include <vector> | 13 #include <vector> |
14 | 14 |
15 #include "base/mac/scoped_nsobject.h" | 15 #include "base/mac/scoped_nsobject.h" |
16 #include "base/memory/scoped_ptr.h" | 16 #include "base/memory/scoped_ptr.h" |
17 #include "base/memory/weak_ptr.h" | 17 #include "base/memory/weak_ptr.h" |
18 #include "base/time/time.h" | 18 #include "base/time/time.h" |
| 19 #include "content/browser/compositor/browser_compositor_view_mac.h" |
19 #include "content/browser/compositor/delegated_frame_host.h" | 20 #include "content/browser/compositor/delegated_frame_host.h" |
20 #include "content/browser/renderer_host/compositing_iosurface_layer_mac.h" | 21 #include "content/browser/renderer_host/compositing_iosurface_layer_mac.h" |
21 #include "content/browser/renderer_host/display_link_mac.h" | 22 #include "content/browser/renderer_host/display_link_mac.h" |
22 #include "content/browser/renderer_host/render_widget_host_view_base.h" | 23 #include "content/browser/renderer_host/render_widget_host_view_base.h" |
23 #include "content/browser/renderer_host/software_frame_manager.h" | 24 #include "content/browser/renderer_host/software_frame_manager.h" |
24 #include "content/common/content_export.h" | 25 #include "content/common/content_export.h" |
25 #include "content/common/cursors/webcursor.h" | 26 #include "content/common/cursors/webcursor.h" |
26 #include "content/common/edit_command.h" | 27 #include "content/common/edit_command.h" |
27 #import "content/public/browser/render_widget_host_view_mac_base.h" | 28 #import "content/public/browser/render_widget_host_view_mac_base.h" |
28 #include "ipc/ipc_sender.h" | 29 #include "ipc/ipc_sender.h" |
(...skipping 177 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
206 // "The lifetime of the RenderWidgetHost* is tied to the render process. | 207 // "The lifetime of the RenderWidgetHost* is tied to the render process. |
207 // If the render process dies, the RenderWidgetHost* goes away and all | 208 // If the render process dies, the RenderWidgetHost* goes away and all |
208 // references to it must become NULL." | 209 // references to it must become NULL." |
209 // | 210 // |
210 // RenderWidgetHostView class hierarchy described in render_widget_host_view.h. | 211 // RenderWidgetHostView class hierarchy described in render_widget_host_view.h. |
211 class CONTENT_EXPORT RenderWidgetHostViewMac | 212 class CONTENT_EXPORT RenderWidgetHostViewMac |
212 : public RenderWidgetHostViewBase, | 213 : public RenderWidgetHostViewBase, |
213 public DelegatedFrameHostClient, | 214 public DelegatedFrameHostClient, |
214 public IPC::Sender, | 215 public IPC::Sender, |
215 public SoftwareFrameManagerClient, | 216 public SoftwareFrameManagerClient, |
| 217 public BrowserCompositorViewMacClient, |
216 public CompositingIOSurfaceLayerClient { | 218 public CompositingIOSurfaceLayerClient { |
217 public: | 219 public: |
218 // The view will associate itself with the given widget. The native view must | 220 // The view will associate itself with the given widget. The native view must |
219 // be hooked up immediately to the view hierarchy, or else when it is | 221 // be hooked up immediately to the view hierarchy, or else when it is |
220 // deleted it will delete this out from under the caller. | 222 // deleted it will delete this out from under the caller. |
221 explicit RenderWidgetHostViewMac(RenderWidgetHost* widget); | 223 explicit RenderWidgetHostViewMac(RenderWidgetHost* widget); |
222 virtual ~RenderWidgetHostViewMac(); | 224 virtual ~RenderWidgetHostViewMac(); |
223 | 225 |
224 RenderWidgetHostViewCocoa* cocoa_view() const { return cocoa_view_; } | 226 RenderWidgetHostViewCocoa* cocoa_view() const { return cocoa_view_; } |
225 | 227 |
(...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
336 // IPC::Sender implementation. | 338 // IPC::Sender implementation. |
337 virtual bool Send(IPC::Message* message) OVERRIDE; | 339 virtual bool Send(IPC::Message* message) OVERRIDE; |
338 | 340 |
339 // SoftwareFrameManagerClient implementation: | 341 // SoftwareFrameManagerClient implementation: |
340 virtual void SoftwareFrameWasFreed( | 342 virtual void SoftwareFrameWasFreed( |
341 uint32 output_surface_id, unsigned frame_id) OVERRIDE; | 343 uint32 output_surface_id, unsigned frame_id) OVERRIDE; |
342 virtual void ReleaseReferencesToSoftwareFrame() OVERRIDE; | 344 virtual void ReleaseReferencesToSoftwareFrame() OVERRIDE; |
343 | 345 |
344 virtual SkBitmap::Config PreferredReadbackFormat() OVERRIDE; | 346 virtual SkBitmap::Config PreferredReadbackFormat() OVERRIDE; |
345 | 347 |
| 348 // BrowserCompositorViewMacHelper implementation. |
| 349 virtual void BrowserCompositorDidDrawFrame() OVERRIDE; |
| 350 |
346 // CompositingIOSurfaceLayerClient implementation. | 351 // CompositingIOSurfaceLayerClient implementation. |
347 virtual void AcceleratedLayerDidDrawFrame(bool succeeded) OVERRIDE; | 352 virtual void AcceleratedLayerDidDrawFrame(bool succeeded) OVERRIDE; |
348 | 353 |
349 // Forwards the mouse event to the renderer. | 354 // Forwards the mouse event to the renderer. |
350 void ForwardMouseEvent(const blink::WebMouseEvent& event); | 355 void ForwardMouseEvent(const blink::WebMouseEvent& event); |
351 | 356 |
352 void KillSelf(); | 357 void KillSelf(); |
353 | 358 |
354 void SetTextInputActive(bool active); | 359 void SetTextInputActive(bool active); |
355 | 360 |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
441 // destroyed together in Create/DestroyCompositedIOSurfaceAndLayer. | 446 // destroyed together in Create/DestroyCompositedIOSurfaceAndLayer. |
442 base::scoped_nsobject<CompositingIOSurfaceLayer> compositing_iosurface_layer_; | 447 base::scoped_nsobject<CompositingIOSurfaceLayer> compositing_iosurface_layer_; |
443 scoped_refptr<CompositingIOSurfaceMac> compositing_iosurface_; | 448 scoped_refptr<CompositingIOSurfaceMac> compositing_iosurface_; |
444 scoped_refptr<CompositingIOSurfaceContext> compositing_iosurface_context_; | 449 scoped_refptr<CompositingIOSurfaceContext> compositing_iosurface_context_; |
445 | 450 |
446 // Delegated frame management and compositior. | 451 // Delegated frame management and compositior. |
447 base::scoped_nsobject<BrowserCompositorViewMac> browser_compositor_view_; | 452 base::scoped_nsobject<BrowserCompositorViewMac> browser_compositor_view_; |
448 scoped_ptr<DelegatedFrameHost> delegated_frame_host_; | 453 scoped_ptr<DelegatedFrameHost> delegated_frame_host_; |
449 scoped_ptr<ui::Layer> root_layer_; | 454 scoped_ptr<ui::Layer> root_layer_; |
450 | 455 |
| 456 // This lock is taken when the browser compositor produces a frame, and is |
| 457 // released when that frame is displayed. It is by this mechanism that the |
| 458 // browser compositor can exert GPU backpressure on the renderer compositor. |
| 459 scoped_refptr<ui::CompositorLock> browser_compositor_lock_; |
| 460 bool browser_compositor_damaged_during_lock_; |
| 461 |
451 // This holds the current software compositing framebuffer, if any. | 462 // This holds the current software compositing framebuffer, if any. |
452 scoped_ptr<SoftwareFrameManager> software_frame_manager_; | 463 scoped_ptr<SoftwareFrameManager> software_frame_manager_; |
453 | 464 |
454 // Whether to allow overlapping views. | 465 // Whether to allow overlapping views. |
455 bool allow_overlapping_views_; | 466 bool allow_overlapping_views_; |
456 | 467 |
457 // Whether to use the CoreAnimation path to draw content. | 468 // Whether to use the CoreAnimation path to draw content. |
458 bool use_core_animation_; | 469 bool use_core_animation_; |
459 | 470 |
460 // Latency info to send back when the next frame appears on the | 471 // Latency info to send back when the next frame appears on the |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
511 // all of them using this function when any of those parameters changes. Also | 522 // all of them using this function when any of those parameters changes. Also |
512 // update the scale factor of the layers. | 523 // update the scale factor of the layers. |
513 void LayoutLayers(); | 524 void LayoutLayers(); |
514 | 525 |
515 // DelegatedFrameHostClient implementation. | 526 // DelegatedFrameHostClient implementation. |
516 virtual ui::Compositor* GetCompositor() const OVERRIDE; | 527 virtual ui::Compositor* GetCompositor() const OVERRIDE; |
517 virtual ui::Layer* GetLayer() OVERRIDE; | 528 virtual ui::Layer* GetLayer() OVERRIDE; |
518 virtual RenderWidgetHostImpl* GetHost() OVERRIDE; | 529 virtual RenderWidgetHostImpl* GetHost() OVERRIDE; |
519 virtual void SchedulePaintInRect( | 530 virtual void SchedulePaintInRect( |
520 const gfx::Rect& damage_rect_in_dip) OVERRIDE; | 531 const gfx::Rect& damage_rect_in_dip) OVERRIDE; |
| 532 virtual void DelegatedCompositorDidSwapBuffers() OVERRIDE; |
| 533 virtual void DelegatedCompositorAbortedSwapBuffers() OVERRIDE; |
521 virtual bool IsVisible() OVERRIDE; | 534 virtual bool IsVisible() OVERRIDE; |
522 virtual scoped_ptr<ResizeLock> CreateResizeLock( | 535 virtual scoped_ptr<ResizeLock> CreateResizeLock( |
523 bool defer_compositor_lock) OVERRIDE; | 536 bool defer_compositor_lock) OVERRIDE; |
524 virtual gfx::Size DesiredFrameSize() OVERRIDE; | 537 virtual gfx::Size DesiredFrameSize() OVERRIDE; |
525 virtual float CurrentDeviceScaleFactor() OVERRIDE; | 538 virtual float CurrentDeviceScaleFactor() OVERRIDE; |
526 virtual gfx::Size ConvertViewSizeToPixel(const gfx::Size& size) OVERRIDE; | 539 virtual gfx::Size ConvertViewSizeToPixel(const gfx::Size& size) OVERRIDE; |
527 virtual DelegatedFrameHost* GetDelegatedFrameHost() const OVERRIDE; | 540 virtual DelegatedFrameHost* GetDelegatedFrameHost() const OVERRIDE; |
528 | 541 |
529 private: | 542 private: |
530 friend class RenderWidgetHostViewMacTest; | 543 friend class RenderWidgetHostViewMacTest; |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
583 void OnDidChangeScrollbarsForMainFrame(bool has_horizontal_scrollbar, | 596 void OnDidChangeScrollbarsForMainFrame(bool has_horizontal_scrollbar, |
584 bool has_vertical_scrollbar); | 597 bool has_vertical_scrollbar); |
585 | 598 |
586 // Convert |rect| from the views coordinate (upper-left origin) into | 599 // Convert |rect| from the views coordinate (upper-left origin) into |
587 // the OpenGL coordinate (lower-left origin) and scale for HiDPI displays. | 600 // the OpenGL coordinate (lower-left origin) and scale for HiDPI displays. |
588 gfx::Rect GetScaledOpenGLPixelRect(const gfx::Rect& rect); | 601 gfx::Rect GetScaledOpenGLPixelRect(const gfx::Rect& rect); |
589 | 602 |
590 // Send updated vsync parameters to the renderer. | 603 // Send updated vsync parameters to the renderer. |
591 void SendVSyncParametersToRenderer(); | 604 void SendVSyncParametersToRenderer(); |
592 | 605 |
| 606 // Release the browser compositor lock, and request another frame from the |
| 607 // browser compositor. Because this can be requested from inside compositor |
| 608 // calbacks, post it as task instead of calling it directly. |
| 609 void PostReleaseBrowserCompositorLock(); |
| 610 void ReleaseBrowserCompositorLock(); |
| 611 |
593 // The associated view. This is weak and is inserted into the view hierarchy | 612 // The associated view. This is weak and is inserted into the view hierarchy |
594 // to own this RenderWidgetHostViewMac object. Set to nil at the start of the | 613 // to own this RenderWidgetHostViewMac object. Set to nil at the start of the |
595 // destructor. | 614 // destructor. |
596 RenderWidgetHostViewCocoa* cocoa_view_; | 615 RenderWidgetHostViewCocoa* cocoa_view_; |
597 | 616 |
598 // Indicates if the page is loading. | 617 // Indicates if the page is loading. |
599 bool is_loading_; | 618 bool is_loading_; |
600 | 619 |
601 // The text to be shown in the tooltip, supplied by the renderer. | 620 // The text to be shown in the tooltip, supplied by the renderer. |
602 base::string16 tooltip_text_; | 621 base::string16 tooltip_text_; |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
651 scoped_ptr<RenderWidgetHostViewFrameSubscriber> frame_subscriber_; | 670 scoped_ptr<RenderWidgetHostViewFrameSubscriber> frame_subscriber_; |
652 | 671 |
653 base::WeakPtrFactory<RenderWidgetHostViewMac> | 672 base::WeakPtrFactory<RenderWidgetHostViewMac> |
654 software_frame_weak_ptr_factory_; | 673 software_frame_weak_ptr_factory_; |
655 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewMac); | 674 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewMac); |
656 }; | 675 }; |
657 | 676 |
658 } // namespace content | 677 } // namespace content |
659 | 678 |
660 #endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ | 679 #endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_MAC_H_ |
OLD | NEW |