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

Side by Side Diff: cc/surfaces/surface_hittest.cc

Issue 2449853004: Getting rid of DelegatedFrameData (Closed)
Patch Set: IsEmpty + rebase Created 4 years, 1 month 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/surfaces/surface_hittest.h" 5 #include "cc/surfaces/surface_hittest.h"
6 6
7 #include "cc/output/compositor_frame.h" 7 #include "cc/output/compositor_frame.h"
8 #include "cc/output/delegated_frame_data.h"
9 #include "cc/quads/draw_quad.h" 8 #include "cc/quads/draw_quad.h"
10 #include "cc/quads/render_pass_draw_quad.h" 9 #include "cc/quads/render_pass_draw_quad.h"
11 #include "cc/quads/surface_draw_quad.h" 10 #include "cc/quads/surface_draw_quad.h"
12 #include "cc/surfaces/surface.h" 11 #include "cc/surfaces/surface.h"
13 #include "cc/surfaces/surface_hittest_delegate.h" 12 #include "cc/surfaces/surface_hittest_delegate.h"
14 #include "cc/surfaces/surface_manager.h" 13 #include "cc/surfaces/surface_manager.h"
15 #include "ui/gfx/geometry/point.h" 14 #include "ui/gfx/geometry/point.h"
16 #include "ui/gfx/transform.h" 15 #include "ui/gfx/transform.h"
17 16
18 namespace cc { 17 namespace cc {
(...skipping 233 matching lines...) Expand 10 before | Expand all | Expand 10 after
252 // The target surface was not found. 251 // The target surface was not found.
253 return false; 252 return false;
254 } 253 }
255 254
256 const RenderPass* SurfaceHittest::GetRenderPassForSurfaceById( 255 const RenderPass* SurfaceHittest::GetRenderPassForSurfaceById(
257 const SurfaceId& surface_id, 256 const SurfaceId& surface_id,
258 const RenderPassId& render_pass_id) { 257 const RenderPassId& render_pass_id) {
259 Surface* surface = manager_->GetSurfaceForId(surface_id); 258 Surface* surface = manager_->GetSurfaceForId(surface_id);
260 if (!surface) 259 if (!surface)
261 return nullptr; 260 return nullptr;
262 261
danakj 2016/10/27 23:06:57 nit: remove whitespace
Saman Sami 2016/10/28 16:47:36 Done.
262 if (!surface->HasFrame())
263 return nullptr;
263 const CompositorFrame& surface_frame = surface->GetEligibleFrame(); 264 const CompositorFrame& surface_frame = surface->GetEligibleFrame();
264 if (!surface_frame.delegated_frame_data)
265 return nullptr;
266 265
267 const DelegatedFrameData* frame_data = 266 if (surface_frame.render_pass_list.empty())
268 surface_frame.delegated_frame_data.get();
269 if (frame_data->render_pass_list.empty())
270 return nullptr; 267 return nullptr;
271 268
272 if (!render_pass_id.IsValid()) 269 if (!render_pass_id.IsValid())
273 return frame_data->render_pass_list.back().get(); 270 return surface_frame.render_pass_list.back().get();
274 271
275 for (const auto& render_pass : frame_data->render_pass_list) { 272 for (const auto& render_pass : surface_frame.render_pass_list) {
276 if (render_pass->id == render_pass_id) 273 if (render_pass->id == render_pass_id)
277 return render_pass.get(); 274 return render_pass.get();
278 } 275 }
279 276
280 return nullptr; 277 return nullptr;
281 } 278 }
282 279
283 bool SurfaceHittest::PointInQuad(const DrawQuad* quad, 280 bool SurfaceHittest::PointInQuad(const DrawQuad* quad,
284 const gfx::Point& point_in_render_pass_space, 281 const gfx::Point& point_in_render_pass_space,
285 gfx::Transform* target_to_quad_transform, 282 gfx::Transform* target_to_quad_transform,
(...skipping 13 matching lines...) Expand all
299 return false; 296 return false;
300 } 297 }
301 298
302 *point_in_quad_space = point_in_render_pass_space; 299 *point_in_quad_space = point_in_render_pass_space;
303 target_to_quad_transform->TransformPoint(point_in_quad_space); 300 target_to_quad_transform->TransformPoint(point_in_quad_space);
304 301
305 return quad->rect.Contains(*point_in_quad_space); 302 return quad->rect.Contains(*point_in_quad_space);
306 } 303 }
307 304
308 } // namespace cc 305 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698