OLD | NEW |
---|---|
1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 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/layers/render_surface_impl.h" | 5 #include "cc/layers/render_surface_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
(...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
186 (!mask_layer->DrawsContent() || mask_layer->bounds().IsEmpty())) | 186 (!mask_layer->DrawsContent() || mask_layer->bounds().IsEmpty())) |
187 mask_layer = nullptr; | 187 mask_layer = nullptr; |
188 | 188 |
189 if (!mask_layer && for_replica) { | 189 if (!mask_layer && for_replica) { |
190 mask_layer = owning_layer_->replica_layer()->mask_layer(); | 190 mask_layer = owning_layer_->replica_layer()->mask_layer(); |
191 if (mask_layer && | 191 if (mask_layer && |
192 (!mask_layer->DrawsContent() || mask_layer->bounds().IsEmpty())) | 192 (!mask_layer->DrawsContent() || mask_layer->bounds().IsEmpty())) |
193 mask_layer = nullptr; | 193 mask_layer = nullptr; |
194 } | 194 } |
195 | 195 |
196 gfx::RectF mask_uv_rect(0.f, 0.f, 1.f, 1.f); | 196 gfx::Vector2dF mask_uv_scale; |
197 gfx::Size mask_texture_size; | |
197 if (mask_layer) { | 198 if (mask_layer) { |
198 gfx::Vector2dF owning_layer_draw_scale = | 199 gfx::Vector2dF owning_layer_draw_scale = |
199 MathUtil::ComputeTransform2dScaleComponents( | 200 MathUtil::ComputeTransform2dScaleComponents( |
200 owning_layer_->draw_transform(), 1.f); | 201 owning_layer_->draw_transform(), 1.f); |
201 gfx::SizeF unclipped_mask_target_size = gfx::ScaleSize( | 202 gfx::SizeF unclipped_mask_target_size = gfx::ScaleSize( |
202 owning_layer_->content_bounds(), | 203 owning_layer_->content_bounds(), |
203 owning_layer_draw_scale.x(), | 204 owning_layer_draw_scale.x(), |
204 owning_layer_draw_scale.y()); | 205 owning_layer_draw_scale.y()); |
205 | 206 mask_uv_scale = gfx::Vector2dF( |
206 float uv_scale_x = | 207 content_rect_.width() / unclipped_mask_target_size.width(), |
207 content_rect_.width() / unclipped_mask_target_size.width(); | 208 content_rect_.height() / unclipped_mask_target_size.height()); |
208 float uv_scale_y = | 209 mask_texture_size = mask_layer->content_bounds(); |
danakj
2014/10/15 15:33:34
with implside painting this is the same as bounds(
enne (OOO)
2014/10/15 19:10:54
Whoa. Nice catch!
ContentsResourceId now has to
| |
209 content_rect_.height() / unclipped_mask_target_size.height(); | |
210 | |
211 mask_uv_rect = gfx::RectF( | |
212 uv_scale_x * content_rect_.x() / content_rect_.width(), | |
213 uv_scale_y * content_rect_.y() / content_rect_.height(), | |
214 uv_scale_x, | |
215 uv_scale_y); | |
216 } | 210 } |
217 | 211 |
218 ResourceProvider::ResourceId mask_resource_id = | 212 ResourceProvider::ResourceId mask_resource_id = |
219 mask_layer ? mask_layer->ContentsResourceId() : 0; | 213 mask_layer ? mask_layer->ContentsResourceId() : 0; |
220 | 214 |
221 DCHECK(owning_layer_->draw_properties().target_space_transform.IsScale2d()); | 215 DCHECK(owning_layer_->draw_properties().target_space_transform.IsScale2d()); |
222 gfx::Vector2dF owning_layer_to_target_scale = | 216 gfx::Vector2dF owning_layer_to_target_scale = |
223 owning_layer_->draw_properties().target_space_transform.Scale2d(); | 217 owning_layer_->draw_properties().target_space_transform.Scale2d(); |
224 owning_layer_to_target_scale.Scale(owning_layer_->contents_scale_x(), | 218 owning_layer_to_target_scale.Scale(owning_layer_->contents_scale_x(), |
225 owning_layer_->contents_scale_y()); | 219 owning_layer_->contents_scale_y()); |
226 | 220 |
227 RenderPassDrawQuad* quad = | 221 RenderPassDrawQuad* quad = |
228 render_pass->CreateAndAppendDrawQuad<RenderPassDrawQuad>(); | 222 render_pass->CreateAndAppendDrawQuad<RenderPassDrawQuad>(); |
229 quad->SetNew(shared_quad_state, | 223 quad->SetNew(shared_quad_state, |
230 content_rect_, | 224 content_rect_, |
231 visible_content_rect, | 225 visible_content_rect, |
232 render_pass_id, | 226 render_pass_id, |
233 mask_resource_id, | 227 mask_resource_id, |
234 mask_uv_rect, | 228 mask_uv_scale, |
229 mask_texture_size, | |
235 owning_layer_->filters(), | 230 owning_layer_->filters(), |
236 owning_layer_to_target_scale, | 231 owning_layer_to_target_scale, |
237 owning_layer_->background_filters()); | 232 owning_layer_->background_filters()); |
238 } | 233 } |
239 | 234 |
240 } // namespace cc | 235 } // namespace cc |
OLD | NEW |