Public Types | Public Member Functions | Static Public Member Functions | Protected Types | Static Protected Attributes | Private Member Functions | Private Attributes | Static Private Attributes
Ogre::DDSCodec Class Reference

Codec specialized in loading DDS (Direct Draw Surface) images. More...

#include <OgreDDSCodec.h>

Inheritance diagram for Ogre::DDSCodec:
Inheritance graph
[legend]

List of all members.

Public Types

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

Public Member Functions

 DDSCodec ()
virtual ~DDSCodec ()
DecodeResult decode (DataStreamPtr &input) const
DataStreamPtr encode (MemoryDataStreamPtr &input, CodecDataPtr &pData) const
void encodeToFile (MemoryDataStreamPtr &input, const String &outFileName, CodecDataPtr &pData) const
String getDataType () const
 Returns the type of the data that supported by this codec as a String.
virtual String getType () const
 Returns the type of the codec as a String.
virtual bool magicNumberMatch (const char *magicNumberPtr, size_t maxbytes) const
 Returns whether a magic number header matches this codec.
String magicNumberToFileExt (const char *magicNumberPtr, size_t maxbytes) const
void operator delete (void *ptr)
void operator delete (void *ptr, void *)
void operator delete (void *ptr, const char *, int, const char *)
void operator delete[] (void *ptr)
void operator delete[] (void *ptr, const char *, int, const char *)
void * operator new (size_t sz, const char *file, int line, const char *func)
 operator new, with debug line info
void * operator new (size_t sz)
void * operator new (size_t sz, void *ptr)
 placement operator new
void * operator new[] (size_t sz, const char *file, int line, const char *func)
 array operator new, with debug line info
void * operator new[] (size_t sz)

Static Public Member Functions

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

Protected Types

typedef map< String, Codec * >
::type 
CodecList

Static Protected Attributes

static CodecList msMapCodecs
 A map that contains all the registered codecs.

Private Member Functions

PixelFormat convertDXToOgreFormat (uint32 fourcc) const
PixelFormat convertFourCCFormat (uint32 fourcc) const
PixelFormat convertPixelFormat (uint32 rgbBits, uint32 rMask, uint32 gMask, uint32 bMask, uint32 aMask) const
void flipEndian (void *pData, size_t size, size_t count) const
void flipEndian (void *pData, size_t size) const
void unpackDXTAlpha (const DXTExplicitAlphaBlock &block, ColourValue *pCol) const
 Unpack DXT alphas into array of 16 colour values.
void unpackDXTAlpha (const DXTInterpolatedAlphaBlock &block, ColourValue *pCol) const
 Unpack DXT alphas into array of 16 colour values.
void unpackDXTColour (PixelFormat pf, const DXTColourBlock &block, ColourValue *pCol) const
 Unpack DXT colours into array of 16 colour values.

Private Attributes

String mType

Static Private Attributes

static DDSCodecmsInstance
 Single registered codec instance.

Detailed Description

Codec specialized in loading DDS (Direct Draw Surface) images.

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

Definition at line 50 of file OgreDDSCodec.h.


Member Typedef Documentation

Definition at line 74 of file OgreCodec.h.

Definition at line 76 of file OgreCodec.h.

typedef map< String, Codec* >::type Ogre::Codec::CodecList [protected, inherited]

Definition at line 59 of file OgreCodec.h.

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

Definition at line 141 of file OgreCodec.h.


Constructor & Destructor Documentation

virtual Ogre::DDSCodec::~DDSCodec ( ) [virtual]

Definition at line 74 of file OgreDDSCodec.h.


Member Function Documentation

PixelFormat Ogre::DDSCodec::convertPixelFormat ( uint32  rgbBits,
uint32  rMask,
uint32  gMask,
uint32  bMask,
uint32  aMask 
) const [private]
DecodeResult Ogre::DDSCodec::decode ( DataStreamPtr input) const [virtual]

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

Parameters:
inputStream containing the encoded data

Implements Ogre::Codec.

DataStreamPtr Ogre::DDSCodec::encode ( MemoryDataStreamPtr input,
CodecDataPtr pData 
) const [virtual]

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

Implements Ogre::Codec.

