OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/surface_utils.h" | 5 #include "content/browser/compositor/surface_utils.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
11 #include "cc/output/copy_output_result.h" | 11 #include "cc/output/copy_output_result.h" |
12 #include "cc/resources/single_release_callback.h" | 12 #include "cc/resources/single_release_callback.h" |
13 #include "cc/surfaces/surface_id_allocator.h" | 13 #include "cc/surfaces/surface_id_allocator.h" |
14 #include "components/display_compositor/gl_helper.h" | 14 #include "components/display_compositor/gl_helper.h" |
15 #include "skia/ext/image_operations.h" | 15 #include "skia/ext/image_operations.h" |
16 #include "third_party/skia/include/core/SkCanvas.h" | 16 #include "third_party/skia/include/core/SkCanvas.h" |
17 #include "third_party/skia/include/core/SkColorFilter.h" | 17 #include "third_party/skia/include/core/SkColorFilter.h" |
18 #include "third_party/skia/include/core/SkPaint.h" | 18 #include "third_party/skia/include/core/SkPaint.h" |
19 #include "third_party/skia/include/effects/SkLumaColorFilter.h" | 19 #include "third_party/skia/include/effects/SkLumaColorFilter.h" |
20 #include "ui/gfx/geometry/rect.h" | 20 #include "ui/gfx/geometry/rect.h" |
21 | 21 |
22 #if defined(OS_ANDROID) | 22 #if defined(OS_ANDROID) |
23 #include "content/browser/renderer_host/context_provider_factory_impl_android.h" | 23 #include "content/browser/renderer_host/compositor_impl_android.h" |
24 #else | 24 #else |
25 #include "content/browser/compositor/image_transport_factory.h" | 25 #include "content/browser/compositor/image_transport_factory.h" |
26 #include "ui/compositor/compositor.h" // nogncheck | 26 #include "ui/compositor/compositor.h" // nogncheck |
27 #endif | 27 #endif |
28 | 28 |
29 namespace { | 29 namespace { |
30 | 30 |
31 #if !defined(OS_ANDROID) || defined(USE_AURA) | 31 #if !defined(OS_ANDROID) || defined(USE_AURA) |
32 void CopyFromCompositingSurfaceFinished( | 32 void CopyFromCompositingSurfaceFinished( |
33 const content::ReadbackRequestCallback& callback, | 33 const content::ReadbackRequestCallback& callback, |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
154 canvas.drawBitmap(scaled_bitmap, SkIntToScalar(0), SkIntToScalar(0), &paint); | 154 canvas.drawBitmap(scaled_bitmap, SkIntToScalar(0), SkIntToScalar(0), &paint); |
155 callback.Run(grayscale_bitmap, content::READBACK_SUCCESS); | 155 callback.Run(grayscale_bitmap, content::READBACK_SUCCESS); |
156 } | 156 } |
157 | 157 |
158 } // namespace | 158 } // namespace |
159 | 159 |
160 namespace content { | 160 namespace content { |
161 | 161 |
162 cc::FrameSinkId AllocateFrameSinkId() { | 162 cc::FrameSinkId AllocateFrameSinkId() { |
163 #if defined(OS_ANDROID) | 163 #if defined(OS_ANDROID) |
164 return ContextProviderFactoryImpl::GetInstance()->AllocateFrameSinkId(); | 164 return CompositorImpl::AllocateFrameSinkId(); |
165 #else | 165 #else |
166 ImageTransportFactory* factory = ImageTransportFactory::GetInstance(); | 166 ImageTransportFactory* factory = ImageTransportFactory::GetInstance(); |
167 return factory->GetContextFactoryPrivate()->AllocateFrameSinkId(); | 167 return factory->GetContextFactoryPrivate()->AllocateFrameSinkId(); |
168 #endif | 168 #endif |
169 } | 169 } |
170 | 170 |
171 cc::SurfaceManager* GetSurfaceManager() { | 171 cc::SurfaceManager* GetSurfaceManager() { |
172 #if defined(OS_ANDROID) | 172 #if defined(OS_ANDROID) |
173 return ContextProviderFactoryImpl::GetInstance()->GetSurfaceManager(); | 173 return CompositorImpl::GetSurfaceManager(); |
174 #else | 174 #else |
175 ImageTransportFactory* factory = ImageTransportFactory::GetInstance(); | 175 ImageTransportFactory* factory = ImageTransportFactory::GetInstance(); |
176 if (factory == NULL) | 176 if (factory == NULL) |
177 return nullptr; | 177 return nullptr; |
178 return factory->GetContextFactoryPrivate()->GetSurfaceManager(); | 178 return factory->GetContextFactoryPrivate()->GetSurfaceManager(); |
179 #endif | 179 #endif |
180 } | 180 } |
181 | 181 |
182 void CopyFromCompositingSurfaceHasResult( | 182 void CopyFromCompositingSurfaceHasResult( |
183 const gfx::Size& dst_size_in_pixel, | 183 const gfx::Size& dst_size_in_pixel, |
(...skipping 18 matching lines...) Expand all Loading... |
202 return; | 202 return; |
203 } | 203 } |
204 | 204 |
205 DCHECK(result->HasBitmap()); | 205 DCHECK(result->HasBitmap()); |
206 // Software path | 206 // Software path |
207 PrepareBitmapCopyOutputResult(output_size_in_pixel, color_type, callback, | 207 PrepareBitmapCopyOutputResult(output_size_in_pixel, color_type, callback, |
208 std::move(result)); | 208 std::move(result)); |
209 } | 209 } |
210 | 210 |
211 } // namespace content | 211 } // namespace content |
OLD | NEW |