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

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

Issue 1330953002: Mac Overlays: Allow multiple overlays with sandwich strategy. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@2490
Patch Set: Created 5 years, 3 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
« no previous file with comments | « cc/output/overlay_strategy_sandwich.h ('k') | cc/output/overlay_strategy_single_on_top.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "cc/output/overlay_strategy_sandwich.h" 5 #include "cc/output/overlay_strategy_sandwich.h"
6 6
7 #include "cc/base/region.h" 7 #include "cc/base/region.h"
8 #include "cc/output/overlay_candidate_validator.h" 8 #include "cc/output/overlay_candidate_validator.h"
9 #include "cc/quads/draw_quad.h" 9 #include "cc/quads/draw_quad.h"
10 #include "cc/quads/solid_color_draw_quad.h" 10 #include "cc/quads/solid_color_draw_quad.h"
(...skipping 13 matching lines...) Expand all
24 bool IsPixelRectAlignedToDIP(float scale_factor, const gfx::Rect& pixel_rect) { 24 bool IsPixelRectAlignedToDIP(float scale_factor, const gfx::Rect& pixel_rect) {
25 return (pixel_rect == AlignPixelRectToDIP(scale_factor, pixel_rect)); 25 return (pixel_rect == AlignPixelRectToDIP(scale_factor, pixel_rect));
26 } 26 }
27 27
28 } // namespace 28 } // namespace
29 29
30 namespace cc { 30 namespace cc {
31 31
32 OverlayStrategySandwich::~OverlayStrategySandwich() {} 32 OverlayStrategySandwich::~OverlayStrategySandwich() {}
33 33
34 bool OverlayStrategySandwich::TryOverlay( 34 OverlayResult OverlayStrategySandwich::TryOverlay(
35 OverlayCandidateValidator* capability_checker, 35 OverlayCandidateValidator* capability_checker,
36 RenderPassList* render_passes_in_draw_order, 36 RenderPassList* render_passes_in_draw_order,
37 OverlayCandidateList* output_candidate_list, 37 OverlayCandidateList* candidate_list,
38 const OverlayCandidate& candidate, 38 const OverlayCandidate& candidate,
39 QuadList::Iterator candidate_iter_in_quad_list, 39 QuadList::Iterator* candidate_iter_in_quad_list,
40 float device_scale_factor) { 40 float device_scale_factor) {
41 RenderPass* root_render_pass = render_passes_in_draw_order->back(); 41 RenderPass* root_render_pass = render_passes_in_draw_order->back();
42 QuadList& quad_list = root_render_pass->quad_list; 42 QuadList& quad_list = root_render_pass->quad_list;
43 gfx::Rect pixel_bounds = root_render_pass->output_rect; 43 gfx::Rect pixel_bounds = root_render_pass->output_rect;
44 44
45 const DrawQuad* candidate_quad = *candidate_iter_in_quad_list; 45 const DrawQuad* candidate_quad = **candidate_iter_in_quad_list;
46 const gfx::Transform& candidate_transform = 46 const gfx::Transform& candidate_transform =
47 candidate_quad->shared_quad_state->quad_to_target_transform; 47 candidate_quad->shared_quad_state->quad_to_target_transform;
48 gfx::Transform candidate_inverse_transform; 48 gfx::Transform candidate_inverse_transform;
49 if (!candidate_transform.GetInverse(&candidate_inverse_transform)) 49 if (!candidate_transform.GetInverse(&candidate_inverse_transform))
50 return false; 50 return DID_NOT_CREATE_OVERLAY;
51 51
52 // Compute the candidate's rect in display space (pixels on the screen). The 52 // Compute the candidate's rect in display space (pixels on the screen). The
53 // rect needs to be DIP-aligned, or we cannot use it. 53 // rect needs to be DIP-aligned, or we cannot use it.
54 gfx::RectF candidate_pixel_rect_float = candidate_quad->rect; 54 const gfx::Rect candidate_pixel_rect =
55 candidate_transform.TransformRect(&candidate_pixel_rect_float); 55 gfx::ToEnclosingRect(candidate.display_rect);
56 gfx::Rect candidate_pixel_rect; 56 if (candidate_pixel_rect != candidate.display_rect ||
57 candidate_pixel_rect = gfx::ToEnclosingRect(candidate_pixel_rect_float); 57 !IsPixelRectAlignedToDIP(device_scale_factor, candidate_pixel_rect)) {
58 if (candidate_pixel_rect != candidate_pixel_rect_float) 58 return DID_NOT_CREATE_OVERLAY;
59 return false; 59 }
60 if (!IsPixelRectAlignedToDIP(device_scale_factor, candidate_pixel_rect))
61 return false;
62 60
63 // Iterate through the quads in front of |potential_candidate|, and compute 61 // Don't allow overlapping overlays for now.
64 // the region of |potential_candidate| that is covered. 62 for (const OverlayCandidate& other_candidate : *candidate_list) {
63 if (other_candidate.display_rect.Intersects(candidate.display_rect) &&
64 other_candidate.plane_z_order == 1) {
65 return DID_NOT_CREATE_OVERLAY;
66 }
67 }
68
69 // Iterate through the quads in front of |candidate|, and compute the region
70 // of |candidate| that is covered.
65 Region pixel_covered_region; 71 Region pixel_covered_region;
66 for (auto overlap_iter = quad_list.cbegin(); 72 for (auto overlap_iter = quad_list.cbegin();
67 overlap_iter != candidate_iter_in_quad_list; ++overlap_iter) { 73 overlap_iter != *candidate_iter_in_quad_list; ++overlap_iter) {
68 if (OverlayStrategyCommon::IsInvisibleQuad(*overlap_iter)) 74 if (OverlayStrategyCommon::IsInvisibleQuad(*overlap_iter))
69 continue; 75 continue;
70 // Compute the quad's bounds in display space, and ensure that it is rounded 76 // Compute the quad's bounds in display space, and ensure that it is rounded
71 // up to be DIP-aligned. 77 // up to be DIP-aligned.
72 gfx::RectF pixel_covered_rect_float = overlap_iter->rect; 78 gfx::RectF pixel_covered_rect_float = overlap_iter->rect;
73 overlap_iter->shared_quad_state->quad_to_target_transform.TransformRect( 79 overlap_iter->shared_quad_state->quad_to_target_transform.TransformRect(
74 &pixel_covered_rect_float); 80 &pixel_covered_rect_float);
75 gfx::Rect pixel_covered_rect = AlignPixelRectToDIP( 81 gfx::Rect pixel_covered_rect = AlignPixelRectToDIP(
76 device_scale_factor, gfx::ToEnclosingRect(pixel_covered_rect_float)); 82 device_scale_factor, gfx::ToEnclosingRect(pixel_covered_rect_float));
77 83
78 // Include the intersection of that quad with the candidate's quad in the 84 // Include the intersection of that quad with the candidate's quad in the
79 // covered region. 85 // covered region.
80 pixel_covered_rect.Intersect(candidate_pixel_rect); 86 pixel_covered_rect.Intersect(candidate_pixel_rect);
81 pixel_covered_region.Union(pixel_covered_rect); 87 pixel_covered_region.Union(pixel_covered_rect);
82 } 88 }
83 89
84 // Add our primary surface.
85 OverlayCandidateList new_candidate_list;
86 OverlayCandidate main_image;
87 main_image.display_rect = pixel_bounds;
88 new_candidate_list.push_back(main_image);
89
90 // Add the candidate's overlay. 90 // Add the candidate's overlay.
91 DCHECK(candidate.resource_id); 91 DCHECK(candidate.resource_id);
92 OverlayCandidateList new_candidate_list = *candidate_list;
92 new_candidate_list.push_back(candidate); 93 new_candidate_list.push_back(candidate);
93 new_candidate_list.back().plane_z_order = 1; 94 new_candidate_list.back().plane_z_order = 1;
94 95
95 // Add an overlay of the primary surface for any part of the candidate's 96 // Add an overlay of the primary surface for any part of the candidate's
96 // quad that was covered. 97 // quad that was covered.
97 std::vector<gfx::Rect> pixel_covered_rects; 98 std::vector<gfx::Rect> pixel_covered_rects;
98 for (Region::Iterator it(pixel_covered_region); it.has_rect(); it.next()) { 99 for (Region::Iterator it(pixel_covered_region); it.has_rect(); it.next()) {
99 DCHECK(IsPixelRectAlignedToDIP(device_scale_factor, it.rect())); 100 DCHECK(IsPixelRectAlignedToDIP(device_scale_factor, it.rect()));
100 pixel_covered_rects.push_back(it.rect()); 101 pixel_covered_rects.push_back(it.rect());
101 } 102 }
102 for (const gfx::Rect& pixel_covered_rect : pixel_covered_rects) { 103 for (const gfx::Rect& pixel_covered_rect : pixel_covered_rects) {
103 OverlayCandidate main_image_on_top; 104 OverlayCandidate main_image_on_top;
104 main_image_on_top.display_rect = pixel_covered_rect; 105 main_image_on_top.display_rect = pixel_covered_rect;
105 main_image_on_top.uv_rect = pixel_covered_rect; 106 main_image_on_top.uv_rect = pixel_covered_rect;
106 main_image_on_top.uv_rect.Scale(1.f / pixel_bounds.width(), 107 main_image_on_top.uv_rect.Scale(1.f / pixel_bounds.width(),
107 1.f / pixel_bounds.height()); 108 1.f / pixel_bounds.height());
108 main_image_on_top.plane_z_order = 2; 109 main_image_on_top.plane_z_order = 2;
109 main_image_on_top.transform = gfx::OVERLAY_TRANSFORM_NONE; 110 main_image_on_top.transform = gfx::OVERLAY_TRANSFORM_NONE;
110 main_image_on_top.use_output_surface_for_resource = true; 111 main_image_on_top.use_output_surface_for_resource = true;
111 new_candidate_list.push_back(main_image_on_top); 112 new_candidate_list.push_back(main_image_on_top);
112 } 113 }
113 114
114 // Check for support. 115 // Check for support.
115 capability_checker->CheckOverlaySupport(&new_candidate_list); 116 capability_checker->CheckOverlaySupport(&new_candidate_list);
116 for (const OverlayCandidate& candidate : new_candidate_list) { 117 for (const OverlayCandidate& candidate : new_candidate_list) {
117 if (candidate.plane_z_order > 0 && !candidate.overlay_handled) 118 if (candidate.plane_z_order > 0 && !candidate.overlay_handled)
118 return false; 119 return DID_NOT_CREATE_OVERLAY;
119 } 120 }
120 121
121 // Remove the quad for the overlay quad. Replace it with a transparent quad 122 // Remove the quad for the overlay quad. Replace it with a transparent quad
122 // if we're putting a new overlay on top. 123 // if we're putting a new overlay on top.
123 if (pixel_covered_rects.empty()) { 124 if (pixel_covered_rects.empty()) {
124 quad_list.EraseAndInvalidateAllPointers(candidate_iter_in_quad_list); 125 *candidate_iter_in_quad_list =
126 quad_list.EraseAndInvalidateAllPointers(*candidate_iter_in_quad_list);
125 } else { 127 } else {
126 // Cache the information from the candidate quad that we'll need to 128 // Cache the information from the candidate quad that we'll need to
127 // construct the solid color quads. 129 // construct the solid color quads.
128 const SharedQuadState* candidate_shared_quad_state = 130 const SharedQuadState* candidate_shared_quad_state =
129 candidate_quad->shared_quad_state; 131 candidate_quad->shared_quad_state;
130 const gfx::Rect candidate_rect = candidate_quad->rect; 132 const gfx::Rect candidate_rect = candidate_quad->rect;
131 133
132 // Reserve space in the quad list for the transparent quads. 134 // Reserve space in the quad list for the transparent quads.
133 quad_list.ReplaceExistingElement<SolidColorDrawQuad>( 135 quad_list.ReplaceExistingElement<SolidColorDrawQuad>(
134 candidate_iter_in_quad_list); 136 *candidate_iter_in_quad_list);
135 candidate_iter_in_quad_list = 137 *candidate_iter_in_quad_list =
136 quad_list.InsertBeforeAndInvalidateAllPointers<SolidColorDrawQuad>( 138 quad_list.InsertBeforeAndInvalidateAllPointers<SolidColorDrawQuad>(
137 candidate_iter_in_quad_list, pixel_covered_rects.size() - 1); 139 *candidate_iter_in_quad_list, pixel_covered_rects.size() - 1);
138 140
139 // Cover the region with transparent quads. 141 // Cover the region with transparent quads.
140 for (const gfx::Rect& pixel_covered_rect : pixel_covered_rects) { 142 for (const gfx::Rect& pixel_covered_rect : pixel_covered_rects) {
141 gfx::RectF quad_space_covered_rect_float = pixel_covered_rect; 143 gfx::RectF quad_space_covered_rect_float = pixel_covered_rect;
142 candidate_inverse_transform.TransformRect(&quad_space_covered_rect_float); 144 candidate_inverse_transform.TransformRect(&quad_space_covered_rect_float);
143 gfx::Rect quad_space_covered_rect = 145 gfx::Rect quad_space_covered_rect =
144 gfx::ToEnclosingRect(quad_space_covered_rect_float); 146 gfx::ToEnclosingRect(quad_space_covered_rect_float);
145 quad_space_covered_rect.Intersect(candidate_rect); 147 quad_space_covered_rect.Intersect(candidate_rect);
146 148
147 SolidColorDrawQuad* transparent_quad = 149 SolidColorDrawQuad* transparent_quad =
148 static_cast<SolidColorDrawQuad*>(*candidate_iter_in_quad_list); 150 static_cast<SolidColorDrawQuad*>(**candidate_iter_in_quad_list);
149 transparent_quad->SetAll(candidate_shared_quad_state, 151 transparent_quad->SetAll(candidate_shared_quad_state,
150 quad_space_covered_rect, quad_space_covered_rect, 152 quad_space_covered_rect, quad_space_covered_rect,
151 quad_space_covered_rect, false, 153 quad_space_covered_rect, false,
152 SK_ColorTRANSPARENT, true); 154 SK_ColorTRANSPARENT, true);
153 ++candidate_iter_in_quad_list; 155 ++(*candidate_iter_in_quad_list);
154 } 156 }
155 } 157 }
156 158
157 output_candidate_list->swap(new_candidate_list); 159 candidate_list->swap(new_candidate_list);
158 return true; 160 return CREATED_OVERLAY_KEEP_LOOKING;
159 } 161 }
160 162
161 } // namespace cc 163 } // namespace cc
OLDNEW
« no previous file with comments | « cc/output/overlay_strategy_sandwich.h ('k') | cc/output/overlay_strategy_single_on_top.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698