-
Notifications
You must be signed in to change notification settings - Fork 411
XboxDDSTextureLoader
DirectXTK |
---|
This is a version of DDSTextureLoader for use by Xbox One XDK developers. This loads pre-tiled texture resources for use with the CreatePlacedResourceX
API available to Xbox One exclusive app developers.
These pre-tiled resources are stored in a variant of the .DDS
file format marked with the "XBOX" FourCC pixel format. To generate these .DDS
files, see the xtexconv.
To load legacy
DDPIXELFORMAT
or FourCC "DX10"DXGI_FORMAT
variant DDS files, use DDSTextureLoader
This function is only usable by Xbox registered developers via the Xbox One XDK / Microsoft GDKX.
#include <XboxDDSTextureLoader.h>
These are in the Xbox namespace rather than DirectX
These are equivalent to the same functions in DDSTextureLoader.
HRESULT CreateDDSTextureFromMemory(
ID3D12Device* d3dDevice,
const uint8_t* ddsData,
size_t ddsDataSize,
ID3D12Resource** texture,
void** grfxMemory,
DDS_ALPHA_MODE* alphaMode = nullptr,
bool forceSRGB = false,
bool* isCubeMap = nullptr);
HRESULT CreateDDSTextureFromFile(
ID3D12Device* d3dDevice,
const wchar_t* szFileName,
ID3D12Resource** texture,
void** grfxMemory,
DDS_ALPHA_MODE* alphaMode = nullptr,
bool forceSRGB = false,
bool* isCubeMap = nullptr);
There is no need to explictly 'upload' the texture data because the texture data is referenced 'in place' via the Unified Memory Architecture (UMA) of Xbox One.
The grfxMemory is returned as a pointer to the video memory which the caller is responsible for releasing with FreeDDSTextureMemory:
void FreeDDSTextureMemory( _In_opt_ void* grfxMemory );
There is also a forceSRGB option for working around gamma issues with content that is in the sRGB or similar color space but is not encoded explicitly as an SRGB format. This will force return format be one of the of DXGI_FORMAT_*_SRGB
formats if it exist. Note that no pixel data conversion takes place.
Auto-gen mipmaps are not supported with these functions.
Be sure to flush the GPU caches before using textures created with these functions
commandList->FlushPipelineX(D3D12XBOX_FLUSH_IDLE, 0, 0);
You may wish to consider more fine-grained flushes if creating textures at run-time. See the documentation for FlushPipelineX
on GDNP.
This function expects the DDS file to contain a pixel format with FourCC "XBOX" which signifies a specific variant of the file.
DWORD dwMagic
DDS_HEADER header
DDS_HEADER_XBOX
{
DXGI_FORMAT dxgiFormat;
uint32_t resourceDimension;
uint32_t miscFlag; // see DDS_RESOURCE_MISC_FLAG
uint32_t arraySize;
uint32_t miscFlags2; // see DDS_MISC_FLAGS2
uint32_t tileMode; // see XG_TILE_MODE
uint32_t baseAlignment;
uint32_t dataSize;
uint32_t xdkVer; // matching _XDK_VER
} headerXbox
// Remainder of file is a tiled texture binary layout suitable
// for use with CreatePlacedResourceX API
Other DDS
loaders and viewers will fail to recognize this pixel format, and other DDS
creation tools do not support creating it. See the xtexconv sample for more information on creating this variant form of DDS files.
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Xbox One
- Xbox Series X|S
- x86
- x64
- ARM64
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v18
- MinGW 12.2, 13.2
- CMake 3.20