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

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

Issue 927783002: cc: Stop passing the occlusion explicitly to AppendQuads. (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 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
65 } 65 }
66 66
67 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode, 67 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode,
68 ResourceProvider* resource_provider) { 68 ResourceProvider* resource_provider) {
69 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE); 69 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE);
70 return LayerImpl::WillDraw(draw_mode, resource_provider); 70 return LayerImpl::WillDraw(draw_mode, resource_provider);
71 } 71 }
72 72
73 void PaintedScrollbarLayerImpl::AppendQuads( 73 void PaintedScrollbarLayerImpl::AppendQuads(
74 RenderPass* render_pass, 74 RenderPass* render_pass,
75 const Occlusion& occlusion_in_content_space,
76 AppendQuadsData* append_quads_data) { 75 AppendQuadsData* append_quads_data) {
77 bool premultipled_alpha = true; 76 bool premultipled_alpha = true;
78 bool flipped = false; 77 bool flipped = false;
79 bool nearest_neighbor = false; 78 bool nearest_neighbor = false;
80 gfx::PointF uv_top_left(0.f, 0.f); 79 gfx::PointF uv_top_left(0.f, 0.f);
81 gfx::PointF uv_bottom_right(1.f, 1.f); 80 gfx::PointF uv_bottom_right(1.f, 1.f);
82 81
83 SharedQuadState* shared_quad_state = 82 SharedQuadState* shared_quad_state =
84 render_pass->CreateAndAppendSharedQuadState(); 83 render_pass->CreateAndAppendSharedQuadState();
85 PopulateScaledSharedQuadState(shared_quad_state, internal_contents_scale_); 84 PopulateScaledSharedQuadState(shared_quad_state, internal_contents_scale_);
86 85
87 AppendDebugBorderQuad(render_pass, internal_content_bounds_, 86 AppendDebugBorderQuad(render_pass, internal_content_bounds_,
88 shared_quad_state, append_quads_data); 87 shared_quad_state, append_quads_data);
89 88
90 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); 89 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect();
91 gfx::Rect scaled_thumb_quad_rect = 90 gfx::Rect scaled_thumb_quad_rect =
92 gfx::ScaleToEnclosingRect(thumb_quad_rect, internal_contents_scale_); 91 gfx::ScaleToEnclosingRect(thumb_quad_rect, internal_contents_scale_);
93 gfx::Rect visible_thumb_quad_rect = 92 gfx::Rect visible_thumb_quad_rect =
94 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( 95 gfx::Rect scaled_visible_thumb_quad_rect = gfx::ScaleToEnclosingRect(
96 visible_thumb_quad_rect, internal_contents_scale_); 96 visible_thumb_quad_rect, internal_contents_scale_);
97 97
98 ResourceProvider::ResourceId thumb_resource_id = 98 ResourceProvider::ResourceId thumb_resource_id =
99 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); 99 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_);
100 ResourceProvider::ResourceId track_resource_id = 100 ResourceProvider::ResourceId track_resource_id =
101 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); 101 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_);
102 102
103 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { 103 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) {
104 gfx::Rect opaque_rect; 104 gfx::Rect opaque_rect;
105 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 105 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
106 TextureDrawQuad* quad = 106 TextureDrawQuad* quad =
107 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 107 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
108 quad->SetNew(shared_quad_state, scaled_thumb_quad_rect, opaque_rect, 108 quad->SetNew(shared_quad_state, scaled_thumb_quad_rect, opaque_rect,
109 scaled_visible_thumb_quad_rect, thumb_resource_id, 109 scaled_visible_thumb_quad_rect, thumb_resource_id,
110 premultipled_alpha, uv_top_left, uv_bottom_right, 110 premultipled_alpha, uv_top_left, uv_bottom_right,
111 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor); 111 SK_ColorTRANSPARENT, opacity, flipped, nearest_neighbor);
112 } 112 }
113 113
114 gfx::Rect track_quad_rect(bounds()); 114 gfx::Rect track_quad_rect(bounds());
115 gfx::Rect scaled_track_quad_rect(internal_content_bounds_); 115 gfx::Rect scaled_track_quad_rect(internal_content_bounds_);
116 gfx::Rect visible_track_quad_rect = 116 gfx::Rect visible_track_quad_rect =
117 occlusion_in_content_space.GetUnoccludedContentRect(track_quad_rect); 117 draw_properties().occlusion_in_content_space.GetUnoccludedContentRect(
118 track_quad_rect);
118 gfx::Rect scaled_visible_track_quad_rect = gfx::ScaleToEnclosingRect( 119 gfx::Rect scaled_visible_track_quad_rect = gfx::ScaleToEnclosingRect(
119 visible_track_quad_rect, internal_contents_scale_); 120 visible_track_quad_rect, internal_contents_scale_);
120 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) { 121 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) {
121 gfx::Rect opaque_rect(contents_opaque() ? scaled_track_quad_rect 122 gfx::Rect opaque_rect(contents_opaque() ? scaled_track_quad_rect
122 : gfx::Rect()); 123 : gfx::Rect());
123 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 124 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
124 TextureDrawQuad* quad = 125 TextureDrawQuad* quad =
125 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); 126 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>();
126 quad->SetNew(shared_quad_state, scaled_track_quad_rect, opaque_rect, 127 quad->SetNew(shared_quad_state, scaled_track_quad_rect, opaque_rect,
127 scaled_visible_track_quad_rect, track_resource_id, 128 scaled_visible_track_quad_rect, track_resource_id,
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
176 177
177 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { 178 bool PaintedScrollbarLayerImpl::IsThumbResizable() const {
178 return false; 179 return false;
179 } 180 }
180 181
181 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { 182 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const {
182 return "cc::PaintedScrollbarLayerImpl"; 183 return "cc::PaintedScrollbarLayerImpl";
183 } 184 }
184 185
185 } // namespace cc 186 } // namespace cc
OLDNEW
« no previous file with comments | « cc/layers/painted_scrollbar_layer_impl.h ('k') | cc/layers/picture_image_layer_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698