nvidia-texture-tools/extern/pvrtextool/Include/PVRTextureHeader.h
2017-02-08 11:42:25 -08:00

604 lines
29 KiB
C++

/******************************************************************************
@File PVRTextureHeader.h
@Title
@Version
@Copyright Copyright (c) Imagination Technologies Limited. All Rights Reserved. Strictly Confidential.
@Platform
@Description
******************************************************************************/
#ifndef _PVRTEXTURE_HEADER_H
#define _PVRTEXTURE_HEADER_H
#include "PVRTextureDefines.h"
#include "PVRTextureFormat.h"
#include "PVRTMap.h"
#include "PVRTString.h"
namespace pvrtexture
{
//Wrapper class for PVRTextureHeaderV3, adds 'smart' accessor functions.
class PVR_DLL CPVRTextureHeader
{
protected:
PVRTextureHeaderV3 m_sHeader; //Texture header as laid out in a file.
mutable CPVRTMap<uint32, CPVRTMap<uint32,MetaDataBlock> > m_MetaData; //Map of all the meta data stored for a texture.
public:
/*******************************************************************************
* Construction methods for a texture header.
*******************************************************************************/
/*!***********************************************************************
@Function CPVRTextureHeader
@Return CPVRTextureHeader A new texture header.
@Description Default constructor for a CPVRTextureHeader. Returns an empty header.
*************************************************************************/
CPVRTextureHeader();
/*!***********************************************************************
@Function CPVRTextureHeader
@Input fileHeader
@Input metaDataCount
@Input metaData
@Return CPVRTextureHeader A new texture header.
@Description Creates a new texture header from a PVRTextureHeaderV3,
and appends Meta data if any is supplied.
*************************************************************************/
CPVRTextureHeader( PVRTextureHeaderV3 fileHeader,
uint32 metaDataCount=0,
MetaDataBlock* metaData=NULL);
/*!***********************************************************************
@Function CPVRTextureHeader
@Input u64PixelFormat
@Input u32Height
@Input u32Width
@Input u32Depth
@Input u32NumMipMaps
@Input u32NumArrayMembers
@Input u32NumFaces
@Input eColourSpace
@Input eChannelType
@Input bPreMultiplied
@Return CPVRTextureHeader A new texture header.
@Description Creates a new texture header based on individual header
variables.
*************************************************************************/
CPVRTextureHeader( uint64 u64PixelFormat,
uint32 u32Height=1,
uint32 u32Width=1,
uint32 u32Depth=1,
uint32 u32NumMipMaps=1,
uint32 u32NumArrayMembers=1,
uint32 u32NumFaces=1,
EPVRTColourSpace eColourSpace=ePVRTCSpacelRGB,
EPVRTVariableType eChannelType=ePVRTVarTypeUnsignedByteNorm,
bool bPreMultiplied=false);
/*!***********************************************************************
@Function operator=
@Input rhs
@Return CPVRTextureHeader& This header.
@Description Will copy the contents and information of another header into this one.
*************************************************************************/
CPVRTextureHeader& operator=(const CPVRTextureHeader& rhs);
/*******************************************************************************
* Accessor Methods for a texture's properties - getters.
*******************************************************************************/
/*!***********************************************************************
@Function getFileHeader
@Return PVRTextureHeaderV3 The file header.
@Description Gets the file header structure.
*************************************************************************/
const PVRTextureHeaderV3 getFileHeader() const;
/*!***********************************************************************
@Function getPixelType
@Return PixelType 64-bit pixel type ID.
@Description Gets the 64-bit pixel type ID of the texture.
*************************************************************************/
const PixelType getPixelType() const;
/*!***********************************************************************
@Function getBitsPerPixel
@Return uint32 Number of bits per pixel
@Description Gets the bits per pixel of the texture format.
*************************************************************************/
const uint32 getBitsPerPixel() const;
/*!***********************************************************************
@Function getColourSpace
@Return EPVRTColourSpace enum representing colour space.
@Description Returns the colour space of the texture.
*************************************************************************/
const EPVRTColourSpace getColourSpace() const;
/*!***********************************************************************
@Function getChannelType
@Return EPVRTVariableType enum representing the type of the texture.
@Description Returns the variable type that the texture's data is stored in.
*************************************************************************/
const EPVRTVariableType getChannelType() const;
/*!***********************************************************************
@Function getWidth
@Input uiMipLevel MIP level that user is interested in.
@Return uint32 Width of the specified MIP-Map level.
@Description Gets the width of the user specified MIP-Map
level for the texture
*************************************************************************/
const uint32 getWidth(uint32 uiMipLevel=PVRTEX_TOPMIPLEVEL) const;
/*!***********************************************************************
@Function getHeight
@Input uiMipLevel MIP level that user is interested in.
@Return uint32 Height of the specified MIP-Map level.
@Description Gets the height of the user specified MIP-Map
level for the texture
*************************************************************************/
const uint32 getHeight(uint32 uiMipLevel=PVRTEX_TOPMIPLEVEL) const;
/*!***********************************************************************
@Function getDepth
@Input uiMipLevel MIP level that user is interested in.
@Return Depth of the specified MIP-Map level.
@Description Gets the depth of the user specified MIP-Map
level for the texture
*************************************************************************/
const uint32 getDepth(uint32 uiMipLevel=PVRTEX_TOPMIPLEVEL) const;
/*!***********************************************************************
@Function getTextureSize
@Input iMipLevel Specifies a MIP level to check,
'PVRTEX_ALLMIPLEVELS' can be passed to get
the size of all MIP levels.
@Input bAllSurfaces Size of all surfaces is calculated if true,
only a single surface if false.
@Input bAllFaces Size of all faces is calculated if true,
only a single face if false.
@Return uint32 Size in PIXELS of the specified texture area.
@Description Gets the size in PIXELS of the texture, given various input
parameters. User can retrieve the total size of either all
surfaces or a single surface, all faces or a single face and
all MIP-Maps or a single specified MIP level. All of these
*************************************************************************/
const uint32 getTextureSize(int32 iMipLevel=PVRTEX_ALLMIPLEVELS, bool bAllSurfaces = true, bool bAllFaces = true) const;
/*!***********************************************************************
@Function getDataSize
@Input iMipLevel Specifies a mip level to check,
'PVRTEX_ALLMIPLEVELS' can be passed to get
the size of all MIP levels.
@Input bAllSurfaces Size of all surfaces is calculated if true,
only a single surface if false.
@Input bAllFaces Size of all faces is calculated if true,
only a single face if false.
@Return uint32 Size in BYTES of the specified texture area.
@Description Gets the size in BYTES of the texture, given various input
parameters. User can retrieve the size of either all
surfaces or a single surface, all faces or a single face
and all MIP-Maps or a single specified MIP level.
*************************************************************************/
const uint32 getDataSize(int32 iMipLevel=PVRTEX_ALLMIPLEVELS, bool bAllSurfaces = true, bool bAllFaces = true) const;
/*!***********************************************************************
@Function getNumArrayMembers
@Return uint32 Number of array members in this texture.
@Description Gets the number of array members stored in this texture.
*************************************************************************/
const uint32 getNumArrayMembers() const;
/*!***********************************************************************
@Function getNumMIPLevels
@Return uint32 Number of MIP-Map levels in this texture.
@Description Gets the number of MIP-Map levels stored in this texture.
*************************************************************************/
const uint32 getNumMIPLevels() const;
/*!***********************************************************************
@Function getNumFaces
@Return uint32 Number of faces in this texture.
@Description Gets the number of faces stored in this texture.
*************************************************************************/
const uint32 getNumFaces() const;
/*!***********************************************************************
@Function getOrientation
@Input axis EPVRTAxis type specifying the axis to examine.
@Return EPVRTOrientation Enum orientation of the axis.
@Description Gets the data orientation for this texture.
*************************************************************************/
const EPVRTOrientation getOrientation(EPVRTAxis axis) const;
/*!***********************************************************************
@Function isFileCompressed
@Return bool True if it is file compressed.
@Description Returns whether or not the texture is compressed using
PVRTexLib's FILE compression - this is independent of
any texture compression.
*************************************************************************/
const bool isFileCompressed() const;
/*!***********************************************************************
@Function isPreMultiplied
@Return bool True if texture is premultiplied.
@Description Returns whether or not the texture's colour has been
pre-multiplied by the alpha values.
*************************************************************************/
const bool isPreMultiplied() const;
/*!***********************************************************************
@Function getMetaDataSize
@Return const uint32 Size, in bytes, of the meta data stored in the header.
@Description Returns the total size of the meta data stored in the header.
This includes the size of all information stored in all MetaDataBlocks.
*************************************************************************/
const uint32 getMetaDataSize() const;
/*!***********************************************************************
@Function getOGLFormat
@Modified internalformat
@Modified format
@Modified type
@Description Gets the OpenGL equivalent values of internal format, format
and type for this texture. This will return any supported
OpenGL texture values, it is up to the user to decide if
these are valid for their current platform.
*************************************************************************/
const void getOGLFormat(uint32& internalformat, uint32& format, uint32& type) const;
/*!***********************************************************************
@Function getOGLESFormat
@Modified internalformat
@Modified format
@Modified type
@Description Gets the OpenGLES equivalent values of internal format,
format and type for this texture. This will return any
supported OpenGLES texture values, it is up to the user
to decide if these are valid for their current platform.
*************************************************************************/
const void getOGLESFormat(uint32& internalformat, uint32& format, uint32& type) const;
/*!***********************************************************************
@Function getD3DFormat
@Return const uint32
@Description Gets the D3DFormat (up to DirectX 9 and Direct 3D Mobile)
equivalent values for this texture. This will return any
supported D3D texture formats, it is up to the user to
decide if this is valid for their current platform.
*************************************************************************/
const uint32 getD3DFormat() const;
/*!***********************************************************************
@Function getDXGIFormat
@Return const uint32
@Description Gets the DXGIFormat (DirectX 10 onward) equivalent values
for this texture. This will return any supported DX texture
formats, it is up to the user to decide if this is valid
for their current platform.
*************************************************************************/
const uint32 getDXGIFormat() const;
/*!***********************************************************************
* Accessor Methods for a texture's properties - setters.
*************************************************************************/
/*!***********************************************************************
@Function setPixelFormat
@Input uPixelFormat The format of the pixel.
@Description Sets the pixel format for this texture.
*************************************************************************/
void setPixelFormat(PixelType uPixelFormat);
/*!***********************************************************************
@Function setColourSpace
@Input eColourSpace A colour space enum.
@Description Sets the colour space for this texture. Default is lRGB.
*************************************************************************/
void setColourSpace(EPVRTColourSpace eColourSpace);
/*!***********************************************************************
@Function setChannelType
@Input eVarType A variable type enum.
@Description Sets the variable type for the channels in this texture.
*************************************************************************/
void setChannelType(EPVRTVariableType eVarType);
/*!***********************************************************************
@Function setOGLFormat
@Input internalformat
@Input format
@Input type
@Return bool Whether the format is valid or not.
@Description Sets the format of the texture to PVRTexLib's internal
representation of the OGL format.
*************************************************************************/
bool setOGLFormat(const uint32& internalformat, const uint32& format, const uint32& type);
/*!***********************************************************************
@Function setOGLESFormat
@Input internalformat
@Input format
@Input type
@Return bool Whether the format is valid or not.
@Description Sets the format of the texture to PVRTexLib's internal
representation of the OGLES format.
*************************************************************************/
bool setOGLESFormat(const uint32& internalformat, const uint32& format, const uint32& type);
/*!***********************************************************************
@Function setD3DFormat
@Return bool Whether the format is valid or not.
@Description Sets the format of the texture to PVRTexLib's internal
representation of the D3D format.
*************************************************************************/
bool setD3DFormat(const uint32& DWORD_D3D_FORMAT);
/*!***********************************************************************
@Function setDXGIFormat
@Return bool Whether the format is valid or not.
@Description Sets the format of the texture to PVRTexLib's internal
representation of the DXGI format.
*************************************************************************/
bool setDXGIFormat(const uint32& DWORD_DXGI_FORMAT);
/*!***********************************************************************
@Function setWidth
@Input newWidth The new width.
@Description Sets the width.
*************************************************************************/
void setWidth(uint32 newWidth);
/*!***********************************************************************
@Function setHeight
@Input newHeight The new height.
@Description Sets the height.
*************************************************************************/
void setHeight(uint32 newHeight);
/*!***********************************************************************
@Function setDepth
@Input newDepth The new depth.
@Description Sets the depth.
*************************************************************************/
void setDepth(uint32 newDepth);
/*!***********************************************************************
@Function setNumArrayMembers
@Input newNumMembers The new number of members in this array.
@Description Sets the depth.
*************************************************************************/
void setNumArrayMembers(uint32 newNumMembers);
/*!***********************************************************************
@Function setNumMIPLevels
@Input newNumMIPLevels New number of MIP-Map levels.
@Description Sets the number of MIP-Map levels in this texture.
*************************************************************************/
void setNumMIPLevels(uint32 newNumMIPLevels);
/*!***********************************************************************
@Function setNumFaces
@Input newNumFaces New number of faces for this texture.
@Description Sets the number of faces stored in this texture.
*************************************************************************/
void setNumFaces(uint32 newNumFaces);
/*!***********************************************************************
@Function setOrientation
@Input eAxisOrientation Enum specifying axis and orientation.
@Description Sets the data orientation for a given axis in this texture.
*************************************************************************/
void setOrientation(EPVRTOrientation eAxisOrientation);
/*!***********************************************************************
@Function setIsFileCompressed
@Input isFileCompressed Sets file compression to true/false.
@Description Sets whether or not the texture is compressed using
PVRTexLib's FILE compression - this is independent of
any texture compression. Currently unsupported.
*************************************************************************/
void setIsFileCompressed(bool isFileCompressed);
/*!***********************************************************************
@Function isPreMultiplied
@Return isPreMultiplied Sets if texture is premultiplied.
@Description Sets whether or not the texture's colour has been
pre-multiplied by the alpha values.
*************************************************************************/
void setIsPreMultiplied(bool isPreMultiplied);
/*!***********************************************************************
Meta Data functions - Getters.
*************************************************************************/
/*!***********************************************************************
@Function isBumpMap
@Return bool True if it is a bump map.
@Description Returns whether the texture is a bump map or not.
*************************************************************************/
const bool isBumpMap() const;
/*!***********************************************************************
@Function getBumpMapScale
@Return float Returns the bump map scale.
@Description Gets the bump map scaling value for this texture. If the
texture is not a bump map, 0.0f is returned. If the
texture is a bump map but no meta data is stored to
specify its scale, then 1.0f is returned.
*************************************************************************/
const float getBumpMapScale() const;
/*!***********************************************************************
@Function getBumpMapOrder
@Return CPVRTString Returns bump map order relative to rgba.
@Description Gets the bump map channel order relative to rgba. For
example, an RGB texture with bumps mapped to XYZ returns
'xyz'. A BGR texture with bumps in the order ZYX will also
return 'xyz' as the mapping is the same: R=X, G=Y, B=Z.
If the letter 'h' is present in the string, it means that
the height map has been stored here.
Other characters are possible if the bump map was created
manually, but PVRTexLib will ignore these characters. They
are returned simply for completeness.
*************************************************************************/
const CPVRTString getBumpMapOrder() const;
/*!***********************************************************************
@Function getNumTextureAtlasMembers
@Return int Returns number of sub textures defined by meta data.
@Description Works out the number of possible texture atlas members in
the texture based on the w/h/d and the data size.
TODO: Is this the right way to do things? Should I return number of floats? Or just data size? Hmm. Also need to make it TWO floats per dimension, and also possibly a rotated value. Not sure.
*************************************************************************/
const int getNumTextureAtlasMembers() const;
/*!***********************************************************************
@Function getTextureAtlasData
@Return float* Returns a pointer directly to the texture atlas data.
@Description Returns a pointer to the texture atlas data.
TODO: Maybe I should return a copy rather than the original.
*************************************************************************/
const float* getTextureAtlasData() const;
/*!***********************************************************************
@Function getCubeMapOrder
@Return CPVRTString Returns cube map order.
@Description Gets the cube map face order. Returned string will be in
the form "ZzXxYy" with capitals representing positive and
small letters representing negative. I.e. Z=Z-Positive,
z=Z-Negative.
*************************************************************************/
const CPVRTString getCubeMapOrder() const;
/*!***********************************************************************
@Function getBorder
@Input uiBorderWidth
@Input uiBorderHeight
@Input uiBorderDepth
@Description Obtains the border size in each dimension for this texture.
*************************************************************************/
void getBorder(uint32& uiBorderWidth, uint32& uiBorderHeight, uint32& uiBorderDepth) const;
/*!***********************************************************************
@Function getMetaData
@Input DevFOURCC
@Input u32Key
@Return pvrtexture::MetaDataBlock A copy of the meta data from the texture.
@Description Returns a block of meta data from the texture. If the meta data doesn't exist, a block with data size 0 will be returned.
*************************************************************************/
MetaDataBlock getMetaData(uint32 DevFOURCC, uint32 u32Key) const;
/*!***********************************************************************
@Function hasMetaData
@Input DevFOURCC
@Input u32Key
@Return bool Whether or not the meta data bock specified exists
@Description Returns whether or not the specified meta data exists as
part of this texture header.
*************************************************************************/
bool hasMetaData(uint32 DevFOURCC, uint32 u32Key) const;
/*!***********************************************************************
@Function getMetaDataMap
@Return MetaDataMap* A direct pointer to the MetaData map.
@Description A pointer directly to the Meta Data Map, to allow users to read out data.
*************************************************************************/
const MetaDataMap* const getMetaDataMap() const;
/*!***********************************************************************
Meta Data functions - Setters.
*************************************************************************/
/*!***********************************************************************
@Function setBumpMap
@Input bumpScale Floating point "height" value to scale the bump map.
@Input bumpOrder Up to 4 character string, with values x,y,z,h in
some combination. Not all values need to be present.
Denotes channel order; x,y,z refer to the
corresponding axes, h indicates presence of the
original height map. It is possible to have only some
of these values rather than all. For example if 'h'
is present alone it will be considered a height map.
The values should be presented in RGBA order, regardless
of the texture format, so a zyxh order in a bgra texture
should still be passed as 'xyzh'. Capitals are allowed.
Any character stored here that is not one of x,y,z,h
or a NULL character will be ignored when PVRTexLib
reads the data, but will be preserved. This is useful
if you wish to define a custom data channel for instance.
In these instances PVRTexLib will assume it is simply
colour data.
@Description Sets a texture's bump map data.
*************************************************************************/
void setBumpMap(float bumpScale, CPVRTString bumpOrder="xyz");
/*!***********************************************************************
@Function setTextureAtlas
@Input pAtlasData Pointer to an array of atlas data.
@Input dataSize Number of floats that the data pointer contains.
@Description Sets the texture atlas coordinate meta data for later display.
It is up to the user to make sure that this texture atlas
data actually makes sense in the context of the header. It is
suggested that the "generateTextureAtlas" method in the tools
is used to create a texture atlas, manually setting one up is
possible but should be done with care.
*************************************************************************/
void setTextureAtlas(float* pAtlasData, uint32 dataSize);
/*!***********************************************************************
@Function setCubeMapOrder
@Input cubeMapOrder Up to 6 character string, with values
x,X,y,Y,z,Z in some combination. Not all
values need to be present. Denotes face
order; Capitals refer to positive axis
positions and small letters refer to
negative axis positions. E.g. x=X-Negative,
X=X-Positive. It is possible to have only
some of these values rather than all, as
long as they are NULL terminated.
NB: Values past the 6th character are not read.
@Description Sets a texture's bump map data.
*************************************************************************/
void setCubeMapOrder(CPVRTString cubeMapOrder="XxYyZz");
/*!***********************************************************************
@Function setBorder
@Input uiBorderWidth
@Input uiBorderHeight
@Input uiBorderDepth
@Return void
@Description Sets a texture's border size data. This value is subtracted
from the current texture height/width/depth to get the valid
texture data.
*************************************************************************/
void setBorder(uint32 uiBorderWidth, uint32 uiBorderHeight, uint32 uiBorderDepth);
/*!***********************************************************************
@Function addMetaData
@Input MetaBlock Meta data block to be added.
@Description Adds an arbitrary piece of meta data.
*************************************************************************/
void addMetaData(const MetaDataBlock& MetaBlock);
/*!***********************************************************************
@Function removeMetaData
@Input DevFourCC
@Input u32Key
@Return void
@Description Removes a specified piece of meta data, if it exists.
*************************************************************************/
void removeMetaData(const uint32& DevFourCC, const uint32& u32Key);
};
};
#endif