void Ogre::DDSCodec::encodeToFile ( MemoryDataStreamPtr input,
const String outFileName,
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.

void Ogre::DDSCodec::flipEndian ( void *  pData,
size_t  size,
size_t  count 
) const [private]
void Ogre::DDSCodec::flipEndian ( void *  pData,
size_t  size 
) const [private]
static Codec* Ogre::Codec::getCodec ( const String extension) [static, inherited]

Gets the codec registered for the passed in file extension.

static Codec* Ogre::Codec::getCodec ( char *  magicNumberPtr,
size_t  maxbytes 
) [static, inherited]

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
static CodecIterator Ogre::Codec::getCodecIterator ( void  ) [static, inherited]

Gets the iterator for the registered codecs.

Definition at line 108 of file OgreCodec.h.

String Ogre::ImageCodec::getDataType ( ) const [virtual, inherited]

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

Implements Ogre::Codec.

Definition at line 79 of file OgreImageCodec.h.

static StringVector Ogre::Codec::getExtensions ( void  ) [static, inherited]

Gets the file extension list for the registered codecs.

virtual String Ogre::DDSCodec::getType ( ) const [virtual]

Returns the type of the codec as a String.

Implements Ogre::Codec.

static bool Ogre::Codec::isCodecRegistered ( const String codecType) [static, inherited]

Return whether a codec is registered already.

Definition at line 95 of file OgreCodec.h.

virtual bool Ogre::Codec::magicNumberMatch ( const char *  magicNumberPtr,
size_t  maxbytes 
) const [virtual, inherited]

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

Definition at line 161 of file OgreCodec.h.

String Ogre::DDSCodec::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.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr) [inherited]

Definition at line 96 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
void *   
) [inherited]

Definition at line 102 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete ( void *  ptr,
const char *  ,
int  ,
const char *   
) [inherited]

Definition at line 108 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr) [inherited]

Definition at line 113 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void Ogre::AllocatedObject< Alloc >::operator delete[] ( void *  ptr,
const char *  ,
int  ,
const char *   
) [inherited]

Definition at line 119 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
const char *  file,
int  line,
const char *  func 
) [inherited]

operator new, with debug line info

Definition at line 68 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz) [inherited]

Definition at line 73 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new ( size_t  sz,
void *  ptr 
) [inherited]

placement operator new

Definition at line 79 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz,
const char *  file,
int  line,
const char *  func 
) [inherited]

array operator new, with debug line info

Definition at line 86 of file OgreMemoryAllocatedObject.h.

template<class Alloc >
void* Ogre::AllocatedObject< Alloc >::operator new[] ( size_t  sz) [inherited]

Definition at line 91 of file OgreMemoryAllocatedObject.h.

static void Ogre::Codec::registerCodec ( Codec pCodec) [static, inherited]

Registers a new codec in the database.

Definition at line 83 of file OgreCodec.h.

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

static void Ogre::DDSCodec::shutdown ( void  ) [static]

Static method to shutdown and unregister the DDS codec.

static void Ogre::DDSCodec::startup ( void  ) [static]

Static method to startup and register the DDS codec.

void Ogre::DDSCodec::unpackDXTAlpha ( const DXTExplicitAlphaBlock &  block,
ColourValue pCol 
) const [private]

Unpack DXT alphas into array of 16 colour values.

void Ogre::DDSCodec::unpackDXTAlpha ( const DXTInterpolatedAlphaBlock &  block,
ColourValue pCol 
) const [private]

Unpack DXT alphas into array of 16 colour values.

void Ogre::DDSCodec::unpackDXTColour ( PixelFormat  pf,
const DXTColourBlock &  block,
ColourValue pCol 
) const [private]

Unpack DXT colours into array of 16 colour values.

static void Ogre::Codec::unregisterCodec ( Codec pCodec) [static, inherited]

Unregisters a codec from the database.

Definition at line 102 of file OgreCodec.h.

References Ogre::Codec::getType().


Member Data Documentation

Single registered codec instance.

Definition at line 71 of file OgreDDSCodec.h.

CodecList Ogre::Codec::msMapCodecs [static, protected, inherited]

A map that contains all the registered codecs.

Definition at line 62 of file OgreCodec.h.

Definition at line 53 of file OgreDDSCodec.h.


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

Copyright © 2012 Torus Knot Software Ltd
Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.
Last modified Mon Jul 27 2020 13:40:59