cesium-native 0.48.0
Loading...
Searching...
No Matches
Tile.h
1#pragma once
2
3#include <Cesium3DTilesSelection/BoundingVolume.h>
4#include <Cesium3DTilesSelection/Library.h>
5#include <Cesium3DTilesSelection/RasterMappedTo3DTile.h>
6#include <Cesium3DTilesSelection/TileContent.h>
7#include <Cesium3DTilesSelection/TileID.h>
8#include <Cesium3DTilesSelection/TileRefine.h>
9#include <Cesium3DTilesSelection/TileSelectionState.h>
10#include <CesiumUtility/DoublyLinkedList.h>
11#include <CesiumUtility/IntrusivePointer.h>
12
13#include <glm/common.hpp>
14
15#include <atomic>
16#include <limits>
17#include <memory>
18#include <optional>
19#include <span>
20#include <string>
21#include <vector>
22
23#ifdef CESIUM_DEBUG_TILE_UNLOADING
24#include <unordered_map>
25#endif
26
27namespace Cesium3DTilesSelection {
29
30#ifdef CESIUM_DEBUG_TILE_UNLOADING
31class TileReferenceCountTracker {
32private:
33 struct Entry {
34 std::string reason;
35 bool increment;
36 int32_t newCount;
37 };
38
39public:
40 static void addEntry(
41 const uint64_t id,
42 bool increment,
43 const char* reason,
44 int32_t newCount);
45
46private:
47 static std::unordered_map<std::string, std::vector<Entry>> _entries;
48};
49#endif
50
54enum class TileLoadState {
60
66
72
81
86
90 Done = 3,
91
96 Failed = 4,
97};
98
122class CESIUM3DTILESSELECTION_API Tile final {
123public:
132
142 explicit Tile(
143 TilesetContentLoader* pLoader,
144 const TileID& tileID = {}) noexcept;
145
164 TilesetContentLoader* pLoader,
165 const TileID& tileID,
166 std::unique_ptr<TileExternalContent>&& externalContent) noexcept;
167
186 TilesetContentLoader* pLoader,
187 const TileID& tileID,
188 TileEmptyContent emptyContent) noexcept;
189
194 ~Tile() noexcept;
195
201 Tile(const Tile& rhs) = delete;
202
208 Tile(Tile&& rhs) noexcept;
209
215 Tile& operator=(const Tile& rhs) = delete;
216
222 Tile& operator=(Tile&& rhs) noexcept = delete;
223
231 Tile* getParent() noexcept { return this->_pParent; }
232
234 const Tile* getParent() const noexcept { return this->_pParent; }
235
243 std::span<Tile> getChildren() noexcept {
244 return std::span<Tile>(this->_children);
245 }
246
248 std::span<const Tile> getChildren() const noexcept {
249 return std::span<const Tile>(this->_children);
250 }
251
257 void clearChildren() noexcept;
258
267 void createChildTiles(std::vector<Tile>&& children);
268
279 const BoundingVolume& getBoundingVolume() const noexcept {
280 return this->_boundingVolume;
281 }
282
290 void setBoundingVolume(const BoundingVolume& value) noexcept {
291 this->_boundingVolume = value;
292 }
293
305 const std::optional<BoundingVolume>& getViewerRequestVolume() const noexcept {
306 return this->_viewerRequestVolume;
307 }
308
316 void
317 setViewerRequestVolume(const std::optional<BoundingVolume>& value) noexcept {
318 this->_viewerRequestVolume = value;
319 }
320
330 double getGeometricError() const noexcept { return this->_geometricError; }
331
339 void setGeometricError(double value) noexcept {
340 this->_geometricError = value;
341 }
342
357 double getNonZeroGeometricError() const noexcept;
358
369 bool getUnconditionallyRefine() const noexcept {
370 return glm::isinf(this->_geometricError);
371 }
372
378 void setUnconditionallyRefine() noexcept {
379 this->_geometricError = std::numeric_limits<double>::infinity();
380 }
381
393 TileRefine getRefine() const noexcept { return this->_refine; }
394
402 void setRefine(TileRefine value) noexcept { this->_refine = value; }
403
412 const glm::dmat4x4& getTransform() const noexcept { return this->_transform; }
413
421 void setTransform(const glm::dmat4x4& value) noexcept {
422 this->_transform = value;
423 }
424
432 const TileID& getTileID() const noexcept { return this->_id; }
433
441 void setTileID(const TileID& id) noexcept { this->_id = id; }
442
454 const std::optional<BoundingVolume>&
455 getContentBoundingVolume() const noexcept {
456 return this->_contentBoundingVolume;
457 }
458
468 const std::optional<BoundingVolume>& value) noexcept {
469 this->_contentBoundingVolume = value;
470 }
471
476 int64_t computeByteSize() const noexcept;
477
482 return this->_rasterTiles;
483 }
484
486 const std::vector<RasterMappedTo3DTile>&
487 getMappedRasterTiles() const noexcept {
488 return this->_rasterTiles;
489 }
490
494 const TileContent& getContent() const noexcept { return _content; }
495
497 TileContent& getContent() noexcept { return _content; }
498
502 bool isRenderable() const noexcept;
503
507 bool isRenderContent() const noexcept;
508
512 bool isExternalContent() const noexcept;
513
517 bool isEmptyContent() const noexcept;
518
523
527 TileLoadState getState() const noexcept;
528
535 bool needsWorkerThreadLoading() const noexcept;
536
543 bool needsMainThreadLoading() const noexcept;
544
579 void addReference(const char* reason = nullptr) noexcept;
580
603 void releaseReference(const char* reason = nullptr) noexcept;
604
611 int32_t getReferenceCount() const noexcept;
612
631 bool hasReferencingContent() const noexcept;
632
633private:
634 struct TileConstructorImpl {};
635 template <
636 typename... TileContentArgs,
637 typename TileContentEnable = std::enable_if_t<
638 std::is_constructible_v<TileContent, TileContentArgs&&...>,
639 int>>
640 Tile(
641 TileConstructorImpl tag,
642 TileLoadState loadState,
643 TilesetContentLoader* pLoader,
644 const TileID& tileID,
645 TileContentArgs&&... args);
646
647 void setParent(Tile* pParent) noexcept;
648
649 void setState(TileLoadState state) noexcept;
650
666 bool getMightHaveLatentChildren() const noexcept;
667
668 void setMightHaveLatentChildren(bool mightHaveLatentChildren) noexcept;
669
670 // Position in bounding-volume hierarchy.
671 Tile* _pParent;
672 std::vector<Tile> _children;
673
674 // Properties from tileset.json.
675 // These are immutable after the tile leaves TileState::Unloaded.
676 TileID _id;
677 BoundingVolume _boundingVolume;
678 std::optional<BoundingVolume> _viewerRequestVolume;
679 std::optional<BoundingVolume> _contentBoundingVolume;
680 double _geometricError;
681 TileRefine _refine;
682 glm::dmat4x4 _transform;
683
684 // tile content
685 CesiumUtility::DoublyLinkedListPointers<Tile> _unusedTilesLinks;
686 TileContent _content;
687 TilesetContentLoader* _pLoader;
688 TileLoadState _loadState;
689 bool _mightHaveLatentChildren;
690
691 // mapped raster overlay
692 std::vector<RasterMappedTo3DTile> _rasterTiles;
693
694 int32_t _referenceCount;
695
696 friend class TilesetContentManager;
697 friend class MockTilesetContentManagerTestFixture;
698
699public:
703 typedef CesiumUtility::DoublyLinkedList<Tile, &Tile::_unusedTilesLinks>
705};
706
707} // namespace Cesium3DTilesSelection
The result of applying a CesiumRasterOverlays::RasterOverlayTile to geometry.
A tile content container that can store and query the content type that is currently being owned by t...
A tile in a Tileset.
Definition Tile.h:122
Tile(TilesetContentLoader *pLoader, const TileID &tileID={}) noexcept
Construct a tile with unknown content and a loader that is used to load the content of this tile....
const std::optional< BoundingVolume > & getViewerRequestVolume() const noexcept
Returns the viewer request volume of this tile.
Definition Tile.h:305
const std::optional< BoundingVolume > & getContentBoundingVolume() const noexcept
Returns the BoundingVolume of the renderable content of this tile.
Definition Tile.h:455
const TileID & getTileID() const noexcept
Returns the TileID of this tile.
Definition Tile.h:432
double getNonZeroGeometricError() const noexcept
Gets the tile's geometric error as if by calling getGeometricError, except that if the error is small...
CesiumUtility::DoublyLinkedList< Tile, &Tile::_unusedTilesLinks > UnusedLinkedList
A CesiumUtility::DoublyLinkedList for tile objects.
Definition Tile.h:704
void addReference(const char *reason=nullptr) noexcept
Adds a reference to this tile. A live reference will keep this tile from being destroyed,...
const std::vector< RasterMappedTo3DTile > & getMappedRasterTiles() const noexcept
Returns the raster overlay tiles that have been mapped to this tile.
Definition Tile.h:487
void setGeometricError(double value) noexcept
Set the geometric error of the contents of this tile.
Definition Tile.h:339
bool isExternalContent() const noexcept
Determines if this tile has external tileset content.
TileLoadState getState() const noexcept
Returns the TileLoadState of this tile.
void setTileID(const TileID &id) noexcept
Set the TileID of this tile.
Definition Tile.h:441
bool hasReferencingContent() const noexcept
Determines if this tile's getContent counts as a reference to this tile.
int64_t computeByteSize() const noexcept
Determines the number of bytes in this tile's geometry and texture data.
void createChildTiles(std::vector< Tile > &&children)
Assigns the given child tiles to this tile.
bool isRenderContent() const noexcept
Determines if this tile has mesh content.
bool needsMainThreadLoading() const noexcept
Determines if this tile requires main-thread loading.
Tile(TilesetContentLoader *pLoader, const TileID &tileID, std::unique_ptr< TileExternalContent > &&externalContent) noexcept
Construct a tile with an external content and a loader that is associated with this tile....
Tile * getParent() noexcept
Returns the parent of this tile in the tile hierarchy.
Definition Tile.h:231
bool isRenderable() const noexcept
Determines if this tile is currently renderable.
~Tile() noexcept
Default destructor, which clears all resources associated with this tile.
Tile(TilesetContentLoader *pLoader, const TileID &tileID, TileEmptyContent emptyContent) noexcept
Construct a tile with an empty content and a loader that is associated with this tile....
void clearChildren() noexcept
Clears the children of this tile.
CesiumUtility::IntrusivePointer< Tile > Pointer
A reference counting pointer to a Tile.
Definition Tile.h:131
std::span< const Tile > getChildren() const noexcept
Returns a view on the children of this tile.
Definition Tile.h:248
bool needsWorkerThreadLoading() const noexcept
Determines if this tile requires worker-thread loading.
void setRefine(TileRefine value) noexcept
Set the refinement strategy of this tile.
Definition Tile.h:402
const glm::dmat4x4 & getTransform() const noexcept
Gets the transformation matrix for this tile.
Definition Tile.h:412
std::span< Tile > getChildren() noexcept
Returns a view on the children of this tile.
Definition Tile.h:243
TilesetContentLoader * getLoader() const noexcept
get the loader that is used to load the tile content.
void setTransform(const glm::dmat4x4 &value) noexcept
Set the transformation matrix for this tile.
Definition Tile.h:421
void setViewerRequestVolume(const std::optional< BoundingVolume > &value) noexcept
Set the viewer request volume of this tile.
Definition Tile.h:317
TileRefine getRefine() const noexcept
The refinement strategy of this tile.
Definition Tile.h:393
std::vector< RasterMappedTo3DTile > & getMappedRasterTiles() noexcept
Returns the raster overlay tiles that have been mapped to this tile.
Definition Tile.h:481
void releaseReference(const char *reason=nullptr) noexcept
Removes a reference from this tile. A live reference will keep this tile from being destroyed,...
int32_t getReferenceCount() const noexcept
Gets the current number of references to this tile.
void setContentBoundingVolume(const std::optional< BoundingVolume > &value) noexcept
Set the BoundingVolume of the renderable content of this tile.
Definition Tile.h:467
const BoundingVolume & getBoundingVolume() const noexcept
Returns the BoundingVolume of this tile.
Definition Tile.h:279
void setBoundingVolume(const BoundingVolume &value) noexcept
Set the BoundingVolume of this tile.
Definition Tile.h:290
void setUnconditionallyRefine() noexcept
Marks that this tile should be unconditionally refined.
Definition Tile.h:378
bool getUnconditionallyRefine() const noexcept
Returns whether to unconditionally refine this tile.
Definition Tile.h:369
TileContent & getContent() noexcept
Get the content of the tile.
Definition Tile.h:497
bool isEmptyContent() const noexcept
Determines if this tile has empty content.
const TileContent & getContent() const noexcept
Get the content of the tile.
Definition Tile.h:494
double getGeometricError() const noexcept
Returns the geometric error of this tile.
Definition Tile.h:330
const Tile * getParent() const noexcept
Returns the parent of this tile in the tile hierarchy.
Definition Tile.h:234
The loader interface to load the tile content.
A smart pointer that calls addReference and releaseReference on the controlled object.
Classes that implement the 3D Tiles standard.
@ ContentLoaded
The tile content has finished loading.
Definition Tile.h:85
@ Unloading
This tile is in the process of being unloaded, but could not be fully unloaded because an asynchronou...
Definition Tile.h:59
@ ContentLoading
The tile content is currently being loaded.
Definition Tile.h:80
@ FailedTemporarily
Something went wrong while loading this tile, but it may be a temporary problem.
Definition Tile.h:65
@ Unloaded
The tile is not yet loaded at all, beyond the metadata in tileset.json.
Definition Tile.h:71
@ Failed
Something went wrong while loading this tile and it will not be retried.
Definition Tile.h:96
@ Done
The tile is completely done loading.
Definition Tile.h:90
std::variant< CesiumGeometry::BoundingSphere, CesiumGeometry::OrientedBoundingBox, CesiumGeospatial::BoundingRegion, CesiumGeospatial::BoundingRegionWithLooseFittingHeights, CesiumGeospatial::S2CellBoundingVolume, CesiumGeometry::BoundingCylinderRegion > BoundingVolume
A bounding volume.
TileRefine
Refinement strategies for a Cesium3DTilesSelection::Tile.
Definition TileRefine.h:8
std::variant< std::string, CesiumGeometry::QuadtreeTileID, CesiumGeometry::OctreeTileID, CesiumGeometry::UpsampledQuadtreeNode > TileID
An identifier for a Tile inside the tile hierarchy.
Definition TileID.h:39
Utility classes for Cesium.
STL namespace.
A content tag that indicates a tile has no content.
Definition TileContent.h:44