From 2f84f54508065952bbfbc9ce059a85e28be57775 Mon Sep 17 00:00:00 2001 From: vkaytsanov <49615597+vkaytsanov@users.noreply.github.com> Date: Tue, 6 Aug 2024 03:43:03 +0300 Subject: [PATCH] Add cubemap support for OpenEXR (#483) --- Auxiliary/DirectXTexEXR.cpp | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/Auxiliary/DirectXTexEXR.cpp b/Auxiliary/DirectXTexEXR.cpp index e0a5a8f3..ee3b5a54 100644 --- a/Auxiliary/DirectXTexEXR.cpp +++ b/Auxiliary/DirectXTexEXR.cpp @@ -371,23 +371,35 @@ HRESULT DirectX::LoadFromEXRFile(const wchar_t* szFile, TexMetadata* metadata, S auto const dw = file.dataWindow(); - const int width = dw.max.x - dw.min.x + 1; - const int height = dw.max.y - dw.min.y + 1; + int width = dw.max.x - dw.min.x + 1; + int height = dw.max.y - dw.min.y + 1; + size_t arraySize = 1; if (width < 1 || height < 1) return E_FAIL; + if (file.header().find("envmap") != file.header().end()) + { + if (width == height / 6) + { + height = width; + } + arraySize = 6; + } + if (metadata) { metadata->width = static_cast(width); metadata->height = static_cast(height); - metadata->depth = metadata->arraySize = metadata->mipLevels = 1; + metadata->depth = metadata->mipLevels = 1; + metadata->arraySize = arraySize; metadata->format = DXGI_FORMAT_R16G16B16A16_FLOAT; metadata->dimension = TEX_DIMENSION_TEXTURE2D; } hr = image.Initialize2D(DXGI_FORMAT_R16G16B16A16_FLOAT, - static_cast(width), static_cast(height), 1u, 1u); + static_cast(width), static_cast(height), arraySize, 1u); + if (FAILED(hr)) return hr;