Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cache images across glTFs to avoid duplication #1521

Merged
merged 83 commits into from
Nov 1, 2024
Merged
Show file tree
Hide file tree
Changes from 26 commits
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
5c4d926
Tests passing.
azrogers Aug 16, 2024
4a0eb74
Merge with main
azrogers Aug 16, 2024
0748638
Update cesium-native
azrogers Aug 16, 2024
e08581e
Update cesium-native
azrogers Aug 16, 2024
1d85d7b
Start of test for shared images.
azrogers Aug 20, 2024
fcb53ea
Almost fully asynced glTF loading
azrogers Aug 30, 2024
21f034f
Fixed UniquePtr issues
azrogers Sep 3, 2024
164379e
Attempting to resolve invalid pointer issue with material
azrogers Sep 3, 2024
dd14eb1
Fixed crash
azrogers Sep 4, 2024
d9bf27e
Tile debug overlay
azrogers Sep 4, 2024
5c486cf
Working! All tests passing
azrogers Sep 9, 2024
30eeee7
Fix test, update cesium-native
azrogers Sep 11, 2024
03065e9
Merge branch 'main' of github.com:CesiumGS/cesium-unreal into shared-…
azrogers Sep 11, 2024
cc1bd44
Re-add workaround from 396f78f
azrogers Sep 11, 2024
1b7b940
clang-format
azrogers Sep 11, 2024
38042e4
Fix clang-formatting by letting npm dependencies update.
kring Sep 12, 2024
4d68a89
Update cesium-native
azrogers Sep 13, 2024
3784f5d
Merge branch 'shared-assets' of github.com:CesiumGS/cesium-unreal int…
azrogers Sep 13, 2024
1ff1fd3
De-asyncify most of the gltf loading. Still seeing mysterious compila…
azrogers Sep 13, 2024
b0f37ec
Fix lifetime issues
azrogers Sep 18, 2024
6b43702
Log asset stats
azrogers Sep 18, 2024
6fcce71
Fix mipmap generation
azrogers Sep 19, 2024
ac6dbbb
Hopefully fix CI errors
azrogers Sep 19, 2024
1ef546f
Add Map header
azrogers Sep 19, 2024
4da4e83
Add automation test headers
azrogers Sep 19, 2024
0637307
Add WITH_EDITOR block
azrogers Sep 19, 2024
9530e72
Update based on review
azrogers Sep 25, 2024
9e9b409
Merge remote-tracking branch 'origin/main' into shared-assets
kring Sep 25, 2024
eefb113
WIP texture loading reorg.
kring Sep 26, 2024
efe384a
Merge remote-tracking branch 'origin/main' into shared-assets-kring
kring Sep 29, 2024
8b0bcdc
Sort of working again after reorg.
kring Sep 30, 2024
ceca504
Undo accidental rename.
kring Sep 30, 2024
3067284
Use correct sRGB setting when initially creating texture.
kring Sep 30, 2024
aa58bd9
Fix UE 5.3/5.4 compile error.
kring Sep 30, 2024
1246c2d
Fix raster overlays and water mask.
kring Sep 30, 2024
b75d274
GetOrCreate -> getOrCreate.
kring Sep 30, 2024
8141c5c
Fix another UE 5.3/5.4 compile error.
kring Sep 30, 2024
e4734e3
Fix test failures.
kring Sep 30, 2024
1777db0
Formatting.
kring Sep 30, 2024
28a28e0
Merge remote-tracking branch 'origin/main' into shared-assets
kring Sep 30, 2024
93a4265
Merge remote-tracking branch 'origin/shared-assets' into shared-asset…
kring Sep 30, 2024
b03d1f6
SharedImages test working on CI
azrogers Oct 1, 2024
0f341f0
Merge remote-tracking branch 'origin/main' into shared-assets
kring Oct 2, 2024
83a24d1
Merge remote-tracking branch 'origin/shared-assets' into shared-asset…
kring Oct 2, 2024
8020401
Const correctness, doc.
kring Oct 3, 2024
b1b0368
Cleanup, make some useful warnings visible.
kring Oct 3, 2024
d9dffcd
Fix metadata crash caused by failed move from const.
kring Oct 3, 2024
6451ef3
Use ion for shared images test
azrogers Oct 3, 2024
22786f6
Merge branch 'shared-assets-kring' of github.com:CesiumGS/cesium-unre…
azrogers Oct 3, 2024
d3fbccc
AttributeSemantics -> VertexAttributeSemantics
kring Oct 3, 2024
ddff9db
Adapt for ImageCesium only design.
kring Oct 4, 2024
edd8226
More updates for changes in Native.
kring Oct 4, 2024
0a14600
Update cesium-native to shared-assets branch
azrogers Oct 4, 2024
90ea7e4
Integrate deletion rework
azrogers Oct 4, 2024
9a63282
Add skeleton of a Snowdon test, properly report texture stats
azrogers Oct 8, 2024
fc60c1e
Update cesium-native.
kring Oct 10, 2024
1b59597
Rename ImageCesium
azrogers Oct 10, 2024
c042a39
Merge pull request #1531 from CesiumGS/shared-assets-tweaks
azrogers Oct 10, 2024
62bdd81
Merge pull request #1527 from CesiumGS/shared-assets-kring
azrogers Oct 10, 2024
9a675e2
Format, update cesium-native
azrogers Oct 10, 2024
85d6b39
Clean up CesiumTextureUtility
azrogers Oct 10, 2024
d8f27c6
Use shared-assets-wip branch of cesium-native.
kring Oct 28, 2024
4a96eea
Update cesium-native.
kring Oct 28, 2024
2d1ccd8
Update cesium-native.
kring Oct 29, 2024
d7cda44
Merge remote-tracking branch 'origin/main' into shared-assets
kring Oct 29, 2024
71b885b
Merge remote-tracking branch 'origin/shared-assets' into shared-asset…
kring Oct 29, 2024
463e027
Update cesium-native.
kring Oct 29, 2024
9bc94d3
Merge pull request #1536 from CesiumGS/shared-assets-wip
azrogers Oct 29, 2024
6b7f4af
Return to shared-assets branch of cesium-native
azrogers Oct 29, 2024
adec72e
pCesium -> pAsset.
kring Oct 29, 2024
f16dffb
Fix test failure.
kring Oct 30, 2024
c45f82f
Formatting.
kring Oct 30, 2024
04bac36
Don't use deprecated methods.
kring Oct 30, 2024
71d0297
Fix compiler error on macOS, hopefully.
kring Oct 30, 2024
d61b912
Remove unused code.
kring Oct 30, 2024
2ec8b60
LogAssetStats -> LogSharedAssetStats
kring Oct 30, 2024
da6f64c
Remove CesiumGltf usings to try to fix OSX build
azrogers Oct 30, 2024
935e0db
Fix memory leak and non-async texture creation.
kring Oct 31, 2024
26eff5e
More namespacing.
kring Oct 31, 2024
783bb4e
Fix tests
azrogers Oct 31, 2024
358d779
Update CHANGES, remove Snowdon test
azrogers Oct 31, 2024
a6d7b3b
Remove Class.h include
azrogers Oct 31, 2024
28333a1
Eliminate another round of `using namespace CesiumGltf`.
kring Oct 31, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
91 changes: 70 additions & 21 deletions Source/CesiumRuntime/Private/Cesium3DTileset.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
#include "CesiumGeospatial/GlobeTransforms.h"
#include "CesiumGltf/ImageCesium.h"
#include "CesiumGltf/Ktx2TranscodeTargets.h"
#include "CesiumGltf/SharedAssetDepot.h"
#include "CesiumGltfComponent.h"
#include "CesiumGltfPointsSceneProxyUpdater.h"
#include "CesiumGltfPrimitiveComponent.h"
Expand Down Expand Up @@ -703,42 +704,49 @@ class UnrealResourcePreparer
Cesium3DTilesSelection::TileLoadResult&& tileLoadResult,
const glm::dmat4& transform,
const std::any& rendererOptions) override {
CesiumGltf::Model* pModel =
std::get_if<CesiumGltf::Model>(&tileLoadResult.contentKind);
if (!pModel)
TUniquePtr<CreateGltfOptions::CreateModelOptions> options =
azrogers marked this conversation as resolved.
Show resolved Hide resolved
MakeUnique<CreateGltfOptions::CreateModelOptions>(
std::move(tileLoadResult));
if (!options->pModel) {
return asyncSystem.createResolvedFuture(
Cesium3DTilesSelection::TileLoadResultAndRenderResources{
std::move(tileLoadResult),
std::move(options->tileLoadResult),
nullptr});
}

CreateGltfOptions::CreateModelOptions options;
options.pModel = pModel;
options.alwaysIncludeTangents = this->_pActor->GetAlwaysIncludeTangents();
options.createPhysicsMeshes = this->_pActor->GetCreatePhysicsMeshes();
options->alwaysIncludeTangents = this->_pActor->GetAlwaysIncludeTangents();
options->createPhysicsMeshes = this->_pActor->GetCreatePhysicsMeshes();

options.ignoreKhrMaterialsUnlit =
options->ignoreKhrMaterialsUnlit =
this->_pActor->GetIgnoreKhrMaterialsUnlit();

if (this->_pActor->_featuresMetadataDescription) {
options.pFeaturesMetadataDescription =
options->pFeaturesMetadataDescription =
&(*this->_pActor->_featuresMetadataDescription);
} else if (this->_pActor->_metadataDescription_DEPRECATED) {
options.pEncodedMetadataDescription_DEPRECATED =
options->pEncodedMetadataDescription_DEPRECATED =
&(*this->_pActor->_metadataDescription_DEPRECATED);
}

const CesiumGeospatial::Ellipsoid& ellipsoid = tileLoadResult.ellipsoid;

TUniquePtr<UCesiumGltfComponent::HalfConstructed> pHalf =
UCesiumGltfComponent::CreateOffGameThread(
CesiumAsync::Future<
TUniquePtr<UCesiumGltfComponent::CreateOffGameThreadResult>>
pHalfFuture = UCesiumGltfComponent::CreateOffGameThread(
asyncSystem,
transform,
options,
std::move(options),
ellipsoid);

return asyncSystem.createResolvedFuture(
Cesium3DTilesSelection::TileLoadResultAndRenderResources{
std::move(tileLoadResult),
pHalf.Release()});
return MoveTemp(pHalfFuture)
.thenImmediately(
[](TUniquePtr<UCesiumGltfComponent::CreateOffGameThreadResult>&&
pResult)
-> Cesium3DTilesSelection::TileLoadResultAndRenderResources {
return Cesium3DTilesSelection::TileLoadResultAndRenderResources{
std::move(pResult->TileLoadResult),
pResult->HalfConstructed.Release()};
});
}

virtual void* prepareInMainThread(
Expand Down Expand Up @@ -807,17 +815,18 @@ class UnrealResourcePreparer
}
}

CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> imageAsset(image);
azrogers marked this conversation as resolved.
Show resolved Hide resolved

auto texture = CesiumTextureUtility::loadTextureAnyThreadPart(
image,
imageAsset,
TextureAddress::TA_Clamp,
TextureAddress::TA_Clamp,
pOptions->filter,
pOptions->useMipmaps,
pOptions->group,
// TODO: sRGB should probably be configurable on the raster overlay.
true,
std::nullopt,
nullptr);
std::nullopt);
return texture.Release();
}

Expand Down Expand Up @@ -1863,6 +1872,46 @@ void ACesium3DTileset::updateLastViewUpdateResultState(
const Cesium3DTilesSelection::ViewUpdateResult& result) {
TRACE_CPUPROFILER_EVENT_SCOPE(Cesium::updateLastViewUpdateResultState)

if (this->DrawTileInfo) {
azrogers marked this conversation as resolved.
Show resolved Hide resolved
const UWorld* World = GetWorld();
check(World);

const TSoftObjectPtr<ACesiumGeoreference> Georeference = GetGeoreference();
check(Georeference);
azrogers marked this conversation as resolved.
Show resolved Hide resolved

for (auto& tile : result.tilesToRenderThisFrame) {
azrogers marked this conversation as resolved.
Show resolved Hide resolved

CesiumGeometry::OrientedBoundingBox obb =
Cesium3DTilesSelection::getOrientedBoundingBoxFromBoundingVolume(
tile->getBoundingVolume(),
Georeference->GetEllipsoid()->GetNativeEllipsoid());

FVector unrealCenter =
Georeference->TransformEarthCenteredEarthFixedPositionToUnreal(
VecMath::createVector(obb.getCenter()));

FString text = FString::Printf(
TEXT("ID %s (%p)"),
Cesium3DTilesSelection::TileIdUtilities::createTileIdString(
tile->getTileID())
.c_str(),
azrogers marked this conversation as resolved.
Show resolved Hide resolved
tile);

DrawDebugString(World, unrealCenter, text, nullptr, FColor::Red, 0, true);
}
}

if (this->LogAssetStats && this->_pTileset) {
const CesiumGltf::SingleAssetDepot<CesiumGltf::ImageCesium>* imageDepot =
this->_pTileset->getSharedAssetDepot().getImageDepot();
UE_LOG(
azrogers marked this conversation as resolved.
Show resolved Hide resolved
LogCesium,
Display,
TEXT("Images depot: %d distinct assets, %d total usages"),
imageDepot->getDistinctCount(),
imageDepot->getUsageCount());
}

if (!this->LogSelectionStats) {
return;
}
Expand Down
29 changes: 14 additions & 15 deletions Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,8 @@ std::optional<EncodedFeatureIdSet> encodeFeatureIdTexture(
}

// Copy the image, so that we can keep a copy of it in the glTF.
CesiumGltf::ImageCesium imageCopy(*pFeatureIdImage);
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> imageCopy =
CesiumGltf::SharedAsset(CesiumGltf::ImageCesium(*pFeatureIdImage));
encodedFeatureIdTexture.pTexture =
MakeShared<LoadedTextureResult>(std::move(*loadTextureAnyThreadPart(
imageCopy,
Expand All @@ -152,8 +153,7 @@ std::optional<EncodedFeatureIdSet> encodeFeatureIdTexture(
TEXTUREGROUP_8BitData,
false,
// TODO: currently this is always the case, but doesn't have to be
EPixelFormat::PF_R8G8B8A8_UINT,
nullptr)));
EPixelFormat::PF_R8G8B8A8_UINT)));
featureIdTextureMap.Emplace(
pFeatureIdImage,
encodedFeatureIdTexture.pTexture);
Expand Down Expand Up @@ -544,11 +544,11 @@ EncodedPropertyTable encodePropertyTableAnyThreadPart(
? floorSqrtFeatureCount
: (floorSqrtFeatureCount + 1);

CesiumGltf::ImageCesium image;
image.width = image.height = textureDimension;
image.bytesPerChannel = encodedFormat.bytesPerChannel;
image.channels = encodedFormat.channels;
image.pixelData.resize(
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> image;
image->width = image->height = textureDimension;
image->bytesPerChannel = encodedFormat.bytesPerChannel;
image->channels = encodedFormat.channels;
image->pixelData.resize(
textureDimension * textureDimension * encodedFormat.bytesPerChannel *
encodedFormat.channels);

Expand All @@ -557,13 +557,13 @@ EncodedPropertyTable encodePropertyTableAnyThreadPart(
CesiumEncodedMetadataParseColorFromString::encode(
*pDescription,
property,
gsl::span(image.pixelData),
gsl::span(image->pixelData),
encodedFormat.bytesPerChannel * encodedFormat.channels);
} else /* info.Conversion == ECesiumEncodedMetadataConversion::Coerce */ {
CesiumEncodedMetadataCoerce::encode(
*pDescription,
property,
gsl::span(image.pixelData),
gsl::span(image->pixelData),
encodedFormat.bytesPerChannel * encodedFormat.channels);
}

Expand All @@ -575,8 +575,7 @@ EncodedPropertyTable encodePropertyTableAnyThreadPart(
false,
TEXTUREGROUP_8BitData,
false,
encodedFormat.format,
nullptr);
encodedFormat.format);
}

