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 #include "content/browser/compositor/browser_compositor_view_mac.h" | 5 #include "content/browser/compositor/browser_compositor_view_mac.h" |
6 | 6 |
7 #include "base/debug/trace_event.h" | 7 #include "base/debug/trace_event.h" |
8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
9 #include "content/browser/gpu/gpu_process_host_ui_shim.h" | 9 #include "content/browser/gpu/gpu_process_host_ui_shim.h" |
10 #include "content/browser/compositor/browser_compositor_ca_layer_tree_mac.h" | 10 #include "content/browser/compositor/browser_compositor_ca_layer_tree_mac.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 // |g_recyclable_ca_layer_tree|, will be freed. | 21 // |g_recyclable_ca_layer_tree|, will be freed. |
22 uint32 g_placeholder_count = 0; | 22 uint32 g_placeholder_count = 0; |
23 | 23 |
24 // A spare BrowserCompositorCALayerTreeMac kept around for recycling. | 24 // A spare BrowserCompositorCALayerTreeMac kept around for recycling. |
25 base::LazyInstance<scoped_ptr<BrowserCompositorCALayerTreeMac>> | 25 base::LazyInstance<scoped_ptr<BrowserCompositorCALayerTreeMac>> |
26 g_recyclable_ca_layer_tree; | 26 g_recyclable_ca_layer_tree; |
27 | 27 |
28 } // namespace | 28 } // namespace |
29 | 29 |
30 BrowserCompositorViewMac::BrowserCompositorViewMac( | 30 BrowserCompositorViewMac::BrowserCompositorViewMac( |
31 BrowserCompositorViewMacClient* client) : client_(client) { | 31 BrowserCompositorViewMacClient* client, |
| 32 NSView* native_view, |
| 33 ui::Layer* ui_root_layer) |
| 34 : client_(client), |
| 35 native_view_(native_view), |
| 36 ui_root_layer_(ui_root_layer) { |
32 // Try to use the recyclable BrowserCompositorCALayerTreeMac if there is one, | 37 // Try to use the recyclable BrowserCompositorCALayerTreeMac if there is one, |
33 // otherwise allocate a new one. | 38 // otherwise allocate a new one. |
34 // TODO(ccameron): If there exists a frame in flight (swap has been called | 39 // TODO(ccameron): If there exists a frame in flight (swap has been called |
35 // by the compositor, but the frame has not arrived from the GPU process | 40 // by the compositor, but the frame has not arrived from the GPU process |
36 // yet), then that frame may inappropriately flash in the new view. | 41 // yet), then that frame may inappropriately flash in the new view. |
37 ca_layer_tree_ = g_recyclable_ca_layer_tree.Get().Pass(); | 42 ca_layer_tree_ = g_recyclable_ca_layer_tree.Get().Pass(); |
38 if (!ca_layer_tree_) | 43 if (!ca_layer_tree_) |
39 ca_layer_tree_.reset(new BrowserCompositorCALayerTreeMac); | 44 ca_layer_tree_.reset(new BrowserCompositorCALayerTreeMac); |
40 ca_layer_tree_->SetClient(client_); | 45 ca_layer_tree_->SetView(this); |
41 } | 46 } |
42 | 47 |
43 BrowserCompositorViewMac::~BrowserCompositorViewMac() { | 48 BrowserCompositorViewMac::~BrowserCompositorViewMac() { |
44 // Make this BrowserCompositorCALayerTreeMac recyclable for future instances. | 49 // Make this BrowserCompositorCALayerTreeMac recyclable for future instances. |
45 ca_layer_tree_->ResetClient(); | 50 ca_layer_tree_->ResetView(); |
46 g_recyclable_ca_layer_tree.Get() = ca_layer_tree_.Pass(); | 51 g_recyclable_ca_layer_tree.Get() = ca_layer_tree_.Pass(); |
47 | 52 |
48 // If there are no placeholders allocated, destroy the recyclable | 53 // If there are no placeholders allocated, destroy the recyclable |
49 // BrowserCompositorCALayerTreeMac that we just populated. | 54 // BrowserCompositorCALayerTreeMac that we just populated. |
50 if (!g_placeholder_count) | 55 if (!g_placeholder_count) |
51 g_recyclable_ca_layer_tree.Get().reset(); | 56 g_recyclable_ca_layer_tree.Get().reset(); |
52 } | 57 } |
53 | 58 |
54 ui::Compositor* BrowserCompositorViewMac::GetCompositor() const { | 59 ui::Compositor* BrowserCompositorViewMac::GetCompositor() const { |
55 DCHECK(ca_layer_tree_); | 60 DCHECK(ca_layer_tree_); |
(...skipping 10 matching lines...) Expand all Loading... |
66 void BrowserCompositorViewMac::BeginPumpingFrames() { | 71 void BrowserCompositorViewMac::BeginPumpingFrames() { |
67 if (ca_layer_tree_) | 72 if (ca_layer_tree_) |
68 ca_layer_tree_->BeginPumpingFrames(); | 73 ca_layer_tree_->BeginPumpingFrames(); |
69 } | 74 } |
70 | 75 |
71 void BrowserCompositorViewMac::EndPumpingFrames() { | 76 void BrowserCompositorViewMac::EndPumpingFrames() { |
72 if (ca_layer_tree_) | 77 if (ca_layer_tree_) |
73 ca_layer_tree_->EndPumpingFrames(); | 78 ca_layer_tree_->EndPumpingFrames(); |
74 } | 79 } |
75 | 80 |
76 // static | |
77 void BrowserCompositorViewMac::GotAcceleratedFrame( | |
78 gfx::AcceleratedWidget widget, | |
79 uint64 surface_handle, int surface_id, | |
80 const std::vector<ui::LatencyInfo>& latency_info, | |
81 gfx::Size pixel_size, float scale_factor, | |
82 int gpu_host_id, int gpu_route_id) { | |
83 BrowserCompositorCALayerTreeMac* ca_layer_tree = | |
84 BrowserCompositorCALayerTreeMac::FromAcceleratedWidget(widget); | |
85 bool disable_throttling = false; | |
86 int renderer_id = 0; | |
87 if (ca_layer_tree) { | |
88 ca_layer_tree->GotAcceleratedFrame( | |
89 surface_handle, surface_id, latency_info, pixel_size, scale_factor); | |
90 disable_throttling = ca_layer_tree->IsRendererThrottlingDisabled(); | |
91 renderer_id = ca_layer_tree->GetRendererID(); | |
92 } | |
93 | |
94 // Acknowledge the swap, now that it has been processed. | |
95 AcceleratedSurfaceMsg_BufferPresented_Params ack_params; | |
96 ack_params.disable_throttling = disable_throttling; | |
97 ack_params.renderer_id = renderer_id; | |
98 GpuProcessHostUIShim* ui_shim = GpuProcessHostUIShim::FromID(gpu_host_id); | |
99 if (ui_shim) { | |
100 ui_shim->Send(new AcceleratedSurfaceMsg_BufferPresented( | |
101 gpu_route_id, ack_params)); | |
102 } | |
103 } | |
104 | |
105 // static | |
106 void BrowserCompositorViewMac::GotSoftwareFrame( | |
107 gfx::AcceleratedWidget widget, | |
108 cc::SoftwareFrameData* frame_data, float scale_factor, SkCanvas* canvas) { | |
109 BrowserCompositorCALayerTreeMac* ca_layer_tree = | |
110 BrowserCompositorCALayerTreeMac::FromAcceleratedWidget(widget); | |
111 if (ca_layer_tree) | |
112 ca_layer_tree->GotSoftwareFrame(frame_data, scale_factor, canvas); | |
113 } | |
114 | |
115 //////////////////////////////////////////////////////////////////////////////// | 81 //////////////////////////////////////////////////////////////////////////////// |
116 // BrowserCompositorViewPlaceholderMac | 82 // BrowserCompositorViewPlaceholderMac |
117 | 83 |
118 BrowserCompositorViewPlaceholderMac::BrowserCompositorViewPlaceholderMac() { | 84 BrowserCompositorViewPlaceholderMac::BrowserCompositorViewPlaceholderMac() { |
119 g_placeholder_count += 1; | 85 g_placeholder_count += 1; |
120 } | 86 } |
121 | 87 |
122 BrowserCompositorViewPlaceholderMac::~BrowserCompositorViewPlaceholderMac() { | 88 BrowserCompositorViewPlaceholderMac::~BrowserCompositorViewPlaceholderMac() { |
123 DCHECK_GT(g_placeholder_count, 0u); | 89 DCHECK_GT(g_placeholder_count, 0u); |
124 g_placeholder_count -= 1; | 90 g_placeholder_count -= 1; |
125 | 91 |
126 // If there are no placeholders allocated, destroy the recyclable | 92 // If there are no placeholders allocated, destroy the recyclable |
127 // BrowserCompositorCALayerTreeMac. | 93 // BrowserCompositorCALayerTreeMac. |
128 if (!g_placeholder_count) | 94 if (!g_placeholder_count) |
129 g_recyclable_ca_layer_tree.Get().reset(); | 95 g_recyclable_ca_layer_tree.Get().reset(); |
130 } | 96 } |
131 | 97 |
132 } // namespace content | 98 } // namespace content |
OLD | NEW |