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

Side by Side Diff: cc/trees/layer_sorter.h

Issue 960893004: Revert of Splitting of layers for correct intersections (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 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
« no previous file with comments | « cc/test/data/intersecting_blue_green_squares_video.png ('k') | cc/trees/layer_sorter.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CC_TREES_LAYER_SORTER_H_
6 #define CC_TREES_LAYER_SORTER_H_
7
8 #include <vector>
9
10 #include "base/basictypes.h"
11 #include "base/containers/hash_tables.h"
12 #include "cc/base/cc_export.h"
13 #include "cc/layers/layer_impl.h"
14 #include "ui/gfx/geometry/point3_f.h"
15 #include "ui/gfx/geometry/quad_f.h"
16 #include "ui/gfx/geometry/rect_f.h"
17 #include "ui/gfx/geometry/vector3d_f.h"
18
19 namespace gfx {
20 class Transform;
21 }
22
23 namespace cc {
24 struct GraphEdge;
25
26 // Holds various useful properties derived from a layer's 3D outline.
27 struct CC_EXPORT LayerShape {
28 LayerShape();
29 LayerShape(float width, float height, const gfx::Transform& draw_transform);
30 ~LayerShape();
31
32 float LayerZFromProjectedPoint(const gfx::PointF& p) const;
33
34 gfx::Vector3dF layer_normal;
35 gfx::Point3F transform_origin;
36 gfx::QuadF projected_quad;
37 gfx::RectF projected_bounds;
38 };
39
40 struct GraphNode {
41 explicit GraphNode(LayerImpl* layer_impl);
42 ~GraphNode();
43
44 LayerImpl* layer;
45 LayerShape shape;
46 std::vector<GraphEdge*> incoming;
47 std::vector<GraphEdge*> outgoing;
48 float incoming_edge_weight;
49 };
50
51 struct GraphEdge {
52 GraphEdge(GraphNode* from_node, GraphNode* to_node, float weight)
53 : from(from_node),
54 to(to_node),
55 weight(weight) {}
56
57 GraphNode* from;
58 GraphNode* to;
59 float weight;
60 };
61
62
63
64 class CC_EXPORT LayerSorter {
65 public:
66 LayerSorter();
67 ~LayerSorter();
68
69 void Sort(LayerImplList::iterator first, LayerImplList::iterator last);
70
71 enum ABCompareResult { A_BEFORE_B, B_BEFORE_A, NONE };
72
73 static ABCompareResult CheckOverlap(LayerShape* a,
74 LayerShape* b,
75 float z_threshold,
76 float* weight);
77
78 private:
79 typedef std::vector<GraphNode> NodeList;
80 typedef std::vector<GraphEdge> EdgeList;
81 NodeList nodes_;
82 EdgeList edges_;
83 float z_range_;
84
85 typedef base::hash_map<GraphEdge*, GraphEdge*> EdgeMap;
86 EdgeMap active_edges_;
87
88 void CreateGraphNodes(LayerImplList::iterator first,
89 LayerImplList::iterator last);
90 void CreateGraphEdges();
91 void RemoveEdgeFromList(GraphEdge* graph, std::vector<GraphEdge*>* list);
92
93 DISALLOW_COPY_AND_ASSIGN(LayerSorter);
94 };
95
96 } // namespace cc
97 #endif // CC_TREES_LAYER_SORTER_H_
OLDNEW
« no previous file with comments | « cc/test/data/intersecting_blue_green_squares_video.png ('k') | cc/trees/layer_sorter.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698