OGRE  1.12.4
Object-Oriented Graphics Rendering Engine
Ogre::ASTCCodec Class Reference

Codec specialized in loading ASTC (ARM Adaptive Scalable Texture Compression) images. More...

#include <OgreASTCCodec.h>

+ Inheritance diagram for Ogre::ASTCCodec:

Public Types

typedef SharedPtr< CodecDataCodecDataPtr
 
typedef ConstMapIterator< CodecList > CodecIterator
 
typedef std::pair< MemoryDataStreamPtr, CodecDataPtrDecodeResult
 Result of a decoding; both a decoded data stream and CodecData metadata. More...
 

Public Member Functions

 ASTCCodec ()
 
virtual ~ASTCCodec ()
 
DecodeResult decode (const DataStreamPtr &input) const
 Codes the data from the input chunk into the output chunk. More...
 
DataStreamPtr encode (const MemoryDataStreamPtr &input, const CodecDataPtr &pData) const
 Codes the data in the input stream and saves the result in the output stream. More...
 
void encodeToFile (const MemoryDataStreamPtr &input, const String &outFileName, const CodecDataPtr &pData) const
 Codes the data in the input chunk and saves the result in the output filename provided. More...
 
String getDataType () const
 Returns the type of the data that supported by this codec as a String. More...
 
virtual String getType () const
 Returns the type of the codec as a String. More...
 
virtual bool magicNumberMatch (const char *magicNumberPtr, size_t maxbytes) const
 Returns whether a magic number header matches this codec. More...
 
String magicNumberToFileExt (const char *magicNumberPtr, size_t maxbytes) const
 Maps a magic number header to a file extension, if this codec recognises it. More...
 

Static Public Member Functions

static CodecgetCodec (const String &extension)
 Gets the codec registered for the passed in file extension. More...
 
static CodecgetCodec (char *magicNumberPtr, size_t maxbytes)
 Gets the codec that can handle the given 'magic' identifier. More...
 
static CodecIterator getCodecIterator (void)
 Gets the iterator for the registered codecs. More...
 
static StringVector getExtensions (void)
 Gets the file extension list for the registered codecs. More...
 
static size_t getMemorySize (uint32 width, uint32 height, uint32 depth, int32 xdim, int32 ydim, PixelFormat fmt)
 
static bool isCodecRegistered (const String &codecType)
 Return whether a codec is registered already. More...
 
static void registerCodec (Codec *pCodec)
 Registers a new codec in the database. More...
 
static void shutdown (void)
 Static method to shutdown and unregister the ASTC codec. More...
 
static void startup (void)
 Static method to startup and register the ASTC codec. More...
 
static void unregisterCodec (Codec *pCodec)
 Unregisters a codec from the database. More...
 

Detailed Description

Codec specialized in loading ASTC (ARM Adaptive Scalable Texture Compression) images.

Remarks
We implement our own codec here since we need to be able to keep ASTC data compressed if the card supports it.

Member Typedef Documentation

◆ CodecDataPtr

◆ CodecIterator

typedef ConstMapIterator<CodecList> Ogre::Codec::CodecIterator
inherited

◆ DecodeResult

Result of a decoding; both a decoded data stream and CodecData metadata.

Constructor & Destructor Documentation

◆ ASTCCodec()

Ogre::ASTCCodec::ASTCCodec ( )

◆ ~ASTCCodec()

virtual Ogre::ASTCCodec::~ASTCCodec ( )
inlinevirtual

Member Function Documentation

◆ encode()

DataStreamPtr Ogre::ASTCCodec::encode ( const MemoryDataStreamPtr input,
const CodecDataPtr pData 
) const
virtual

Codes the data in the input stream and saves the result in the output stream.

Implements Ogre::Codec.

◆ encodeToFile()

void Ogre::ASTCCodec::encodeToFile ( const MemoryDataStreamPtr input,
const String outFileName,
const CodecDataPtr pData 
) const
virtual