if (pDescription->PropertyDetails.bHasOffset) {
Expand Down Expand Up @@ -692,7 +691,8 @@ EncodedPropertyTexture encodePropertyTextureAnyThreadPart(
}

// Copy the image, so that we can keep a copy of it in the glTF.
CesiumGltf::ImageCesium imageCopy(*pImage);
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> imageCopy =
CesiumGltf::SharedAsset(CesiumGltf::ImageCesium(*pImage));
encodedProperty.pTexture =
MakeShared<LoadedTextureResult>(std::move(*loadTextureAnyThreadPart(
imageCopy,
Expand All @@ -705,8 +705,7 @@ EncodedPropertyTexture encodePropertyTextureAnyThreadPart(
false,
// This assumes that the texture's image only contains one byte
// per channel.
EPixelFormat::PF_R8G8B8A8_UINT,
nullptr)));
EPixelFormat::PF_R8G8B8A8_UINT)));
propertyTexturePropertyMap.Emplace(pImage, encodedProperty.pTexture);
}
};
Expand Down
39 changes: 20 additions & 19 deletions Source/CesiumRuntime/Private/CesiumEncodedMetadataUtility.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -205,18 +205,19 @@ EncodedMetadataFeatureTable encodeMetadataFeatureTableAnyThreadPart(
? floorSqrtFeatureCount
: (floorSqrtFeatureCount + 1);

CesiumGltf::ImageCesium image;
image.bytesPerChannel = encodedFormat.bytesPerChannel;
image.channels = encodedFormat.channels;
image.compressedPixelFormat = CesiumGltf::GpuCompressedPixelFormat::NONE;
image.height = image.width = ceilSqrtFeatureCount;
image.pixelData.resize(size_t(
image.width * image.height * image.channels * image.bytesPerChannel));
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> image;
image->bytesPerChannel = encodedFormat.bytesPerChannel;
image->channels = encodedFormat.channels;
image->compressedPixelFormat = CesiumGltf::GpuCompressedPixelFormat::NONE;
image->height = image->width = ceilSqrtFeatureCount;
image->pixelData.resize(size_t(
image->width * image->height * image->channels *
image->bytesPerChannel));

if (isArray) {
switch (gpuType) {
case ECesiumMetadataPackedGpuType_DEPRECATED::Uint8_DEPRECATED: {
uint8* pWritePos = reinterpret_cast<uint8*>(image.pixelData.data());
uint8* pWritePos = reinterpret_cast<uint8*>(image->pixelData.data());
int64_t pixelSize =
encodedFormat.channels * encodedFormat.bytesPerChannel;
for (int64 i = 0; i < featureCount; ++i) {
Expand All @@ -232,7 +233,7 @@ EncodedMetadataFeatureTable encodeMetadataFeatureTableAnyThreadPart(
}
} break;
case ECesiumMetadataPackedGpuType_DEPRECATED::Float_DEPRECATED: {
uint8* pWritePos = reinterpret_cast<uint8*>(image.pixelData.data());
uint8* pWritePos = reinterpret_cast<uint8*>(image->pixelData.data());
int64_t pixelSize =
encodedFormat.channels * encodedFormat.bytesPerChannel;
for (int64 i = 0; i < featureCount; ++i) {
Expand All @@ -256,7 +257,7 @@ EncodedMetadataFeatureTable encodeMetadataFeatureTableAnyThreadPart(
} else {
switch (gpuType) {
case ECesiumMetadataPackedGpuType_DEPRECATED::Uint8_DEPRECATED: {
uint8* pWritePos = reinterpret_cast<uint8*>(image.pixelData.data());
uint8* pWritePos = reinterpret_cast<uint8*>(image->pixelData.data());
for (int64 i = 0; i < featureCount; ++i) {
*pWritePos = UCesiumPropertyTablePropertyBlueprintLibrary::GetByte(
property,
Expand All @@ -265,7 +266,7 @@ EncodedMetadataFeatureTable encodeMetadataFeatureTableAnyThreadPart(
}
} break;
case ECesiumMetadataPackedGpuType_DEPRECATED::Float_DEPRECATED: {
float* pWritePosF = reinterpret_cast<float*>(image.pixelData.data());
float* pWritePosF = reinterpret_cast<float*>(image->pixelData.data());
for (int64 i = 0; i < featureCount; ++i) {
*pWritePosF = UCesiumPropertyTablePropertyBlueprintLibrary::GetFloat(
property,
Expand All @@ -284,8 +285,7 @@ EncodedMetadataFeatureTable encodeMetadataFeatureTableAnyThreadPart(
false,
TEXTUREGROUP_8BitData,
false,
encodedFormat.format,
nullptr);
encodedFormat.format);
}

return encodedFeatureTable;
Expand Down Expand Up @@ -410,7 +410,8 @@ EncodedFeatureTexture encodeFeatureTextureAnyThreadPart(
if (pMappedUnrealImageIt) {
encodedFeatureTextureProperty.pTexture = pMappedUnrealImageIt->Pin();
} else {
CesiumGltf::ImageCesium imageCopy(*pImage);
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> imageCopy =
CesiumGltf::SharedAsset(CesiumGltf::ImageCesium(*pImage));
encodedFeatureTextureProperty.pTexture =
MakeShared<LoadedTextureResult>(std::move(*loadTextureAnyThreadPart(
imageCopy,
Expand All @@ -424,8 +425,7 @@ EncodedFeatureTexture encodeFeatureTextureAnyThreadPart(
// R8G8B8A8 form, but this does not necessarily need to be the
// case in the future.
isNormalized ? EPixelFormat::PF_R8G8B8A8
: EPixelFormat::PF_R8G8B8A8_UINT,
nullptr)));
: EPixelFormat::PF_R8G8B8A8_UINT)));
featureTexturePropertyMap.Emplace(
pImage,
encodedFeatureTextureProperty.pTexture);
Expand Down Expand Up @@ -516,7 +516,9 @@ EncodedMetadataPrimitive encodeMetadataPrimitiveAnyThreadPart(
if (pMappedUnrealImageIt) {
encodedFeatureIdTexture.pTexture = pMappedUnrealImageIt->Pin();
} else {
CesiumGltf::ImageCesium imageCopy(*pFeatureIdImage);
CesiumGltf::SharedAsset<CesiumGltf::ImageCesium> imageCopy =
CesiumGltf::SharedAsset(
CesiumGltf::ImageCesium(*pFeatureIdImage));
encodedFeatureIdTexture.pTexture = MakeShared<LoadedTextureResult>(
std::move(*loadTextureAnyThreadPart(
imageCopy,
Expand All @@ -528,8 +530,7 @@ EncodedMetadataPrimitive encodeMetadataPrimitiveAnyThreadPart(
false,
// TODO: currently this is always the case, but doesn't have
// to be
EPixelFormat::PF_R8G8B8A8_UINT,
nullptr)));
EPixelFormat::PF_R8G8B8A8_UINT)));
featureIdTextureMap.Emplace(
pFeatureIdImage,
encodedFeatureIdTexture.pTexture);
Expand Down
Loading
Loading