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

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

Issue 913133004: cc: Make PaintedScrollbarLayer not use ContentsScalingLayer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix thumb rects under device scale 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_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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698