Codes the data in the input chunk and saves the result in the output filename provided.

Provided for efficiency since coding to memory is progressive therefore memory required is unknown leading to reallocations.

Parameters
inputThe input data
outFileNameThe filename to write to
pDataExtra information to be passed to the codec (codec type specific)

Implements Ogre::Codec.

◆ decode()

DecodeResult Ogre::ASTCCodec::decode ( const DataStreamPtr input) const
virtual

Codes the data from the input chunk into the output chunk.

Parameters
inputStream containing the encoded data

Implements Ogre::Codec.

◆ magicNumberToFileExt()

String Ogre::ASTCCodec::magicNumberToFileExt ( const char *  magicNumberPtr,
size_t  maxbytes 
) const
virtual

Maps a magic number header to a file extension, if this codec recognises it.

Parameters
magicNumberPtrPointer to a stream of bytes which should identify the file. Note that this may be more than needed - each codec may be looking for a different size magic number.
maxbytesThe number of bytes passed
Returns
A blank string if the magic number was unknown, or a file extension.

Implements Ogre::Codec.

◆ getType()

virtual String Ogre::ASTCCodec::getType ( ) const
virtual

Returns the type of the codec as a String.

Implements Ogre::Codec.

◆ startup()

static void Ogre::ASTCCodec::startup ( void  )
static

Static method to startup and register the ASTC codec.

◆ shutdown()

static void Ogre::ASTCCodec::shutdown ( void  )
static

Static method to shutdown and unregister the ASTC codec.

◆ getMemorySize()

static size_t Ogre::ASTCCodec::getMemorySize ( uint32  width,
uint32  height,
uint32  depth,
int32  xdim,
int32  ydim,
PixelFormat  fmt 
)
static

◆ getDataType()

String Ogre::ImageCodec::getDataType ( ) const
inlinevirtualinherited

Returns the type of the data that supported by this codec as a String.

Implements Ogre::Codec.

◆ registerCodec()

static void Ogre::Codec::registerCodec ( Codec pCodec)
inlinestaticinherited

Registers a new codec in the database.

References Ogre::Exception::ERR_DUPLICATE_ITEM, Ogre::Codec::getType(), and OGRE_EXCEPT.

◆ isCodecRegistered()

static bool Ogre::Codec::isCodecRegistered ( const String codecType)
inlinestaticinherited

Return whether a codec is registered already.

◆ unregisterCodec()

static void Ogre::Codec::unregisterCodec ( Codec pCodec)
inlinestaticinherited

Unregisters a codec from the database.

References Ogre::Codec::getType().

◆ getCodecIterator()

static CodecIterator Ogre::Codec::getCodecIterator ( void  )
inlinestaticinherited

Gets the iterator for the registered codecs.

◆ getExtensions()

static StringVector Ogre::Codec::getExtensions ( void  )
staticinherited

Gets the file extension list for the registered codecs.

◆ getCodec() [1/2]

static Codec* Ogre::Codec::getCodec ( const String extension)
staticinherited

Gets the codec registered for the passed in file extension.

◆ getCodec() [2/2]

static Codec* Ogre::Codec::getCodec ( char *  magicNumberPtr,
size_t  maxbytes 
)
staticinherited

Gets the codec that can handle the given 'magic' identifier.

Parameters
magicNumberPtrPointer to a stream of bytes which should identify the file. Note that this may be more than needed - each codec may be looking for a different size magic number.
maxbytesThe number of bytes passed

◆ magicNumberMatch()

virtual bool Ogre::Codec::magicNumberMatch ( const char *  magicNumberPtr,
size_t  maxbytes 
) const
inlinevirtualinherited

Returns whether a magic number header matches this codec.

Parameters
magicNumberPtrPointer to a stream of bytes which should identify the file. Note that this may be more than needed - each codec may be looking for a different size magic number.
maxbytesThe number of bytes passed

The documentation for this class was generated from the following file: