cesium-native 0.55.0
Loading...
Searching...
No Matches
RasterOverlayTileProvider.h
1#pragma once
2
3#include <CesiumAsync/IAssetAccessor.h>
4#include <CesiumGeospatial/Projection.h>
5#include <CesiumGltfReader/GltfReader.h>
6#include <CesiumRasterOverlays/Library.h>
7#include <CesiumRasterOverlays/RasterOverlayExternals.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 CesiumUtility {
21}
22
23namespace CesiumRasterOverlays {
24
25class RasterOverlay;
29
33struct CESIUMRASTEROVERLAYS_API LoadedRasterOverlayImage {
41
49
54 std::vector<CesiumUtility::Credit> credits{};
55
63
68 bool moreDetailAvailable = false;
69
73 int64_t getSizeBytes() const {
74 int64_t accum = 0;
75 accum += int64_t(sizeof(LoadedRasterOverlayImage));
76 accum += int64_t(this->credits.capacity() * sizeof(CesiumUtility::Credit));
77 if (this->pImage) {
78 accum += this->pImage->getSizeBytes();
79 }
80 return accum;
81 }
82};
83
93
100 std::vector<CesiumUtility::Credit> credits{};
101
107
125 bool allowEmptyImages = false;
126};
127
129
136class CESIUMRASTEROVERLAYS_API RasterOverlayTileProvider
138 RasterOverlayTileProvider> {
139public:
154 const CesiumGeospatial::Projection& projection,
155 const CesiumGeometry::Rectangle& coverageRectangle) noexcept;
156
158 virtual ~RasterOverlayTileProvider() noexcept;
159
166
171
173 const RasterOverlay& getOwner() const noexcept;
174
178 const RasterOverlayExternals& getExternals() const noexcept;
179
183 const std::shared_ptr<CesiumAsync::IAssetAccessor>&
184 getAssetAccessor() const noexcept;
185
189 const std::shared_ptr<CesiumUtility::CreditSystem>&
190 getCreditSystem() const noexcept;
191
195 const CesiumAsync::AsyncSystem& getAsyncSystem() const noexcept;
196
203
208 const std::shared_ptr<spdlog::logger>& getLogger() const noexcept;
209
213 const CesiumGeospatial::Projection& getProjection() const noexcept;
214
219 const CesiumGeometry::Rectangle& getCoverageRectangle() const noexcept;
220
225 const CesiumUtility::CreditSource& getCreditSource() const noexcept;
226
237 std::vector<CesiumUtility::Credit>& getCredits() noexcept;
238
242 const std::vector<CesiumUtility::Credit>& getCredits() const noexcept;
243
251 loadTileImage(const RasterOverlayTile& overlayTile) = 0;
252
263 virtual void
264 addCredits(CesiumUtility::CreditReferencer& creditReferencer) noexcept;
265
266protected:
278 const std::string& url,
279 const std::vector<CesiumAsync::IAssetAccessor::THeader>& headers = {},
280 LoadTileImageFromUrlOptions&& options = {}) const;
281
282private:
283 struct DestructionCompleteDetails {
286 };
287
288 CesiumUtility::IntrusivePointer<RasterOverlay> _pOwner;
289 RasterOverlayExternals _externals;
290 std::vector<CesiumUtility::Credit> _credits;
292 CesiumGeometry::Rectangle _coverageRectangle;
293 std::optional<DestructionCompleteDetails> _destructionCompleteDetails;
294 std::shared_ptr<CesiumUtility::CreditSource> _pCreditSource;
295};
296} // namespace CesiumRasterOverlays
A promise that can be resolved or rejected by an asynchronous task.
Definition Promise.h:19
A value that will be available in the future, as produced by AsyncSystem. Unlike Future,...
An interface between Cesium Native and the application using it, allowing Cesium Native to pass loade...
External interfaces used by a RasterOverlay.
Provides individual tiles for a RasterOverlay on demand.
virtual CesiumAsync::Future< LoadedRasterOverlayImage > loadTileImage(const RasterOverlayTile &overlayTile)=0
Loads the image for a tile.
RasterOverlay & getOwner() noexcept
Returns the RasterOverlay that created this instance.
virtual void addCredits(CesiumUtility::CreditReferencer &creditReferencer) noexcept
Adds this tile provider's credits to a credit referencer.
CesiumAsync::SharedFuture< void > & getAsyncDestructionCompleteEvent()
A future that resolves when this RasterOverlayTileProvider has been destroyed (i.e....
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.
const CesiumGeometry::Rectangle & getCoverageRectangle() const noexcept
Returns the coverage CesiumGeometry::Rectangle of this instance.
const CesiumUtility::CreditSource & getCreditSource() const noexcept
Gets the CesiumUtility::CreditSource that identifies this raster overlay's credits with the CesiumUti...
const std::shared_ptr< spdlog::logger > & getLogger() const noexcept
Gets the logger to which to send messages about the tile provider and tiles.
const RasterOverlayExternals & getExternals() const noexcept
Get the external interfaces for use by the tile provider.
RasterOverlayTileProvider(const CesiumUtility::IntrusivePointer< const RasterOverlay > &pCreator, const CreateRasterOverlayTileProviderParameters &parameters, const CesiumGeospatial::Projection &projection, const CesiumGeometry::Rectangle &coverageRectangle) noexcept
Creates a new instance.
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.
std::vector< CesiumUtility::Credit > & getCredits() noexcept
Gets the collection of credits that should be shown whenever this tile provider is shown.
const std::shared_ptr< CesiumUtility::CreditSystem > & getCreditSystem() const noexcept
Get the credit system that receives credits from this tile provider.
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....
Provides a way to reference a set of credits in a CreditSystem so that the references can easily be r...
A smart pointer that calls addReference and releaseReference on the controlled object.
Classes that support asynchronous operations.
Basic geometry classes for Cesium.
Classes for geospatial computations in Cesium.
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.
ReferenceCounted< T, false > ReferenceCountedNonThreadSafe
A reference-counted base class, meant to be used with IntrusivePointer. The reference count is not th...
STL namespace.
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.
CesiumUtility::ErrorList errorList
Errors and warnings from loading the image.
std::vector< CesiumUtility::Credit > credits
The CesiumUtility::Credit objects that decribe the attributions that are required when using the imag...
CesiumGeometry::Rectangle rectangle
The projected rectangle defining the bounds of this image.
bool moreDetailAvailable
Whether more detailed data, beyond this image, is available within the bounds of this image.
CesiumUtility::IntrusivePointer< CesiumGltf::ImageAsset > pImage
The loaded image.
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:18