cesium-native 0.43.0
Loading...
Searching...
No Matches
RasterOverlayTileProvider.h
1#pragma once
2
3#include "Library.h"
4
5#include <CesiumAsync/IAssetAccessor.h>
6#include <CesiumGeospatial/Projection.h>
7#include <CesiumGltfReader/GltfReader.h>
8#include <CesiumUtility/Assert.h>
9#include <CesiumUtility/CreditSystem.h>
10#include <CesiumUtility/ErrorList.h>
11#include <CesiumUtility/IntrusivePointer.h>
12#include <CesiumUtility/ReferenceCounted.h>
13#include <CesiumUtility/Tracing.h>
14
15#include <spdlog/fwd.h>
16
17#include <optional>
18
19namespace CesiumRasterOverlays {
20
21class RasterOverlay;
22class RasterOverlayTile;
23class IPrepareRasterOverlayRendererResources;
24
28struct CESIUMRASTEROVERLAYS_API LoadedRasterOverlayImage {
36
44
49 std::vector<CesiumUtility::Credit> credits{};
50
58
63 bool moreDetailAvailable = false;
64
68 int64_t getSizeBytes() const {
69 int64_t accum = 0;
70 accum += int64_t(sizeof(LoadedRasterOverlayImage));
71 accum += int64_t(this->credits.capacity() * sizeof(CesiumUtility::Credit));
72 if (this->pImage) {
73 accum += this->pImage->getSizeBytes();
74 }
75 return accum;
76 }
77};
78
88
95 std::vector<CesiumUtility::Credit> credits{};
96
102
120 bool allowEmptyImages = false;
121};
122
124
139
146class CESIUMRASTEROVERLAYS_API RasterOverlayTileProvider
147 : public CesiumUtility::ReferenceCountedNonThreadSafe<
149public:
163 const CesiumAsync::AsyncSystem& asyncSystem,
164 const std::shared_ptr<CesiumAsync::IAssetAccessor>& pAssetAccessor,
165 const CesiumGeospatial::Ellipsoid& ellipsoid
166 CESIUM_DEFAULT_ELLIPSOID) noexcept;
167
186 const CesiumAsync::AsyncSystem& asyncSystem,
187 const std::shared_ptr<CesiumAsync::IAssetAccessor>& pAssetAccessor,
188 std::optional<CesiumUtility::Credit> credit,
189 const std::shared_ptr<IPrepareRasterOverlayRendererResources>&
190 pPrepareRendererResources,
191 const std::shared_ptr<spdlog::logger>& pLogger,
192 const CesiumGeospatial::Projection& projection,
193 const CesiumGeometry::Rectangle& coverageRectangle) noexcept;
194
196 virtual ~RasterOverlayTileProvider() noexcept;
197
217 bool isPlaceholder() const noexcept { return this->_pPlaceholder != nullptr; }
218
222 RasterOverlay& getOwner() noexcept { return *this->_pOwner; }
223
225 const RasterOverlay& getOwner() const noexcept { return *this->_pOwner; }
226
230 const std::shared_ptr<CesiumAsync::IAssetAccessor>&
231 getAssetAccessor() const noexcept {
232 return this->_pAssetAccessor;
233 }
234
238 const CesiumAsync::AsyncSystem& getAsyncSystem() const noexcept {
239 return this->_asyncSystem;
240 }
241
246 const std::shared_ptr<IPrepareRasterOverlayRendererResources>&
248 return this->_pPrepareRendererResources;
249 }
250
255 const std::shared_ptr<spdlog::logger>& getLogger() const noexcept {
256 return this->_pLogger;
257 }
258
263 return this->_projection;
264 }
265
271 return this->_coverageRectangle;
272 }
273
294 const CesiumGeometry::Rectangle& rectangle,
295 const glm::dvec2& targetScreenPixels);
296
300 int64_t getTileDataBytes() const noexcept { return this->_tileDataBytes; }
301
305 uint32_t getNumberOfTilesLoading() const noexcept {
306 CESIUM_ASSERT(this->_totalTilesCurrentlyLoading > -1);
307 return static_cast<uint32_t>(this->_totalTilesCurrentlyLoading);
308 }
309
321
325 const std::optional<CesiumUtility::Credit>& getCredit() const noexcept {
326 return _credit;
327 }
328
346
369
370protected:
379
391 const std::string& url,
392 const std::vector<CesiumAsync::IAssetAccessor::THeader>& headers = {},
393 LoadTileImageFromUrlOptions&& options = {}) const;
394
395private:
397 doLoad(RasterOverlayTile& tile, bool isThrottledLoad);
398
406 void beginTileLoad(bool isThrottledLoad) noexcept;
407
416 void finalizeTileLoad(bool isThrottledLoad) noexcept;
417
418private:
420 CesiumAsync::AsyncSystem _asyncSystem;
421 std::shared_ptr<CesiumAsync::IAssetAccessor> _pAssetAccessor;
422 std::optional<CesiumUtility::Credit> _credit;
423 std::shared_ptr<IPrepareRasterOverlayRendererResources>
424 _pPrepareRendererResources;
425 std::shared_ptr<spdlog::logger> _pLogger;
427 CesiumGeometry::Rectangle _coverageRectangle;
429 int64_t _tileDataBytes;
430 int32_t _totalTilesCurrentlyLoading;
431 int32_t _throttledTilesCurrentlyLoading;
432 CESIUM_TRACE_DECLARE_TRACK_SET(
433 _loadingSlots,
434 "Raster Overlay Tile Loading Slot")
435};
436} // namespace CesiumRasterOverlays
A system for managing asynchronous requests and tasks.
Definition AsyncSystem.h:36
A value that will be available in the future, as produced by AsyncSystem.
Definition Promise.h:11
A quadratic surface defined in Cartesian coordinates.
Definition Ellipsoid.h:38
Provides individual tiles for a RasterOverlay on demand.
void removeTile(RasterOverlayTile *pTile) noexcept
Removes a no-longer-referenced tile from this provider's cache and deletes it.
const std::optional< CesiumUtility::Credit > & getCredit() const noexcept
Get the per-TileProvider CesiumUtility::Credit if one exists.
CesiumUtility::IntrusivePointer< RasterOverlayTile > getTile(const CesiumGeometry::Rectangle &rectangle, const glm::dvec2 &targetScreenPixels)
Returns a new RasterOverlayTile with the given specifications.
bool loadTileThrottled(RasterOverlayTile &tile)
Loads a tile, unless there are too many tile loads already in progress.
const RasterOverlay & getOwner() const noexcept
Returns the RasterOverlay that created this instance.
RasterOverlay & getOwner() noexcept
Returns the RasterOverlay that created this instance.
CesiumAsync::Future< TileProviderAndTile > loadTile(RasterOverlayTile &tile)
Loads a tile immediately, without throttling requests.
virtual CesiumAsync::Future< LoadedRasterOverlayImage > loadTileImage(RasterOverlayTile &overlayTile)=0
Loads the image for a tile.
const std::shared_ptr< IPrepareRasterOverlayRendererResources > & getPrepareRendererResources() const noexcept
Gets the interface used to prepare raster overlay images for rendering.
virtual ~RasterOverlayTileProvider() noexcept
Default destructor.
CesiumAsync::Future< LoadedRasterOverlayImage > loadTileImageFromUrl(const std::string &url, const std::vector< CesiumAsync::IAssetAccessor::THeader > &headers={}, LoadTileImageFromUrlOptions &&options={}) const
Loads an image from a URL and optionally some request headers.
uint32_t getNumberOfTilesLoading() const noexcept
Returns the number of tiles that are currently loading.
const CesiumGeometry::Rectangle & getCoverageRectangle() const noexcept
Returns the coverage CesiumGeometry::Rectangle of this instance.
const std::shared_ptr< spdlog::logger > & getLogger() const noexcept
Gets the logger to which to send messages about the tile provider and tiles.
const CesiumGeospatial::Projection & getProjection() const noexcept
Returns the CesiumGeospatial::Projection of this instance.
const CesiumAsync::AsyncSystem & getAsyncSystem() const noexcept
Gets the async system used to do work in threads.
int64_t getTileDataBytes() const noexcept
Gets the number of bytes of tile data that are currently loaded.
RasterOverlayTileProvider(const CesiumUtility::IntrusivePointer< const RasterOverlay > &pOwner, const CesiumAsync::AsyncSystem &asyncSystem, const std::shared_ptr< CesiumAsync::IAssetAccessor > &pAssetAccessor, std::optional< CesiumUtility::Credit > credit, const std::shared_ptr< IPrepareRasterOverlayRendererResources > &pPrepareRendererResources, const std::shared_ptr< spdlog::logger > &pLogger, const CesiumGeospatial::Projection &projection, const CesiumGeometry::Rectangle &coverageRectangle) noexcept
Creates a new instance.
RasterOverlayTileProvider(const CesiumUtility::IntrusivePointer< const RasterOverlay > &pOwner, const CesiumAsync::AsyncSystem &asyncSystem, const std::shared_ptr< CesiumAsync::IAssetAccessor > &pAssetAccessor, const CesiumGeospatial::Ellipsoid &ellipsoid=CesiumGeospatial::Ellipsoid::WGS84) noexcept
const std::shared_ptr< CesiumAsync::IAssetAccessor > & getAssetAccessor() const noexcept
Get the system to use for asychronous requests and threaded work.
Raster image data for a tile in a quadtree.
The base class for a rasterized image that can be draped over a Cesium3DTilesSelection::Tileset....
A smart pointer that calls addReference and releaseReference on the controlled object.
std::variant< GeographicProjection, WebMercatorProjection > Projection
A projection.
Definition Projection.h:25
Classes for raster overlays, which allow draping massive 2D textures over a model.
Utility classes for Cesium.
A 2D rectangle.
Definition Rectangle.h:14
Options for RasterOverlayTileProvider::loadTileImageFromUrl.
CesiumGeometry::Rectangle rectangle
The rectangle definining the bounds of the image being loaded, expressed in the RasterOverlayTileProv...
std::vector< CesiumUtility::Credit > credits
The credits to display with this tile.
bool moreDetailAvailable
Whether more detailed data, beyond this image, is available within the bounds of this image.
bool allowEmptyImages
Whether empty (zero length) images are accepted as a valid response.
Summarizes the result of loading an image of a RasterOverlay.
int64_t getSizeBytes() const
Returns the size of this LoadedRasterOverlayImage in bytes.
Holds a tile and its corresponding tile provider. Used as the return value of RasterOverlayTileProvid...
CesiumUtility::IntrusivePointer< RasterOverlayTile > pTile
A CesiumUtility::IntrusivePointer to the RasterOverlayTile used for this tile.
CesiumUtility::IntrusivePointer< RasterOverlayTileProvider > pTileProvider
A CesiumUtility::IntrusivePointer to the RasterOverlayTileProvider used for this tile.
Represents an HTML string that should be shown on screen to attribute third parties for used data,...
The container to store the error and warning list when loading a tile or glTF content.
Definition ErrorList.h:17