cpl_quad_tree.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /**********************************************************************
  2. * $Id: cpl_quad_tree.h 27044 2014-03-16 23:41:27Z rouault $
  3. *
  4. * Project: CPL - Common Portability Library
  5. * Purpose: Implementation of quadtree building and searching functions.
  6. * Derived from shapelib and mapserver implementations
  7. * Author: Frank Warmerdam, warmerdam@pobox.com
  8. * Even Rouault, <even dot rouault at mines dash paris dot org>
  9. *
  10. ******************************************************************************
  11. * Copyright (c) 1999-2008, Frank Warmerdam
  12. * Copyright (c) 2008-2014, Even Rouault <even dot rouault at mines-paris dot org>
  13. *
  14. * Permission is hereby granted, free of charge, to any person obtaining a
  15. * copy of this software and associated documentation files (the "Software"),
  16. * to deal in the Software without restriction, including without limitation
  17. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  18. * and/or sell copies of the Software, and to permit persons to whom the
  19. * Software is furnished to do so, subject to the following conditions:
  20. *
  21. * The above copyright notice and this permission notice shall be included
  22. * in all copies or substantial portions of the Software.
  23. *
  24. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  25. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  26. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  27. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  28. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  29. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  30. * DEALINGS IN THE SOFTWARE.
  31. ****************************************************************************/
  32. #ifndef _CPL_QUAD_TREE_H_INCLUDED
  33. #define _CPL_QUAD_TREE_H_INCLUDED
  34. #include "cpl_port.h"
  35. /**
  36. * \file cpl_quad_tree.h
  37. *
  38. * Quad tree implementation.
  39. *
  40. * A quadtree is a tree data structure in which each internal node
  41. * has up to four children. Quadtrees are most often used to partition
  42. * a two dimensional space by recursively subdividing it into four
  43. * quadrants or regions
  44. */
  45. CPL_C_START
  46. /* Types */
  47. typedef struct {
  48. double minx, miny, maxx, maxy;
  49. } CPLRectObj;
  50. typedef struct _CPLQuadTree CPLQuadTree;
  51. typedef void (*CPLQuadTreeGetBoundsFunc)(const void* hFeature, CPLRectObj* pBounds);
  52. typedef int (*CPLQuadTreeForeachFunc)(void* pElt, void* pUserData);
  53. typedef void (*CPLQuadTreeDumpFeatureFunc)(const void* hFeature, int nIndentLevel, void* pUserData);
  54. /* Functions */
  55. CPLQuadTree CPL_DLL *CPLQuadTreeCreate(const CPLRectObj* pGlobalBounds,
  56. CPLQuadTreeGetBoundsFunc pfnGetBounds);
  57. void CPL_DLL CPLQuadTreeDestroy(CPLQuadTree *hQuadtree);
  58. void CPL_DLL CPLQuadTreeSetBucketCapacity(CPLQuadTree *hQuadtree,
  59. int nBucketCapacity);
  60. int CPL_DLL CPLQuadTreeGetAdvisedMaxDepth(int nExpectedFeatures);
  61. void CPL_DLL CPLQuadTreeSetMaxDepth(CPLQuadTree *hQuadtree,
  62. int nMaxDepth);
  63. void CPL_DLL CPLQuadTreeInsert(CPLQuadTree *hQuadtree,
  64. void* hFeature);
  65. void CPL_DLL CPLQuadTreeInsertWithBounds(CPLQuadTree *hQuadtree,
  66. void* hFeature,
  67. const CPLRectObj* psBounds);
  68. void CPL_DLL **CPLQuadTreeSearch(const CPLQuadTree *hQuadtree,
  69. const CPLRectObj* pAoi,
  70. int* pnFeatureCount);
  71. void CPL_DLL CPLQuadTreeForeach(const CPLQuadTree *hQuadtree,
  72. CPLQuadTreeForeachFunc pfnForeach,
  73. void* pUserData);
  74. void CPL_DLL CPLQuadTreeDump(const CPLQuadTree *hQuadtree,
  75. CPLQuadTreeDumpFeatureFunc pfnDumpFeatureFunc,
  76. void* pUserData);
  77. void CPL_DLL CPLQuadTreeGetStats(const CPLQuadTree *hQuadtree,
  78. int* pnFeatureCount,
  79. int* pnNodeCount,
  80. int* pnMaxDepth,
  81. int* pnMaxBucketCapacity);
  82. CPL_C_END
  83. #endif