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

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

Issue 913393004: Revert of cc: Make PaintedScrollbarLayer not use ContentsScalingLayer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.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),
36 thumb_thickness_(0), 35 thumb_thickness_(0),
37 thumb_length_(0), 36 thumb_length_(0),
38 track_start_(0), 37 track_start_(0),
39 track_length_(0) { 38 track_length_(0) {
40 } 39 }
41 40
42 PaintedScrollbarLayerImpl::~PaintedScrollbarLayerImpl() {} 41 PaintedScrollbarLayerImpl::~PaintedScrollbarLayerImpl() {}
43 42
44 scoped_ptr<LayerImpl> PaintedScrollbarLayerImpl::CreateLayerImpl( 43 scoped_ptr<LayerImpl> PaintedScrollbarLayerImpl::CreateLayerImpl(
45 LayerTreeImpl* tree_impl) { 44 LayerTreeImpl* tree_impl) {
46 return PaintedScrollbarLayerImpl::Create(tree_impl, id(), orientation()); 45 return PaintedScrollbarLayerImpl::Create(tree_impl, id(), orientation());
47 } 46 }
48 47
49 void PaintedScrollbarLayerImpl::PushPropertiesTo(LayerImpl* layer) { 48 void PaintedScrollbarLayerImpl::PushPropertiesTo(LayerImpl* layer) {
50 ScrollbarLayerImplBase::PushPropertiesTo(layer); 49 ScrollbarLayerImplBase::PushPropertiesTo(layer);
51 50
52 PaintedScrollbarLayerImpl* scrollbar_layer = 51 PaintedScrollbarLayerImpl* scrollbar_layer =
53 static_cast<PaintedScrollbarLayerImpl*>(layer); 52 static_cast<PaintedScrollbarLayerImpl*>(layer);
54 53
55 scrollbar_layer->set_internal_contents_scale_and_bounds(
56 internal_contents_scale_, internal_content_bounds_);
57
58 scrollbar_layer->SetThumbThickness(thumb_thickness_); 54 scrollbar_layer->SetThumbThickness(thumb_thickness_);
59 scrollbar_layer->SetThumbLength(thumb_length_); 55 scrollbar_layer->SetThumbLength(thumb_length_);
60 scrollbar_layer->SetTrackStart(track_start_); 56 scrollbar_layer->SetTrackStart(track_start_);
61 scrollbar_layer->SetTrackLength(track_length_); 57 scrollbar_layer->SetTrackLength(track_length_);
62 58
63 scrollbar_layer->set_track_ui_resource_id(track_ui_resource_id_); 59 scrollbar_layer->set_track_ui_resource_id(track_ui_resource_id_);
64 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_); 60 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_);
65 } 61 }
66 62
67 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode, 63 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode,
68 ResourceProvider* resource_provider) { 64 ResourceProvider* resource_provider) {
69 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE); 65 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE);
70 return LayerImpl::WillDraw(draw_mode, resource_provider); 66 return LayerImpl::WillDraw(draw_mode, resource_provider);
71 } 67 }
72 68
73 void PaintedScrollbarLayerImpl::AppendQuads( 69 void PaintedScrollbarLayerImpl::AppendQuads(
74 RenderPass* render_pass, 70 RenderPass* render_pass,
75 const Occlusion& occlusion_in_content_space, 71 const Occlusion& occlusion_in_content_space,
76 AppendQuadsData* append_quads_data) { 72 AppendQuadsData* append_quads_data) {
77 bool premultipled_alpha = true; 73 bool premultipled_alpha = true;
78 bool flipped = false; 74 bool flipped = false;
79 bool nearest_neighbor = false; 75 bool nearest_neighbor = false;
80 gfx::PointF uv_top_left(0.f, 0.f); 76 gfx::PointF uv_top_left(0.f, 0.f);
81 gfx::PointF uv_bottom_right(1.f, 1.f); 77 gfx::PointF uv_bottom_right(1.f, 1.f);
78 gfx::Rect bounds_rect(bounds());
79 gfx::Rect content_bounds_rect(content_bounds());
82 80
83 SharedQuadState* shared_quad_state = 81 SharedQuadState* shared_quad_state =
84 render_pass->CreateAndAppendSharedQuadState(); 82 render_pass->CreateAndAppendSharedQuadState();
85 PopulateScaledSharedQuadState(shared_quad_state, internal_contents_scale_); 83 PopulateSharedQuadState(shared_quad_state);
86 84
87 AppendDebugBorderQuad(render_pass, internal_content_bounds_, 85 AppendDebugBorderQuad(
88 shared_quad_state, append_quads_data); 86 render_pass, content_bounds(), shared_quad_state, append_quads_data);
89 87
90 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); 88 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect();
91 gfx::Rect scaled_thumb_quad_rect =
92 gfx::ScaleToEnclosingRect(thumb_quad_rect, internal_contents_scale_);
93 gfx::Rect visible_thumb_quad_rect = 89 gfx::Rect visible_thumb_quad_rect =
94 occlusion_in_content_space.GetUnoccludedContentRect(thumb_quad_rect); 90 occlusion_in_content_space.GetUnoccludedContentRect(thumb_quad_rect);
95 gfx::Rect scaled_visible_thumb_quad_rect = gfx::ScaleToEnclosingRect(
96 visible_thumb_quad_rect, internal_contents_scale_);
97 91
98 ResourceProvider::ResourceId thumb_resource_id = 92 ResourceProvider::ResourceId thumb_resource_id =
99 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); 93 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_);
100 ResourceProvider::ResourceId track_resource_id = 94 ResourceProvider::ResourceId track_resource_id =
101 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); 95 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_);
102 96
103 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { 97 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) {
104 gfx::Rect opaque_rect; 98 gfx::Rect opaque_rect;
105 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 99 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
106 TextureDrawQuad* quad = 100 TextureDrawQuad* quad =
107 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 101 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
108 quad->SetNew(shared_quad_state, scaled_thumb_quad_rect, opaque_rect, 102 quad->SetNew(shared_quad_state,
109 scaled_visible_thumb_quad_rect, thumb_resource_id, 103 thumb_quad_rect,
110 premultipled_alpha, uv_top_left, uv_bottom_right, 104 opaque_rect,
111 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor); 105 visible_thumb_quad_rect,
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);
112 } 114 }
113 115
114 gfx::Rect track_quad_rect(bounds()); 116 gfx::Rect track_quad_rect = content_bounds_rect;
115 gfx::Rect scaled_track_quad_rect(internal_content_bounds_);
116 gfx::Rect visible_track_quad_rect = 117 gfx::Rect visible_track_quad_rect =
117 occlusion_in_content_space.GetUnoccludedContentRect(track_quad_rect); 118 occlusion_in_content_space.GetUnoccludedContentRect(track_quad_rect);
118 gfx::Rect scaled_visible_track_quad_rect = gfx::ScaleToEnclosingRect(
119 visible_track_quad_rect, internal_contents_scale_);
120 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) { 119 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) {
121 gfx::Rect opaque_rect(contents_opaque() ? track_quad_rect : gfx::Rect()); 120 gfx::Rect opaque_rect(contents_opaque() ? track_quad_rect : gfx::Rect());
122 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 121 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
123 TextureDrawQuad* quad = 122 TextureDrawQuad* quad =
124 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 123 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
125 quad->SetNew(shared_quad_state, scaled_track_quad_rect, opaque_rect, 124 quad->SetNew(shared_quad_state,
126 scaled_visible_track_quad_rect, track_resource_id, 125 track_quad_rect,
127 premultipled_alpha, uv_top_left, uv_bottom_right, 126 opaque_rect,
128 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor); 127 visible_track_quad_rect,
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);
129 } 136 }
130 } 137 }
131 138
132 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) { 139 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) {
133 if (thumb_thickness_ == thumb_thickness) 140 if (thumb_thickness_ == thumb_thickness)
134 return; 141 return;
135 thumb_thickness_ = thumb_thickness; 142 thumb_thickness_ = thumb_thickness;
136 NoteLayerPropertyChanged(); 143 NoteLayerPropertyChanged();
137 } 144 }
138 145
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
175 182
176 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { 183 bool PaintedScrollbarLayerImpl::IsThumbResizable() const {
177 return false; 184 return false;
178 } 185 }
179 186
180 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { 187 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const {
181 return "cc::PaintedScrollbarLayerImpl"; 188 return "cc::PaintedScrollbarLayerImpl";
182 } 189 }
183 190
184 } // namespace cc 191 } // 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