Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(160)

Side by Side Diff: cc/output/overlay_candidate.cc

Issue 1380653003: Mac Overlays: Allow SolidColor and Tile quads to be candidates for overlays. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@AllOrNothing2
Patch Set: Plumb allow_overlay Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "cc/output/overlay_candidate.h" 5 #include "cc/output/overlay_candidate.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <limits> 8 #include <limits>
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "cc/base/math_util.h" 10 #include "cc/base/math_util.h"
11 #include "cc/quads/io_surface_draw_quad.h" 11 #include "cc/quads/io_surface_draw_quad.h"
12 #include "cc/quads/solid_color_draw_quad.h" 12 #include "cc/quads/solid_color_draw_quad.h"
13 #include "cc/quads/stream_video_draw_quad.h" 13 #include "cc/quads/stream_video_draw_quad.h"
14 #include "cc/quads/texture_draw_quad.h" 14 #include "cc/quads/texture_draw_quad.h"
15 #include "cc/quads/tile_draw_quad.h"
15 #include "ui/gfx/geometry/rect_conversions.h" 16 #include "ui/gfx/geometry/rect_conversions.h"
16 #include "ui/gfx/geometry/vector3d_f.h" 17 #include "ui/gfx/geometry/vector3d_f.h"
17 18
18 namespace cc { 19 namespace cc {
19 20
20 namespace { 21 namespace {
21 // Tolerance for considering axis vector elements to be zero. 22 // Tolerance for considering axis vector elements to be zero.
22 const SkMScalar kEpsilon = std::numeric_limits<float>::epsilon(); 23 const SkMScalar kEpsilon = std::numeric_limits<float>::epsilon();
23 24
24 enum Axis { NONE, AXIS_POS_X, AXIS_NEG_X, AXIS_POS_Y, AXIS_NEG_Y }; 25 enum Axis { NONE, AXIS_POS_X, AXIS_NEG_X, AXIS_POS_Y, AXIS_NEG_Y };
(...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after
165 166
166 } // namespace 167 } // namespace
167 168
168 OverlayCandidate::OverlayCandidate() 169 OverlayCandidate::OverlayCandidate()
169 : transform(gfx::OVERLAY_TRANSFORM_NONE), 170 : transform(gfx::OVERLAY_TRANSFORM_NONE),
170 format(RGBA_8888), 171 format(RGBA_8888),
171 uv_rect(0.f, 0.f, 1.f, 1.f), 172 uv_rect(0.f, 0.f, 1.f, 1.f),
172 is_clipped(false), 173 is_clipped(false),
173 use_output_surface_for_resource(false), 174 use_output_surface_for_resource(false),
174 resource_id(0), 175 resource_id(0),
176 solid_color(SK_ColorTRANSPARENT),
175 plane_z_order(0), 177 plane_z_order(0),
176 overlay_handled(false) {} 178 overlay_handled(false) {}
177 179
178 OverlayCandidate::~OverlayCandidate() {} 180 OverlayCandidate::~OverlayCandidate() {}
179 181
180 // static 182 // static
183 bool OverlayCandidate::IsVideoQuad(const DrawQuad* quad) {
184 return quad->material == DrawQuad::TEXTURE_CONTENT ||
185 quad->material == DrawQuad::STREAM_VIDEO_CONTENT ||
186 quad->material == DrawQuad::IO_SURFACE_CONTENT;
187 }
188
189 // static
181 bool OverlayCandidate::FromDrawQuad(const DrawQuad* quad, 190 bool OverlayCandidate::FromDrawQuad(const DrawQuad* quad,
182 OverlayCandidate* candidate) { 191 OverlayCandidate* candidate) {
183 if (quad->needs_blending || quad->shared_quad_state->opacity != 1.f || 192 if (quad->needs_blending || quad->shared_quad_state->opacity != 1.f ||
184 quad->shared_quad_state->blend_mode != SkXfermode::kSrcOver_Mode) 193 quad->shared_quad_state->blend_mode != SkXfermode::kSrcOver_Mode)
185 return false; 194 return false;
186 195
187 auto& transform = quad->shared_quad_state->quad_to_target_transform; 196 auto& transform = quad->shared_quad_state->quad_to_target_transform;
188 candidate->display_rect = gfx::RectF(quad->rect); 197 candidate->display_rect = gfx::RectF(quad->rect);
189 transform.TransformRect(&candidate->display_rect); 198 transform.TransformRect(&candidate->display_rect);
190 candidate->quad_rect_in_target_space = 199 candidate->quad_rect_in_target_space =
191 MathUtil::MapEnclosingClippedRect(transform, quad->rect); 200 MathUtil::MapEnclosingClippedRect(transform, quad->rect);
192 201
193 candidate->format = RGBA_8888; 202 candidate->format = RGBA_8888;
194 candidate->clip_rect = quad->shared_quad_state->clip_rect; 203 candidate->clip_rect = quad->shared_quad_state->clip_rect;
195 candidate->is_clipped = quad->shared_quad_state->is_clipped; 204 candidate->is_clipped = quad->shared_quad_state->is_clipped;
196 205
197 switch (quad->material) { 206 switch (quad->material) {
198 case DrawQuad::TEXTURE_CONTENT: 207 case DrawQuad::TEXTURE_CONTENT:
199 return FromTextureQuad(TextureDrawQuad::MaterialCast(quad), candidate); 208 return FromTextureQuad(TextureDrawQuad::MaterialCast(quad), candidate);
200 case DrawQuad::STREAM_VIDEO_CONTENT: 209 case DrawQuad::STREAM_VIDEO_CONTENT:
201 return FromStreamVideoQuad(StreamVideoDrawQuad::MaterialCast(quad), 210 return FromStreamVideoQuad(StreamVideoDrawQuad::MaterialCast(quad),
202 candidate); 211 candidate);
203 case DrawQuad::IO_SURFACE_CONTENT: 212 case DrawQuad::IO_SURFACE_CONTENT:
204 return FromIOSurfaceQuad(IOSurfaceDrawQuad::MaterialCast(quad), 213 return FromIOSurfaceQuad(IOSurfaceDrawQuad::MaterialCast(quad),
205 candidate); 214 candidate);
215 case DrawQuad::TILED_CONTENT:
216 return FromTileQuad(TileDrawQuad::MaterialCast(quad), candidate);
217 case DrawQuad::SOLID_COLOR:
218 return FromSolidColorQuad(SolidColorDrawQuad::MaterialCast(quad),
219 candidate);
206 default: 220 default:
207 break; 221 break;
208 } 222 }
209 223
210 return false; 224 return false;
211 } 225 }
212 226
213 // static 227 // static
214 bool OverlayCandidate::IsInvisibleQuad(const DrawQuad* quad) { 228 bool OverlayCandidate::IsInvisibleQuad(const DrawQuad* quad) {
215 if (quad->material == DrawQuad::SOLID_COLOR) { 229 if (quad->material == DrawQuad::SOLID_COLOR) {
216 SkColor color = SolidColorDrawQuad::MaterialCast(quad)->color; 230 SkColor color = SolidColorDrawQuad::MaterialCast(quad)->color;
217 float opacity = quad->shared_quad_state->opacity; 231 float opacity = quad->shared_quad_state->opacity;
218 float alpha = (SkColorGetA(color) * (1.0f / 255.0f)) * opacity; 232 float alpha = (SkColorGetA(color) * (1.0f / 255.0f)) * opacity;
219 return quad->ShouldDrawWithBlending() && 233 return quad->ShouldDrawWithBlending() &&
220 alpha < std::numeric_limits<float>::epsilon(); 234 alpha < std::numeric_limits<float>::epsilon();
221 } 235 }
222 return false; 236 return false;
223 } 237 }
224 238
225 // static 239 // static
226 bool OverlayCandidate::FromTextureQuad(const TextureDrawQuad* quad, 240 bool OverlayCandidate::FromTextureQuad(const TextureDrawQuad* quad,
227 OverlayCandidate* candidate) { 241 OverlayCandidate* candidate) {
228 if (!quad->allow_overlay())
229 return false;
230 gfx::OverlayTransform overlay_transform = GetOverlayTransform( 242 gfx::OverlayTransform overlay_transform = GetOverlayTransform(
231 quad->shared_quad_state->quad_to_target_transform, quad->y_flipped); 243 quad->shared_quad_state->quad_to_target_transform, quad->y_flipped);
232 if (quad->background_color != SK_ColorTRANSPARENT || 244 if (quad->background_color != SK_ColorTRANSPARENT ||
233 quad->premultiplied_alpha || 245 quad->premultiplied_alpha ||
234 overlay_transform == gfx::OVERLAY_TRANSFORM_INVALID) 246 overlay_transform == gfx::OVERLAY_TRANSFORM_INVALID)
235 return false; 247 return false;
236 candidate->resource_id = quad->resource_id(); 248 candidate->resource_id = quad->resource_id();
237 candidate->resource_size_in_pixels = quad->resource_size_in_pixels(); 249 candidate->resource_size_in_pixels = quad->resource_size_in_pixels();
238 candidate->transform = overlay_transform; 250 candidate->transform = overlay_transform;
239 candidate->uv_rect = BoundingRect(quad->uv_top_left, quad->uv_bottom_right); 251 candidate->uv_rect = BoundingRect(quad->uv_top_left, quad->uv_bottom_right);
240 return true; 252 return true;
241 } 253 }
242 254
243 // static 255 // static
244 bool OverlayCandidate::FromStreamVideoQuad(const StreamVideoDrawQuad* quad, 256 bool OverlayCandidate::FromStreamVideoQuad(const StreamVideoDrawQuad* quad,
245 OverlayCandidate* candidate) { 257 OverlayCandidate* candidate) {
246 if (!quad->allow_overlay())
247 return false;
248 gfx::OverlayTransform overlay_transform = GetOverlayTransform( 258 gfx::OverlayTransform overlay_transform = GetOverlayTransform(
249 quad->shared_quad_state->quad_to_target_transform, false); 259 quad->shared_quad_state->quad_to_target_transform, false);
250 if (overlay_transform == gfx::OVERLAY_TRANSFORM_INVALID) 260 if (overlay_transform == gfx::OVERLAY_TRANSFORM_INVALID)
251 return false; 261 return false;
252 if (!quad->matrix.IsScaleOrTranslation()) { 262 if (!quad->matrix.IsScaleOrTranslation()) {
253 // We cannot handle anything other than scaling & translation for texture 263 // We cannot handle anything other than scaling & translation for texture
254 // coordinates yet. 264 // coordinates yet.
255 return false; 265 return false;
256 } 266 }
257 candidate->resource_id = quad->resource_id(); 267 candidate->resource_id = quad->resource_id();
(...skipping 23 matching lines...) Expand all
281 candidate->transform = ComposeTransforms( 291 candidate->transform = ComposeTransforms(
282 gfx::OVERLAY_TRANSFORM_FLIP_VERTICAL, candidate->transform); 292 gfx::OVERLAY_TRANSFORM_FLIP_VERTICAL, candidate->transform);
283 candidate->uv_rect = gfx::RectF(uv0.x(), uv0.y(), delta.x(), delta.y()); 293 candidate->uv_rect = gfx::RectF(uv0.x(), uv0.y(), delta.x(), delta.y());
284 } 294 }
285 return true; 295 return true;
286 } 296 }
287 297
288 // static 298 // static
289 bool OverlayCandidate::FromIOSurfaceQuad(const IOSurfaceDrawQuad* quad, 299 bool OverlayCandidate::FromIOSurfaceQuad(const IOSurfaceDrawQuad* quad,
290 OverlayCandidate* candidate) { 300 OverlayCandidate* candidate) {
291 if (!quad->allow_overlay)
292 return false;
293 gfx::OverlayTransform overlay_transform = GetOverlayTransform( 301 gfx::OverlayTransform overlay_transform = GetOverlayTransform(
294 quad->shared_quad_state->quad_to_target_transform, false); 302 quad->shared_quad_state->quad_to_target_transform, false);
295 if (overlay_transform != gfx::OVERLAY_TRANSFORM_NONE) 303 if (overlay_transform != gfx::OVERLAY_TRANSFORM_NONE)
296 return false; 304 return false;
297 candidate->resource_id = quad->io_surface_resource_id(); 305 candidate->resource_id = quad->io_surface_resource_id();
298 candidate->resource_size_in_pixels = quad->io_surface_size; 306 candidate->resource_size_in_pixels = quad->io_surface_size;
299 candidate->transform = overlay_transform; 307 candidate->transform = overlay_transform;
300 candidate->uv_rect = gfx::RectF(1.f, 1.f); 308 candidate->uv_rect = gfx::RectF(1.f, 1.f);
301 return true; 309 return true;
302 } 310 }
303 311
312 // static
313 bool OverlayCandidate::FromTileQuad(const TileDrawQuad* quad,
314 OverlayCandidate* candidate) {
315 candidate->transform = GetOverlayTransform(
316 quad->shared_quad_state->quad_to_target_transform, false);
317 if (candidate->transform != gfx::OVERLAY_TRANSFORM_NONE)
318 return false;
319 candidate->resource_id = quad->resource_id();
320 candidate->resource_size_in_pixels = quad->texture_size;
321 candidate->uv_rect = quad->tex_coord_rect;
322 candidate->uv_rect.Scale(1.f / quad->texture_size.width(),
323 1.f / quad->texture_size.height());
324 return true;
325 }
326
327 // static
328 bool OverlayCandidate::FromSolidColorQuad(const SolidColorDrawQuad* quad,
329 OverlayCandidate* candidate) {
330 candidate->transform = GetOverlayTransform(
331 quad->shared_quad_state->quad_to_target_transform, false);
332 if (candidate->transform != gfx::OVERLAY_TRANSFORM_NONE)
333 return false;
334 candidate->solid_color = quad->color;
335 return true;
336 }
337
304 } // namespace cc 338 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698