X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2Fquadtree.h;h=4b752696022408e09a8e0da547b260a3233cdaeb;hp=671ee0fdf5e987d28143574914ebf7530aaa0599;hb=888817a67a9d840be66b52811b01eb77f10ff3e6;hpb=35e4687acd16a28fc923a75d254cdb4fd2fbc524 diff --git a/src/quadtree.h b/src/quadtree.h index 671ee0f..4b75269 100644 --- a/src/quadtree.h +++ b/src/quadtree.h @@ -6,6 +6,7 @@ #include "common.h" +#include "ipdf.h" namespace IPDF { @@ -42,9 +43,18 @@ namespace IPDF struct QuadTree { + QuadTree() : root_id(QUADTREE_EMPTY) {} QuadTreeIndex root_id; std::vector nodes; + + QuadTreeIndex GetNeighbour(QuadTreeIndex start, int xdir, int ydir) const; + }; + + Rect TransformToQuadChild(const Rect& src, QuadTreeNodeChildren child_type); + Rect TransformFromQuadChild(const Rect& src, QuadTreeNodeChildren child_type); + bool IntersectsQuadChild(const Rect& src, QuadTreeNodeChildren child_type); + bool ContainedInQuadChild(const Rect& src, QuadTreeNodeChildren child_type); } #else