OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/painted_scrollbar_layer_impl.h" | 5 #include "cc/layers/painted_scrollbar_layer_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "cc/animation/scrollbar_animation_controller.h" | 9 #include "cc/animation/scrollbar_animation_controller.h" |
10 #include "cc/layers/layer.h" | 10 #include "cc/layers/layer.h" |
(...skipping 14 matching lines...) Expand all Loading... | |
25 new PaintedScrollbarLayerImpl(tree_impl, id, orientation)); | 25 new PaintedScrollbarLayerImpl(tree_impl, id, orientation)); |
26 } | 26 } |
27 | 27 |
28 PaintedScrollbarLayerImpl::PaintedScrollbarLayerImpl( | 28 PaintedScrollbarLayerImpl::PaintedScrollbarLayerImpl( |
29 LayerTreeImpl* tree_impl, | 29 LayerTreeImpl* tree_impl, |
30 int id, | 30 int id, |
31 ScrollbarOrientation orientation) | 31 ScrollbarOrientation orientation) |
32 : ScrollbarLayerImplBase(tree_impl, id, orientation, false, false), | 32 : ScrollbarLayerImplBase(tree_impl, id, orientation, false, false), |
33 track_ui_resource_id_(0), | 33 track_ui_resource_id_(0), |
34 thumb_ui_resource_id_(0), | 34 thumb_ui_resource_id_(0), |
35 internal_content_scale_(1.f), | |
35 thumb_thickness_(0), | 36 thumb_thickness_(0), |
36 thumb_length_(0), | 37 thumb_length_(0), |
37 track_start_(0), | 38 track_start_(0), |
38 track_length_(0) { | 39 track_length_(0) { |
39 } | 40 } |
40 | 41 |
41 PaintedScrollbarLayerImpl::~PaintedScrollbarLayerImpl() {} | 42 PaintedScrollbarLayerImpl::~PaintedScrollbarLayerImpl() {} |
42 | 43 |
43 scoped_ptr<LayerImpl> PaintedScrollbarLayerImpl::CreateLayerImpl( | 44 scoped_ptr<LayerImpl> PaintedScrollbarLayerImpl::CreateLayerImpl( |
44 LayerTreeImpl* tree_impl) { | 45 LayerTreeImpl* tree_impl) { |
45 return PaintedScrollbarLayerImpl::Create(tree_impl, id(), orientation()); | 46 return PaintedScrollbarLayerImpl::Create(tree_impl, id(), orientation()); |
46 } | 47 } |
47 | 48 |
48 void PaintedScrollbarLayerImpl::PushPropertiesTo(LayerImpl* layer) { | 49 void PaintedScrollbarLayerImpl::PushPropertiesTo(LayerImpl* layer) { |
49 ScrollbarLayerImplBase::PushPropertiesTo(layer); | 50 ScrollbarLayerImplBase::PushPropertiesTo(layer); |
50 | 51 |
51 PaintedScrollbarLayerImpl* scrollbar_layer = | 52 PaintedScrollbarLayerImpl* scrollbar_layer = |
52 static_cast<PaintedScrollbarLayerImpl*>(layer); | 53 static_cast<PaintedScrollbarLayerImpl*>(layer); |
53 | 54 |
55 scrollbar_layer->set_internal_content_scale_and_bounds( | |
56 internal_content_scale_, internal_content_bounds_); | |
57 | |
54 scrollbar_layer->SetThumbThickness(thumb_thickness_); | 58 scrollbar_layer->SetThumbThickness(thumb_thickness_); |
55 scrollbar_layer->SetThumbLength(thumb_length_); | 59 scrollbar_layer->SetThumbLength(thumb_length_); |
56 scrollbar_layer->SetTrackStart(track_start_); | 60 scrollbar_layer->SetTrackStart(track_start_); |
57 scrollbar_layer->SetTrackLength(track_length_); | 61 scrollbar_layer->SetTrackLength(track_length_); |
58 | 62 |
59 scrollbar_layer->set_track_ui_resource_id(track_ui_resource_id_); | 63 scrollbar_layer->set_track_ui_resource_id(track_ui_resource_id_); |
60 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_); | 64 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_); |
61 } | 65 } |
62 | 66 |
63 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode, | 67 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode, |
64 ResourceProvider* resource_provider) { | 68 ResourceProvider* resource_provider) { |
65 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE); | 69 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE); |
66 return LayerImpl::WillDraw(draw_mode, resource_provider); | 70 return LayerImpl::WillDraw(draw_mode, resource_provider); |
67 } | 71 } |
68 | 72 |
69 void PaintedScrollbarLayerImpl::AppendQuads( | 73 void PaintedScrollbarLayerImpl::AppendQuads( |
70 RenderPass* render_pass, | 74 RenderPass* render_pass, |
71 const Occlusion& occlusion_in_content_space, | 75 const Occlusion& occlusion_in_content_space, |
72 AppendQuadsData* append_quads_data) { | 76 AppendQuadsData* append_quads_data) { |
73 bool premultipled_alpha = true; | 77 bool premultipled_alpha = true; |
74 bool flipped = false; | 78 bool flipped = false; |
75 bool nearest_neighbor = false; | 79 bool nearest_neighbor = false; |
76 gfx::PointF uv_top_left(0.f, 0.f); | 80 gfx::PointF uv_top_left(0.f, 0.f); |
77 gfx::PointF uv_bottom_right(1.f, 1.f); | 81 gfx::PointF uv_bottom_right(1.f, 1.f); |
78 gfx::Rect bounds_rect(bounds()); | 82 gfx::Rect bounds_rect(bounds()); |
79 gfx::Rect content_bounds_rect(content_bounds()); | 83 gfx::Rect content_bounds_rect(internal_content_bounds_); |
80 | 84 |
81 SharedQuadState* shared_quad_state = | 85 SharedQuadState* shared_quad_state = |
82 render_pass->CreateAndAppendSharedQuadState(); | 86 render_pass->CreateAndAppendSharedQuadState(); |
83 PopulateSharedQuadState(shared_quad_state); | 87 PopulateScaledSharedQuadState(shared_quad_state, internal_content_scale_); |
84 | 88 |
85 AppendDebugBorderQuad( | 89 AppendDebugBorderQuad(render_pass, internal_content_bounds_, |
86 render_pass, content_bounds(), shared_quad_state, append_quads_data); | 90 shared_quad_state, append_quads_data); |
87 | 91 |
88 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); | 92 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); |
89 gfx::Rect visible_thumb_quad_rect = | 93 gfx::Rect visible_thumb_quad_rect = |
90 occlusion_in_content_space.GetUnoccludedContentRect(thumb_quad_rect); | 94 occlusion_in_content_space.GetUnoccludedContentRect(thumb_quad_rect); |
danakj
2015/02/12 19:35:43
The occlusion is in unscaled space (from the draw
enne (OOO)
2015/02/12 21:55:56
OOPS.
| |
91 | 95 |
92 ResourceProvider::ResourceId thumb_resource_id = | 96 ResourceProvider::ResourceId thumb_resource_id = |
93 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); | 97 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); |
94 ResourceProvider::ResourceId track_resource_id = | 98 ResourceProvider::ResourceId track_resource_id = |
95 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); | 99 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); |
96 | 100 |
97 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { | 101 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { |
98 gfx::Rect opaque_rect; | 102 gfx::Rect opaque_rect; |
99 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; | 103 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; |
100 TextureDrawQuad* quad = | 104 TextureDrawQuad* quad = |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
177 } | 181 } |
178 | 182 |
179 float PaintedScrollbarLayerImpl::TrackLength() const { | 183 float PaintedScrollbarLayerImpl::TrackLength() const { |
180 return track_length_ + (orientation() == VERTICAL ? vertical_adjust() : 0); | 184 return track_length_ + (orientation() == VERTICAL ? vertical_adjust() : 0); |
181 } | 185 } |
182 | 186 |
183 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { | 187 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { |
184 return false; | 188 return false; |
185 } | 189 } |
186 | 190 |
191 gfx::Rect PaintedScrollbarLayerImpl::ComputeThumbQuadRect() const { | |
192 gfx::Rect thumb_quad_rect = ScrollbarLayerImplBase::ComputeThumbQuadRect(); | |
193 return gfx::ScaleToEnclosingRect(thumb_quad_rect, internal_content_scale_); | |
194 } | |
195 | |
187 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { | 196 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { |
188 return "cc::PaintedScrollbarLayerImpl"; | 197 return "cc::PaintedScrollbarLayerImpl"; |
189 } | 198 } |
190 | 199 |
191 } // namespace cc | 200 } // namespace cc |
OLD | NEW |