summaryrefslogtreecommitdiffstats
path: root/cc/trees/layer_sorter.h
diff options
context:
space:
mode:
authorjamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-03-18 08:03:04 +0000
committerjamesr@chromium.org <jamesr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2013-03-18 08:03:04 +0000
commit556fd29842f0ad999d8d3b302636bcafc46792de (patch)
treebca322141170ab48c18539ed5257c14774ec8531 /cc/trees/layer_sorter.h
parent89e8267acd40726861cbe9eef803534000286c70 (diff)
downloadchromium_src-556fd29842f0ad999d8d3b302636bcafc46792de.zip
chromium_src-556fd29842f0ad999d8d3b302636bcafc46792de.tar.gz
chromium_src-556fd29842f0ad999d8d3b302636bcafc46792de.tar.bz2
Part 7 of cc/ directory shuffles: trees
Continuation of https://src.chromium.org/viewvc/chrome?view=rev&revision=188681 BUG=190824 TBR=enne@chromium.org, piman@chromium.org Review URL: https://codereview.chromium.org/12722007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@188694 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'cc/trees/layer_sorter.h')
-rw-r--r--cc/trees/layer_sorter.h113
1 files changed, 113 insertions, 0 deletions
diff --git a/cc/trees/layer_sorter.h b/cc/trees/layer_sorter.h
new file mode 100644
index 0000000..3b3e839
--- /dev/null
+++ b/cc/trees/layer_sorter.h
@@ -0,0 +1,113 @@
+// Copyright 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CC_TREES_LAYER_SORTER_H_
+#define CC_TREES_LAYER_SORTER_H_
+
+#include "base/basictypes.h"
+#include "base/hash_tables.h"
+#include "cc/base/cc_export.h"
+#include "cc/layer_impl.h"
+#include "ui/gfx/point3_f.h"
+#include "ui/gfx/quad_f.h"
+#include "ui/gfx/rect_f.h"
+#include "ui/gfx/vector3d_f.h"
+
+#if defined(COMPILER_GCC)
+namespace cc { struct GraphEdge; }
+
+namespace BASE_HASH_NAMESPACE {
+template <>
+struct hash<cc::GraphEdge*> {
+ size_t operator()(cc::GraphEdge* ptr) const {
+ return hash<size_t>()(reinterpret_cast<size_t>(ptr));
+ }
+};
+} // namespace BASE_HASH_NAMESPACE
+#endif // COMPILER
+
+namespace gfx {
+class Transform;
+}
+
+namespace cc {
+struct GraphEdge;
+
+// Holds various useful properties derived from a layer's 3D outline.
+struct CC_EXPORT LayerShape {
+ LayerShape();
+ LayerShape(float width, float height, const gfx::Transform& draw_transform);
+ ~LayerShape();
+
+ float LayerZFromProjectedPoint(gfx::PointF p) const;
+
+ gfx::Vector3dF layer_normal;
+ gfx::Point3F transform_origin;
+ gfx::QuadF projected_quad;
+ gfx::RectF projected_bounds;
+};
+
+struct GraphNode {
+ explicit GraphNode(LayerImpl* layer_impl);
+ ~GraphNode();
+
+ LayerImpl* layer;
+ LayerShape shape;
+ std::vector<GraphEdge*> incoming;
+ std::vector<GraphEdge*> outgoing;
+ float incoming_edge_weight;
+};
+
+struct GraphEdge {
+ GraphEdge(GraphNode* from_node, GraphNode* to_node, float weight)
+ : from(from_node),
+ to(to_node),
+ weight(weight) {}
+
+ GraphNode* from;
+ GraphNode* to;
+ float weight;
+};
+
+
+
+class CC_EXPORT LayerSorter {
+ public:
+ LayerSorter();
+ ~LayerSorter();
+
+ typedef std::vector<LayerImpl*> LayerList;
+
+ void Sort(LayerList::iterator first, LayerList::iterator last);
+
+ enum ABCompareResult {
+ ABeforeB,
+ BBeforeA,
+ None
+ };
+
+ static ABCompareResult CheckOverlap(LayerShape* a,
+ LayerShape* b,
+ float z_threshold,
+ float* weight);
+
+ private:
+ typedef std::vector<GraphNode> NodeList;
+ typedef std::vector<GraphEdge> EdgeList;
+ NodeList nodes_;
+ EdgeList edges_;
+ float z_range_;
+
+ typedef base::hash_map<GraphEdge*, GraphEdge*> EdgeMap;
+ EdgeMap active_edges_;
+
+ void CreateGraphNodes(LayerList::iterator first, LayerList::iterator last);
+ void CreateGraphEdges();
+ void RemoveEdgeFromList(GraphEdge* graph, std::vector<GraphEdge*>* list);
+
+ DISALLOW_COPY_AND_ASSIGN(LayerSorter);
+};
+
+}
+#endif // CC_TREES_LAYER_SORTER_H_