| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ | 5 #ifndef UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ |
| 6 #define UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ | 6 #define UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ |
| 7 | 7 |
| 8 #include <IOSurface/IOSurface.h> | 8 #include <IOSurface/IOSurface.h> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 | 32 |
| 33 class AcceleratedWidgetMac; | 33 class AcceleratedWidgetMac; |
| 34 | 34 |
| 35 // A class through which an AcceleratedWidget may be bound to draw the contents | 35 // A class through which an AcceleratedWidget may be bound to draw the contents |
| 36 // of an NSView. An AcceleratedWidget may be bound to multiple different views | 36 // of an NSView. An AcceleratedWidget may be bound to multiple different views |
| 37 // throughout its lifetime (one at a time, though). | 37 // throughout its lifetime (one at a time, though). |
| 38 class AcceleratedWidgetMacNSView { | 38 class AcceleratedWidgetMacNSView { |
| 39 public: | 39 public: |
| 40 virtual NSView* AcceleratedWidgetGetNSView() const = 0; | 40 virtual NSView* AcceleratedWidgetGetNSView() const = 0; |
| 41 virtual bool AcceleratedWidgetShouldIgnoreBackpressure() const = 0; | 41 virtual bool AcceleratedWidgetShouldIgnoreBackpressure() const = 0; |
| 42 virtual uint32_t AcceleratedWidgetGetDisplayID() const = 0; |
| 42 virtual void AcceleratedWidgetSwapCompleted( | 43 virtual void AcceleratedWidgetSwapCompleted( |
| 43 const std::vector<ui::LatencyInfo>& latency_info) = 0; | 44 const std::vector<ui::LatencyInfo>& latency_info) = 0; |
| 44 virtual void AcceleratedWidgetHitError() = 0; | 45 virtual void AcceleratedWidgetHitError() = 0; |
| 45 }; | 46 }; |
| 46 | 47 |
| 47 #if defined(__OBJC__) | 48 #if defined(__OBJC__) |
| 48 | 49 |
| 49 // AcceleratedWidgetMac owns a tree of CALayers. The widget may be passed | 50 // AcceleratedWidgetMac owns a tree of CALayers. The widget may be passed |
| 50 // to a ui::Compositor, which will cause, through its output surface, calls to | 51 // to a ui::Compositor, which will cause, through its output surface, calls to |
| 51 // GotAcceleratedFrame and GotSoftwareFrame. The CALayers may be installed | 52 // GotAcceleratedFrame and GotSoftwareFrame. The CALayers may be installed |
| 52 // in an NSView by setting the AcceleratedWidgetMacNSView for the helper. | 53 // in an NSView by setting the AcceleratedWidgetMacNSView for the helper. |
| 53 class ACCELERATED_WIDGET_MAC_EXPORT AcceleratedWidgetMac | 54 class ACCELERATED_WIDGET_MAC_EXPORT AcceleratedWidgetMac |
| 54 : public IOSurfaceLayerClient { | 55 : public IOSurfaceLayerClient { |
| 55 public: | 56 public: |
| 56 explicit AcceleratedWidgetMac(bool needs_gl_finish_workaround); | 57 explicit AcceleratedWidgetMac(bool needs_gl_finish_workaround); |
| 57 virtual ~AcceleratedWidgetMac(); | 58 virtual ~AcceleratedWidgetMac(); |
| 58 | 59 |
| 59 gfx::AcceleratedWidget accelerated_widget() { return native_widget_; } | 60 gfx::AcceleratedWidget accelerated_widget() { return native_widget_; } |
| 60 | 61 |
| 61 void SetNSView(AcceleratedWidgetMacNSView* view); | 62 void SetNSView(AcceleratedWidgetMacNSView* view); |
| 62 void ResetNSView(); | 63 void ResetNSView(); |
| 63 | 64 |
| 64 // Return true if the last frame swapped has a size in DIP of |dip_size|. | 65 // Return true if the last frame swapped has a size in DIP of |dip_size|. |
| 65 bool HasFrameOfSize(const gfx::Size& dip_size) const; | 66 bool HasFrameOfSize(const gfx::Size& dip_size) const; |
| 66 | 67 |
| 67 // Return the CGL renderer ID for the surface, if one is available. | 68 // Return the CGL renderer ID for the surface, if one is available. |
| 68 int GetRendererID() const; | 69 int GetRendererID() const; |
| 69 | 70 |
| 71 // Return the CG display ID for the surface, if known. |
| 72 uint32_t GetDisplayID() const; |
| 73 |
| 70 // Return true if the renderer should not be throttled by GPU back-pressure. | 74 // Return true if the renderer should not be throttled by GPU back-pressure. |
| 71 bool IsRendererThrottlingDisabled() const; | 75 bool IsRendererThrottlingDisabled() const; |
| 72 | 76 |
| 73 // Mark a bracket in which new frames are being pumped in a restricted nested | 77 // Mark a bracket in which new frames are being pumped in a restricted nested |
| 74 // run loop. | 78 // run loop. |
| 75 void BeginPumpingFrames(); | 79 void BeginPumpingFrames(); |
| 76 void EndPumpingFrames(); | 80 void EndPumpingFrames(); |
| 77 | 81 |
| 78 void GotAcceleratedFrame( | 82 void GotAcceleratedFrame( |
| 79 uint64 surface_handle, | 83 uint64 surface_handle, |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 154 #endif // __OBJC__ | 158 #endif // __OBJC__ |
| 155 | 159 |
| 156 ACCELERATED_WIDGET_MAC_EXPORT | 160 ACCELERATED_WIDGET_MAC_EXPORT |
| 157 void AcceleratedWidgetMacGotAcceleratedFrame( | 161 void AcceleratedWidgetMacGotAcceleratedFrame( |
| 158 gfx::AcceleratedWidget widget, uint64 surface_handle, | 162 gfx::AcceleratedWidget widget, uint64 surface_handle, |
| 159 const std::vector<ui::LatencyInfo>& latency_info, | 163 const std::vector<ui::LatencyInfo>& latency_info, |
| 160 const gfx::Size& pixel_size, | 164 const gfx::Size& pixel_size, |
| 161 float scale_factor, | 165 float scale_factor, |
| 162 const gfx::Rect& pixel_damage_rect, | 166 const gfx::Rect& pixel_damage_rect, |
| 163 const base::Closure& drawn_callback, | 167 const base::Closure& drawn_callback, |
| 164 bool* disable_throttling, int* renderer_id); | 168 bool* disable_throttling, int* renderer_id, uint32_t* display_id); |
| 165 | 169 |
| 166 ACCELERATED_WIDGET_MAC_EXPORT | 170 ACCELERATED_WIDGET_MAC_EXPORT |
| 167 void AcceleratedWidgetMacGotSoftwareFrame( | 171 void AcceleratedWidgetMacGotSoftwareFrame( |
| 168 gfx::AcceleratedWidget widget, float scale_factor, SkCanvas* canvas); | 172 gfx::AcceleratedWidget widget, float scale_factor, SkCanvas* canvas); |
| 169 | 173 |
| 170 } // namespace ui | 174 } // namespace ui |
| 171 | 175 |
| 172 #endif // UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ | 176 #endif // UI_ACCELERATED_WIDGET_MAC_ACCELERATED_WIDGET_MAC_H_ |
| OLD | NEW |