OGRE
13.6
Object-Oriented Graphics Rendering Engine
|
Class representing an image file. More...
#include <OgreImage.h>
Public Types | |
enum | Filter { FILTER_NEAREST , FILTER_LINEAR , FILTER_BILINEAR = FILTER_LINEAR } |
Public Member Functions | |
Image (const Image &img) | |
Copy-constructor - copies all the data from the target image. More... | |
Image (PixelFormat format=PF_UNKNOWN, uint32 width=0, uint32 height=0, uint32 depth=1, uchar *buffer=NULL, bool autoDelete=true) | |
Standard constructor. More... | |
~Image () | |
Standard destructor. More... | |
Image & | combineTwoImagesAsRGBA (const Image &rgb, const Image &alpha, PixelFormat format=PF_BYTE_RGBA) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha). More... | |
void | create (PixelFormat format, uint32 width, uint32 height, uint32 depth=1, uint32 numFaces=1, uint32 numMipMaps=0) |
allocates a buffer of given size if needed More... | |
DataStreamPtr | encode (const String &formatextension) |
Encode the image and return a stream to the data. More... | |
Image & | flipAroundX () |
Flips (mirrors) the image around the X-axis. More... | |
Image & | flipAroundY () |
Flips (mirrors) the image around the Y-axis. More... | |
void | freeMemory () |
Delete all the memory held by this image, if owned by this image (not dynamic) More... | |
uchar | getBPP () const |
Returns the number of bits per pixel. More... | |
ColourValue | getColourAt (uint32 x, uint32 y, uint32 z) const |
Get colour value from a certain location in the image. More... | |
uchar * | getData (uint32 x=0, uint32 y=0, uint32 z=0) |
Returns a pointer to the internal image buffer at the specified pixel location. More... | |
template<typename T > | |
T * | getData (uint32 x=0, uint32 y=0, uint32 z=0) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
const uchar * | getData (uint32 x=0, uint32 y=0, uint32 z=0) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
template<typename T > | |
const T * | getData (uint32 x=0, uint32 y=0, uint32 z=0) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
uint32 | getDepth (void) const |
Gets the depth of the image. More... | |
PixelFormat | getFormat () const |
Returns the image format. More... | |
bool | getHasAlpha () const |
Returns true if the image has an alpha component. More... | |
uint32 | getHeight (void) const |
Gets the height of the image in pixels. More... | |
uint32 | getNumFaces (void) const |
Get the number of faces of the image. More... | |
uint32 | getNumMipmaps () const |
Returns the number of mipmaps contained in the image. More... | |
PixelBox | getPixelBox (uint32 face=0, uint32 mipmap=0) const |
Get a PixelBox encapsulating the image data of a mipmap. More... | |
size_t | getRowSpan (void) const |
Gets the physical width in bytes of each row of pixels. More... | |
size_t | getSize () const |
Returns the size of the data buffer in bytes. More... | |
uint32 | getWidth (void) const |
Gets the width of the image in pixels. More... | |
bool | hasFlag (const ImageFlags imgFlag) const |
Returns true if the image has the appropriate flag set. More... | |
Image & | load (const DataStreamPtr &stream, const String &type=BLANKSTRING) |
Loads an image file from a stream. More... | |
Image & | load (const String &filename, const String &groupName) |
Loads an image file. More... | |
Image & | loadDynamicImage (uchar *data, uint32 width, uint32 height, PixelFormat format) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
Image & | loadDynamicImage (uchar *data, uint32 width, uint32 height, uint32 depth, PixelFormat format, bool autoDelete=false, uint32 numFaces=1, uint32 numMipMaps=0) |
Stores a pointer to raw data in memory. More... | |
Image & | loadRawData (const DataStreamPtr &stream, uint32 width, uint32 height, PixelFormat format) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
Image & | loadRawData (const DataStreamPtr &stream, uint32 width, uint32 height, uint32 depth, PixelFormat format, uint32 numFaces=1, uint32 numMipMaps=0) |
Loads raw data from a stream. More... | |
Image & | loadTwoImagesAsRGBA (const DataStreamPtr &rgbStream, const DataStreamPtr &alphaStream, PixelFormat format=PF_BYTE_RGBA, const String &rgbType=BLANKSTRING, const String &alphaType=BLANKSTRING) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha). More... | |
Image & | loadTwoImagesAsRGBA (const String &rgbFilename, const String &alphaFilename, const String &groupName, PixelFormat format=PF_BYTE_RGBA) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha). More... | |
Image & | operator= (const Image &img) |
Assignment operator - copies all the data from the target image. More... | |
void | resize (ushort width, ushort height, Filter filter=FILTER_BILINEAR) |
Resize a 2D image, applying the appropriate filter. More... | |
void | save (const String &filename) |
Save the image as a file. More... | |
void | setColourAt (ColourValue const &cv, uint32 x, uint32 y, uint32 z) |
Set colour value at a certain location in the image. More... | |
void | setTo (const ColourValue &col) |
sets all pixels to the specified colour More... | |
Static Public Member Functions | |
static void | applyGamma (uchar *buffer, Real gamma, size_t size, uchar bpp) |
Does gamma adjustment. More... | |
static size_t | calculateSize (uint32 mipmaps, uint32 faces, uint32 width, uint32 height, uint32 depth, PixelFormat format) |
Static function to calculate size in bytes from the number of mipmaps, faces and the dimensions. More... | |
static String | getFileExtFromMagic (DataStreamPtr stream) |
Static function to get an image type string from a stream via magic numbers. More... | |
static void | scale (const PixelBox &src, const PixelBox &dst, Filter filter=FILTER_BILINEAR) |
Scale a 1D, 2D or 3D image volume. More... | |
Class representing an image file.
enum Ogre::Image::Filter |
Ogre::Image::Image | ( | PixelFormat | format = PF_UNKNOWN , |
uint32 | width = 0 , |
||
uint32 | height = 0 , |
||
uint32 | depth = 1 , |
||
uchar * | buffer = NULL , |
||
bool | autoDelete = true |
||
) |
Standard constructor.
allocates a buffer of given size if buffer pointer is NULL.
Ogre::Image::Image | ( | const Image & | img | ) |
Copy-constructor - copies all the data from the target image.
Ogre::Image::~Image | ( | ) |
Standard destructor.
void Ogre::Image::create | ( | PixelFormat | format, |
uint32 | width, | ||
uint32 | height, | ||
uint32 | depth = 1 , |
||
uint32 | numFaces = 1 , |
||
uint32 | numMipMaps = 0 |
||
) |
allocates a buffer of given size if needed
Referenced by Ogre::TinyDepthBuffer::TinyDepthBuffer().
Assignment operator - copies all the data from the target image.
void Ogre::Image::setTo | ( | const ColourValue & | col | ) |
sets all pixels to the specified colour
format conversion is performed as needed
Image& Ogre::Image::flipAroundY | ( | ) |
Flips (mirrors) the image around the Y-axis.
originalimg 00000000000 00000000000 00000000000 00000000000 00000000000 ------------> flip axis 00000000000 00000000000 00000000000 00000000000 00000000000 originalimg
Image& Ogre::Image::flipAroundX | ( | ) |
Flips (mirrors) the image around the X-axis.
flip axis | originalimg|gmilanigiro 00000000000|00000000000 00000000000|00000000000 00000000000|00000000000 00000000000|00000000000 00000000000|00000000000
Image& Ogre::Image::loadDynamicImage | ( | uchar * | data, |
uint32 | width, | ||
uint32 | height, | ||
uint32 | depth, | ||
PixelFormat | format, | ||
bool | autoDelete = false , |
||
uint32 | numFaces = 1 , |
||
uint32 | numMipMaps = 0 |
||
) |
Stores a pointer to raw data in memory.
The pixel format has to be specified.
data | The data pointer |
width | Width of image |
height | Height of image |
depth | Image Depth (in 3d images, numbers of layers, otherwise 1) |
format | Pixel Format |
autoDelete | If memory associated with this buffer is to be destroyed with the Image object. Note: it's important that if you set this option to true, that you allocated the memory using OGRE_ALLOC_T with a category of MEMCATEGORY_GENERAL to ensure the freeing of memory matches up. |
numFaces | The number of faces the image data has inside (6 for cubemaps, 1 otherwise) |
numMipMaps | The number of mipmaps the image data has inside |
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Image& Ogre::Image::loadRawData | ( | const DataStreamPtr & | stream, |
uint32 | width, | ||
uint32 | height, | ||
uint32 | depth, | ||
PixelFormat | format, | ||
uint32 | numFaces = 1 , |
||
uint32 | numMipMaps = 0 |
||
) |
Loads raw data from a stream.
See the function loadDynamicImage for a description of the parameters.
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Loads an image file.
filename | Name of an image file to load. |
groupName | Name of the resource group to search for the image |
Image& Ogre::Image::load | ( | const DataStreamPtr & | stream, |
const String & | type = BLANKSTRING |
||
) |
Loads an image file from a stream.
stream | The source data. |
type | The type of the image. Used to decide what decompression codec to use. Can be left blank if the stream data includes a header to identify the data. |
Image& Ogre::Image::loadTwoImagesAsRGBA | ( | const String & | rgbFilename, |
const String & | alphaFilename, | ||
const String & | groupName, | ||
PixelFormat | format = PF_BYTE_RGBA |
||
) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha).
rgbFilename | Filename of image supplying the RGB channels (any alpha is ignored) |
alphaFilename | Filename of image supplying the alpha channel. If a luminance image the single channel is used directly, if an RGB image then the values are converted to greyscale. |
groupName | The resource group from which to load the images |
format | The destination format |
Image& Ogre::Image::loadTwoImagesAsRGBA | ( | const DataStreamPtr & | rgbStream, |
const DataStreamPtr & | alphaStream, | ||
PixelFormat | format = PF_BYTE_RGBA , |
||
const String & | rgbType = BLANKSTRING , |
||
const String & | alphaType = BLANKSTRING |
||
) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha).
rgbStream | Stream of image supplying the RGB channels (any alpha is ignored) |
alphaStream | Stream of image supplying the alpha channel. If a luminance image the single channel is used directly, if an RGB image then the values are converted to greyscale. |
format | The destination format |
rgbType | The type of the RGB image. Used to decide what decompression codec to use. Can be left blank if the stream data includes a header to identify the data. |
alphaType | The type of the alpha image. Used to decide what decompression codec to use. Can be left blank if the stream data includes a header to identify the data. |
Image& Ogre::Image::combineTwoImagesAsRGBA | ( | const Image & | rgb, |
const Image & | alpha, | ||
PixelFormat | format = PF_BYTE_RGBA |
||
) |
Utility method to combine 2 separate images into this one, with the first image source supplying the RGB channels, and the second image supplying the alpha channel (as luminance or separate alpha).
void Ogre::Image::save | ( | const String & | filename | ) |
Save the image as a file.
DataStreamPtr Ogre::Image::encode | ( | const String & | formatextension | ) |
Encode the image and return a stream to the data.
formatextension | An extension to identify the image format to encode into, e.g. "jpg" or "png" |
Returns a pointer to the internal image buffer at the specified pixel location.
Be careful with this method. You will almost certainly prefer to use getPixelBox, especially with complex images which include many faces or custom mipmaps.
Referenced by Ogre::IShader::sample2D().
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
inline |
Returns the size of the data buffer in bytes.
|
inline |
Returns the number of mipmaps contained in the image.
|
inline |
Returns true if the image has the appropriate flag set.
|
inline |
Gets the width of the image in pixels.
Referenced by Ogre::IShader::sample2D().
|
inline |
Gets the height of the image in pixels.
Referenced by Ogre::IShader::sample2D().
|
inline |
Gets the depth of the image.
|
inline |
Get the number of faces of the image.
This is usually 6 for a cubemap, and 1 for a normal image.
References Ogre::IF_CUBEMAP.
|
inline |
Gets the physical width in bytes of each row of pixels.
|
inline |
Returns the image format.
|
inline |
Returns the number of bits per pixel.
bool Ogre::Image::getHasAlpha | ( | ) | const |
Returns true if the image has an alpha component.
Does gamma adjustment.
ColourValue Ogre::Image::getColourAt | ( | uint32 | x, |
uint32 | y, | ||
uint32 | z | ||
) | const |
Get colour value from a certain location in the image.
The z coordinate is only valid for cubemaps and volume textures. This uses the first (largest) mipmap.
void Ogre::Image::setColourAt | ( | ColourValue const & | cv, |
uint32 | x, | ||
uint32 | y, | ||
uint32 | z | ||
) |
Set colour value at a certain location in the image.
The z coordinate is only valid for cubemaps and volume textures. This uses the first (largest) mipmap.
Get a PixelBox encapsulating the image data of a mipmap.
void Ogre::Image::freeMemory | ( | ) |
Delete all the memory held by this image, if owned by this image (not dynamic)
|
static |
Scale a 1D, 2D or 3D image volume.
src | PixelBox containing the source pointer, dimensions and format |
dst | PixelBox containing the destination pointer, dimensions and format |
filter | Which filter to use |
void Ogre::Image::resize | ( | ushort | width, |
ushort | height, | ||
Filter | filter = FILTER_BILINEAR |
||
) |
Resize a 2D image, applying the appropriate filter.
|
static |
Static function to calculate size in bytes from the number of mipmaps, faces and the dimensions.
|
static |
Static function to get an image type string from a stream via magic numbers.