22#include "moc_qgschunkloader.cpp"
26QgsQuadtreeChunkLoaderFactory::QgsQuadtreeChunkLoaderFactory() =
default;
28QgsQuadtreeChunkLoaderFactory::~QgsQuadtreeChunkLoaderFactory() =
default;
30void QgsQuadtreeChunkLoaderFactory::setupQuadtree(
const QgsBox3D &rootBox3D,
float rootError,
int maxLevel,
const QgsBox3D &clippingBox3D )
32 mRootBox3D = rootBox3D;
33 mRootError = rootError;
35 mClippingBox3D = clippingBox3D;
38QgsChunkNode *QgsQuadtreeChunkLoaderFactory::createRootNode()
const
40 return new QgsChunkNode( QgsChunkNodeId( 0, 0, 0 ), mRootBox3D, mRootError );
43QVector<QgsChunkNode *> QgsQuadtreeChunkLoaderFactory::createChildren( QgsChunkNode *node )
const
45 QVector<QgsChunkNode *> children;
48 if ( mMaxLevel != -1 && node->level() >= mMaxLevel )
51 const QgsBox3D box3D = node->box3D();
57 const QgsChunkNodeId nodeId = node->tileId();
58 const float childError = node->error() / 2;
59 QgsVector3D center = box3D.
center();
63 const bool skipDx = box3D.
height() > box3D.
width() * 2;
64 const bool skipDy = box3D.
width() > box3D.
height() * 2;
65 for (
int i = 0; i < 4; ++i )
67 int dx = i & 1, dy = !!( i & 2 );
74 const QgsChunkNodeId childId( nodeId.d + 1, nodeId.x * 2 + dx, nodeId.y * 2 + dy );
76 const double chXMin = dx ? center.
x() : box3D.
xMinimum();
77 const double chXMax = dx || skipDx ? box3D.
xMaximum() : center.
x();
78 const double chYMin = dy ? center.
y() : box3D.
yMinimum();
79 const double chYMax = dy || skipDy ? box3D.
yMaximum() : center.
y();
80 const double chZMin = box3D.
zMinimum();
81 const double chZMax = box3D.
zMaximum();
82 const QgsBox3D childBox3D( chXMin, chYMin, chZMin, chXMax, chYMax, chZMax );
85 if ( mClippingBox3D.isNull() || childBox3D.intersects( mClippingBox3D ) )
86 children <<
new QgsChunkNode( childId, childBox3D, childError, node );
A 3-dimensional box composed of x, y, z coordinates.
double yMaximum() const
Returns the maximum y value.
double xMinimum() const
Returns the minimum x value.
double zMaximum() const
Returns the maximum z value.
QgsVector3D center() const
Returns the center of the box as a vector.
double xMaximum() const
Returns the maximum x value.
double width() const
Returns the width of the box.
double zMinimum() const
Returns the minimum z value.
double yMinimum() const
Returns the minimum y value.
double height() const
Returns the height of the box.
bool isNull() const
Test if the box is null (holding no spatial information).
double y() const
Returns Y coordinate.
double x() const
Returns X coordinate.