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

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

Issue 308193003: Removed QuadSink and MockQuadCuller (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@plumLayerImpl
Patch Set: rm unused line Created 6 years, 6 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"
11 #include "cc/layers/quad_sink.h"
12 #include "cc/quads/solid_color_draw_quad.h" 11 #include "cc/quads/solid_color_draw_quad.h"
13 #include "cc/quads/texture_draw_quad.h" 12 #include "cc/quads/texture_draw_quad.h"
14 #include "cc/trees/layer_tree_impl.h" 13 #include "cc/trees/layer_tree_impl.h"
15 #include "cc/trees/layer_tree_settings.h" 14 #include "cc/trees/layer_tree_settings.h"
15 #include "cc/trees/occlusion_tracker.h"
16 #include "ui/gfx/rect_conversions.h" 16 #include "ui/gfx/rect_conversions.h"
17 17
18 namespace cc { 18 namespace cc {
19 19
20 scoped_ptr<PaintedScrollbarLayerImpl> PaintedScrollbarLayerImpl::Create( 20 scoped_ptr<PaintedScrollbarLayerImpl> PaintedScrollbarLayerImpl::Create(
21 LayerTreeImpl* tree_impl, 21 LayerTreeImpl* tree_impl,
22 int id, 22 int id,
23 ScrollbarOrientation orientation) { 23 ScrollbarOrientation orientation) {
24 return make_scoped_ptr( 24 return make_scoped_ptr(
25 new PaintedScrollbarLayerImpl(tree_impl, id, orientation)); 25 new PaintedScrollbarLayerImpl(tree_impl, id, orientation));
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
62 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_); 62 scrollbar_layer->set_thumb_ui_resource_id(thumb_ui_resource_id_);
63 } 63 }
64 64
65 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode, 65 bool PaintedScrollbarLayerImpl::WillDraw(DrawMode draw_mode,
66 ResourceProvider* resource_provider) { 66 ResourceProvider* resource_provider) {
67 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE); 67 DCHECK(draw_mode != DRAW_MODE_RESOURCELESS_SOFTWARE);
68 return LayerImpl::WillDraw(draw_mode, resource_provider); 68 return LayerImpl::WillDraw(draw_mode, resource_provider);
69 } 69 }
70 70
71 void PaintedScrollbarLayerImpl::AppendQuads( 71 void PaintedScrollbarLayerImpl::AppendQuads(
72 QuadSink* quad_sink, 72 RenderPass* render_pass,
73 const OcclusionTracker<LayerImpl>& occlusion_tracker,
73 AppendQuadsData* append_quads_data) { 74 AppendQuadsData* append_quads_data) {
74 bool premultipled_alpha = true; 75 bool premultipled_alpha = true;
75 bool flipped = false; 76 bool flipped = false;
76 gfx::PointF uv_top_left(0.f, 0.f); 77 gfx::PointF uv_top_left(0.f, 0.f);
77 gfx::PointF uv_bottom_right(1.f, 1.f); 78 gfx::PointF uv_bottom_right(1.f, 1.f);
78 gfx::Rect bounds_rect(bounds()); 79 gfx::Rect bounds_rect(bounds());
79 gfx::Rect content_bounds_rect(content_bounds()); 80 gfx::Rect content_bounds_rect(content_bounds());
80 81
81 SharedQuadState* shared_quad_state = quad_sink->CreateSharedQuadState(); 82 SharedQuadState* shared_quad_state =
83 render_pass->CreateAndAppendSharedQuadState();
82 PopulateSharedQuadState(shared_quad_state); 84 PopulateSharedQuadState(shared_quad_state);
83 85
84 AppendDebugBorderQuad(quad_sink, shared_quad_state, append_quads_data); 86 AppendDebugBorderQuad(render_pass, shared_quad_state, append_quads_data);
85 87
86 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect(); 88 gfx::Rect thumb_quad_rect = ComputeThumbQuadRect();
87 gfx::Rect visible_thumb_quad_rect = 89 gfx::Rect visible_thumb_quad_rect = occlusion_tracker.UnoccludedContentRect(
88 quad_sink->UnoccludedContentRect(this, thumb_quad_rect, draw_transform()); 90 this->render_target(), thumb_quad_rect, draw_transform());
89 91
90 ResourceProvider::ResourceId thumb_resource_id = 92 ResourceProvider::ResourceId thumb_resource_id =
91 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_); 93 layer_tree_impl()->ResourceIdForUIResource(thumb_ui_resource_id_);
92 ResourceProvider::ResourceId track_resource_id = 94 ResourceProvider::ResourceId track_resource_id =
93 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_); 95 layer_tree_impl()->ResourceIdForUIResource(track_ui_resource_id_);
94 96
95 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) { 97 if (thumb_resource_id && !visible_thumb_quad_rect.IsEmpty()) {
96 gfx::Rect opaque_rect; 98 gfx::Rect opaque_rect;
97 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 99 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
98 scoped_ptr<TextureDrawQuad> quad = TextureDrawQuad::Create(); 100 scoped_ptr<TextureDrawQuad> quad = TextureDrawQuad::Create();
99 quad->SetNew(shared_quad_state, 101 quad->SetNew(shared_quad_state,
100 thumb_quad_rect, 102 thumb_quad_rect,
101 opaque_rect, 103 opaque_rect,
102 visible_thumb_quad_rect, 104 visible_thumb_quad_rect,
103 thumb_resource_id, 105 thumb_resource_id,
104 premultipled_alpha, 106 premultipled_alpha,
105 uv_top_left, 107 uv_top_left,
106 uv_bottom_right, 108 uv_bottom_right,
107 SK_ColorTRANSPARENT, 109 SK_ColorTRANSPARENT,
108 opacity, 110 opacity,
109 flipped); 111 flipped);
110 quad_sink->Append(quad.PassAs<DrawQuad>()); 112 render_pass->AppendDrawQuad(quad.PassAs<DrawQuad>());
111 } 113 }
112 114
113 gfx::Rect track_quad_rect = content_bounds_rect; 115 gfx::Rect track_quad_rect = content_bounds_rect;
114 gfx::Rect visible_track_quad_rect = 116 gfx::Rect visible_track_quad_rect = occlusion_tracker.UnoccludedContentRect(
115 quad_sink->UnoccludedContentRect(this, track_quad_rect, draw_transform()); 117 this->render_target(), track_quad_rect, draw_transform());
116 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) { 118 if (track_resource_id && !visible_track_quad_rect.IsEmpty()) {
117 gfx::Rect opaque_rect(contents_opaque() ? track_quad_rect : gfx::Rect()); 119 gfx::Rect opaque_rect(contents_opaque() ? track_quad_rect : gfx::Rect());
118 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f}; 120 const float opacity[] = {1.0f, 1.0f, 1.0f, 1.0f};
119 scoped_ptr<TextureDrawQuad> quad = TextureDrawQuad::Create(); 121 scoped_ptr<TextureDrawQuad> quad = TextureDrawQuad::Create();
120 quad->SetNew(shared_quad_state, 122 quad->SetNew(shared_quad_state,
121 track_quad_rect, 123 track_quad_rect,
122 opaque_rect, 124 opaque_rect,
123 visible_track_quad_rect, 125 visible_track_quad_rect,
124 track_resource_id, 126 track_resource_id,
125 premultipled_alpha, 127 premultipled_alpha,
126 uv_top_left, 128 uv_top_left,
127 uv_bottom_right, 129 uv_bottom_right,
128 SK_ColorTRANSPARENT, 130 SK_ColorTRANSPARENT,
129 opacity, 131 opacity,
130 flipped); 132 flipped);
131 quad_sink->Append(quad.PassAs<DrawQuad>()); 133 render_pass->AppendDrawQuad(quad.PassAs<DrawQuad>());
132 } 134 }
133 } 135 }
134 136
135 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) { 137 void PaintedScrollbarLayerImpl::SetThumbThickness(int thumb_thickness) {
136 if (thumb_thickness_ == thumb_thickness) 138 if (thumb_thickness_ == thumb_thickness)
137 return; 139 return;
138 thumb_thickness_ = thumb_thickness; 140 thumb_thickness_ = thumb_thickness;
139 NoteLayerPropertyChanged(); 141 NoteLayerPropertyChanged();
140 } 142 }
141 143
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
178 180
179 bool PaintedScrollbarLayerImpl::IsThumbResizable() const { 181 bool PaintedScrollbarLayerImpl::IsThumbResizable() const {
180 return false; 182 return false;
181 } 183 }
182 184
183 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const { 185 const char* PaintedScrollbarLayerImpl::LayerTypeAsString() const {
184 return "cc::PaintedScrollbarLayerImpl"; 186 return "cc::PaintedScrollbarLayerImpl";
185 } 187 }
186 188
187 } // namespace cc 189 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698