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

Side by Side Diff: cc/layers/painted_scrollbar_layer_impl.cc

Issue 935333002: Update from https://crrev.com/316786 (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 10 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 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
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_contents_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_contents_scale_and_bounds(
56 internal_contents_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,
72 AppendQuadsData* append_quads_data) { 75 AppendQuadsData* append_quads_data) {
73 bool premultipled_alpha = true; 76 bool premultipled_alpha = true;
74 bool flipped = false; 77 bool flipped = false;
75 bool nearest_neighbor = false; 78 bool nearest_neighbor = false;
76 gfx::PointF uv_top_left(0.f, 0.f); 79 gfx::PointF uv_top_left(0.f, 0.f);
77 gfx::PointF uv_bottom_right(1.f, 1.f); 80 gfx::PointF uv_bottom_right(1.f, 1.f);
78 gfx::Rect bounds_rect(bounds());
79 gfx::Rect content_bounds_rect(content_bounds());
80 81
81 SharedQuadState* shared_quad_state = 82 SharedQuadState* shared_quad_state =
82 render_pass->CreateAndAppendSharedQuadState(); 83 render_pass->CreateAndAppendSharedQuadState();
83 PopulateSharedQuadState(shared_quad_state); 84 PopulateScaledSharedQuadState(shared_quad_state, internal_contents_scale_);
84 85
85 AppendDebugBorderQuad( 86 AppendDebugBorderQuad(render_pass, internal_content_bounds_,
86 render_pass, content_bounds(), shared_quad_state, append_quads_data); 87 shared_quad_state, append_quads_data);
87 88
88 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); 89 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect();
90 gfx::Rect scaled_thumb_quad_rect =
91 gfx::ScaleToEnclosingRect(thumb_quad_rect, internal_contents_scale_);
89 gfx::Rect visible_thumb_quad_rect = 92 gfx::Rect visible_thumb_quad_rect =
90 occlusion_in_content_space.GetUnoccludedContentRect(thumb_quad_rect); 93 draw_properties().occlusion_in_content_space.GetUnoccludedContentRect(
94 thumb_quad_rect);
95 gfx::Rect scaled_visible_thumb_quad_rect = gfx::ScaleToEnclosingRect(
96 visible_thumb_quad_rect, internal_contents_scale_);
91 97
92 ResourceProvider::ResourceId thumb_resource_id = 98 ResourceProvider::ResourceId thumb_resource_id =
93 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); 99 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_);
94 ResourceProvider::ResourceId track_resource_id = 100 ResourceProvider::ResourceId track_resource_id =
95 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); 101 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_);
96 102
97 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { 103 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) {
98 gfx::Rect opaque_rect; 104 gfx::Rect opaque_rect;
99 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 105 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
100 TextureDrawQuad* quad = 106 TextureDrawQuad* quad =
101 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 107 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
102 quad->SetNew(shared_quad_state, 108 quad->SetNew(shared_quad_state, scaled_thumb_quad_rect, opaque_rect,
103 thumb_quad_rect, 109 scaled_visible_thumb_quad_rect, thumb_resource_id,
104 opaque_rect, 110 premultipled_alpha, uv_top_left, uv_bottom_right,
105 visible_thumb_quad_rect, 111 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor);
106 thumb_resource_id,
107 premultipled_alpha,
108 uv_top_left,
109 uv_bottom_right,
110 SK_ColorTRANSPARENT,
111 opacity,
112 flipped,
113 nearest_neighbor);
114 } 112 }
115 113
116 gfx::Rect track_quad_rect = content_bounds_rect; 114 gfx::Rect track_quad_rect(bounds());
115 gfx::Rect scaled_track_quad_rect(internal_content_bounds_);
117 gfx::Rect visible_track_quad_rect = 116 gfx::Rect visible_track_quad_rect =
118 occlusion_in_content_space.GetUnoccludedContentRect(track_quad_rect); 117 draw_properties().occlusion_in_content_space.GetUnoccludedContentRect(
118 track_quad_rect);
119 gfx::Rect scaled_visible_track_quad_rect = gfx::ScaleToEnclosingRect(
120 visible_track_quad_rect, internal_contents_scale_);
119 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) { 121 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) {
120 gfx::Rect opaque_rect(contents_opaque() ? track_quad_rect : gfx::Rect()); 122 gfx::Rect opaque_rect(contents_opaque() ? scaled_track_quad_rect
123 : gfx::Rect());
121 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 124 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
122 TextureDrawQuad* quad = 125 TextureDrawQuad* quad =
123 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 126 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
124 quad->SetNew(shared_quad_state, 127 quad->SetNew(shared_quad_state, scaled_track_quad_rect, opaque_rect,
125 track_quad_rect, 128 scaled_visible_track_quad_rect, track_resource_id,
126 opaque_rect, 129 premultipled_alpha, uv_top_left, uv_bottom_right,
127 visible_track_quad_rect, 130 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor);
128 track_resource_id,
129 premultipled_alpha,
130 uv_top_left,
131 uv_bottom_right,
132 SK_ColorTRANSPARENT,
133 opacity,
134 flipped,
135 nearest_neighbor);
136 } 131 }
137 } 132 }
138 133
139 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) { 134 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) {
140 if (thumb_thickness_ == thumb_thickness) 135 if (thumb_thickness_ == thumb_thickness)
141 return; 136 return;
142 thumb_thickness_ = thumb_thickness; 137 thumb_thickness_ = thumb_thickness;
143 NoteLayerPropertyChanged(); 138 NoteLayerPropertyChanged();
144 } 139 }
145 140
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
182 177
183 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { 178 bool PaintedScrollbarLayerImpl::IsThumbResizable() const {
184 return false; 179 return false;
185 } 180 }
186 181
187 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { 182 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const {
188 return "cc::PaintedScrollbarLayerImpl"; 183 return "cc::PaintedScrollbarLayerImpl";
189 } 184 }
190 185
191 } // namespace cc 186 } // namespace cc
OLDNEW
« no previous file with comments | « cc/layers/painted_scrollbar_layer_impl.h ('k') | cc/layers/painted_scrollbar_layer_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698