Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CC_DRAW_PROPERTIES_H_ | |
| 6 #define CC_DRAW_PROPERTIES_H_ | |
| 7 | |
| 8 #include "base/memory/scoped_ptr.h" | |
| 9 #include "ui/gfx/rect.h" | |
| 10 #include "ui/gfx/transform.h" | |
| 11 | |
| 12 namespace cc { | |
| 13 | |
| 14 // Container for properties that layers need to compute before they can be | |
| 15 // drawn. | |
| 16 template<typename LayerType, typename RenderSurfaceType> | |
| 17 struct CC_EXPORT DrawProperties { | |
| 18 DrawProperties() | |
| 19 : opacity(0) | |
| 20 , opacity_is_animating(false) | |
| 21 , target_space_transform_is_animating(false) | |
| 22 , screen_space_transform_is_animating(false) | |
| 23 , is_clipped(false) | |
| 24 , render_target(0) | |
| 25 { | |
| 26 } | |
| 27 | |
| 28 // Transforms objects from content space to target surface space, where | |
| 29 // this layer would be drawn. | |
| 30 gfx::Transform target_space_transform; | |
| 31 | |
| 32 // Transforms objects from content space to screen space (viewport space). | |
| 33 gfx::Transform screen_space_transform; | |
| 34 | |
| 35 // DrawProperties::opacity may be different than LayerType::opacity, | |
| 36 // particularly in the case when a renderSurface re-parents the layer's | |
| 37 // opacity, or when opacity is compounded by the hierarchy. | |
| 38 float opacity; | |
| 39 | |
| 40 // XXXIsAnimating flags are used to indicate whether the drawProperties | |
| 41 // are actually meaningful on the main thread. When the properties are | |
| 42 // animating, the main thread may not have the same values that are used | |
| 43 // to draw. | |
| 44 bool opacity_is_animating; | |
| 45 bool target_space_transform_is_animating; | |
| 46 bool screen_space_transform_is_animating; | |
| 47 | |
| 48 // True if the layer needs to be clipped by clipRect. | |
| 49 bool is_clipped; | |
| 50 | |
| 51 // The layer whose coordinate space this layer draws into. This can be | |
| 52 // either the same layer (m_drawProperties.render_target == this) or an | |
| 53 // ancestor of this layer. | |
| 54 LayerType* render_target; | |
| 55 | |
| 56 // The surface that this layer and its subtree would contribute to. | |
| 57 scoped_ptr<RenderSurfaceType> render_surface; | |
| 58 | |
| 59 // This rect is in the layer's content space. | |
| 60 gfx::Rect visible_content_rect; | |
| 61 | |
| 62 // In target surface space, the rect that encloses the clipped, drawable | |
| 63 // content of the layer. | |
| 64 gfx::Rect drawable_content_rect; | |
| 65 | |
| 66 // In target surface space, the original rect that clipped this | |
| 67 // layer. This value is used to avoid unnecessarily changing GL scissor | |
| 68 // state. | |
| 69 gfx::Rect clip_rect; | |
| 70 }; | |
| 71 | |
| 72 } // namespace cc | |
|
danakj
2012/12/05 18:35:00
nit: 2 spaces before //
| |
| 73 | |
| 74 #endif // CC_DRAW_PROPERTIES_H_ | |
|
danakj
2012/12/05 18:35:00
nit: 2 spaces
| |
| OLD | NEW |