#include <tb_texture_manager.h>
Public Member Functions | |
void | Initialize (void) |
TextureHandle | CreateTextureFromFile (const tbCore::tbString &filename) |
TextureHandle | CreateTextureFromFileData (const unsigned char *fileDataInMemory, const size_t &fileSizeInBytes) |
TextureHandle | CreateTextureFromPixelData (const unsigned char *pixelData, const PixelSpace &textureWidth, const PixelSpace &textureHeight) |
TextureHandle | CreateTextureEmpty (const PixelSpace &textureWidth, const PixelSpace &textureHeight) |
TextureHandle | CreateTextureReference (const TextureHandle &textureHandle) |
void | DestroyTexture (const TextureHandle &textureHandle) |
void | BindTexture (const TextureHandle &textureHandle) |
void | BindTexture (const TextureHandle &textureHandle, tbCore::uint8 textureUnit) |
PixelSpace | GetTextureWidth (const TextureHandle &textureHandle) const |
PixelSpace | GetTextureHeight (const TextureHandle &textureHandle) const |
tbCore::uint64 | ComputeMemoryUsage (void) const |
Friends | |
class | tbImplementation::TextureManagerCreator |
A basic texture manager to load images from disk or file/pixel data in memory while using a caching technique so using the same file path will not create more textures. TurtleBrains makes use of Sean Barrett's stb_image API to process the file, which supports the following file formats with some limitations:
void TurtleBrains::Graphics::TextureManager::BindTexture | ( | const TextureHandle & | textureHandle | ) |
Binds the texture associated with the textureHandle to the GL context for rendering calls. An error condition will be triggered if textureHandle is the handle was not initialized or the associated texture has been destroyed.
textureHandle | of the texture to apply to the GL context. |
tbCore::uint64 TurtleBrains::Graphics::TextureManager::ComputeMemoryUsage | ( | void | ) | const |
Returns the number of bytes in memory from all textures currently loaded in the manager/texture cache.
TextureHandle TurtleBrains::Graphics::TextureManager::CreateTextureEmpty | ( | const PixelSpace & | textureWidth, |
const PixelSpace & | textureHeight | ||
) |
Creates a texture with specified width and height then sets all the pixels to white. Textures created empty do not get cached, so be aware that calling this several times with the same width/height will create new textures. Any texture created must be cleaned up by calling DestroyTexture().
textureWidth | is the width of the texture to be created, in pixels, must be greater than 0. |
textureHeight | is the height of the texture to be created, in pixels, must be greater than 0. |
TextureHandle TurtleBrains::Graphics::TextureManager::CreateTextureFromFile | ( | const tbCore::tbString & | filename | ) |
Checks the cache if the file has already been opened, if not, the file will be opened from disk and processed creating an ARGB texture with OpenGL. Any texture created must be cleaned up by calling DestroyTexture. Although the texture may not actually be destroyed if there are still others referencing the texture object (via other calls to CreateTextureFromFile).
filename | the path of the file to open and process. |
TextureHandle TurtleBrains::Graphics::TextureManager::CreateTextureFromFileData | ( | const unsigned char * | fileDataInMemory, |
const size_t & | fileSizeInBytes | ||
) |
Creates a texture from the data of a file already in memory, this is not the uncompressed pixel data. Textures created from file data do not get cached, so be aware that calling this several times with the same file data will create new textures. Any texture created must be cleaned up by calling DestroyTexture().
fileDataInMemory | should contain an entire supported file in memory which can be removed after the call. |
fileSizeInBytes | is how many bytes make up the file. |
TextureHandle TurtleBrains::Graphics::TextureManager::CreateTextureFromPixelData | ( | const unsigned char * | pixelData, |
const PixelSpace & | textureWidth, | ||
const PixelSpace & | textureHeight | ||
) |
Creates a texture from the data of each pixel color, this is the uncompressed 32bit ARGB pixel data format. A 1x1 texture would be 4 bytes, first byte Alpha, second Red, then Green and final byte Blue. Textures created from pixel data do not get cached, so be aware that calling this several times with the same pixel data will create new textures. Any texture created must be cleaned up by calling DestroyTexture().
pixelData | must contain at least (textureWidth * textureHeight * 4) bytes of data for each byte. |
textureWidth | is the width of the supplied pixelData in pixels wide, must be greater than 0. |
textureHeight | is the height of the supplied pixelData in pixels tall, must be greater than 0. |
TextureHandle TurtleBrains::Graphics::TextureManager::CreateTextureReference | ( | const TextureHandle & | textureHandle | ) |
This does not actually create a texture but will increase the reference count so it does not get unloaded/cleaned on the call to DestroyTexture. This is meant to allow textured created by file data or pixel data to be shared more easily in the reference counted manner. Any texture created must be cleaned up by calling DestroyTexture().
textureHandle | The texture associated with this handle will increment the reference count and be returned back. Must be a valid TextureHandle or an error condition will be triggered. |
void TurtleBrains::Graphics::TextureManager::DestroyTexture | ( | const TextureHandle & | textureHandle | ) |
Decrements the textures reference count and if needed will destroys the texture, removing it from the OpenGL pipeline and cleaning any other associated resources. Each texture handle is reference counted, so every call to Create needs a matching call to destroy.
textureHandle | of the texture to destroy and remove completely from the GL context and TextureManager. |
PixelSpace TurtleBrains::Graphics::TextureManager::GetTextureHeight | ( | const TextureHandle & | textureHandle | ) | const |
Returns the width of the texture associated with the textureHandle provided. If kInvalidTexture is provided 0 will be returned. An error condition will be triggered if textureHandle is the handle was not initialized or the associated texture has been destroyed.
PixelSpace TurtleBrains::Graphics::TextureManager::GetTextureWidth | ( | const TextureHandle & | textureHandle | ) | const |
Returns the width of the texture associated with the textureHandle provided. If kInvalidTexture is provided 0 will be returned. An error condition will be triggered if textureHandle is the handle was not initialized or the associated texture has been destroyed.
void TurtleBrains::Graphics::TextureManager::Initialize | ( | void | ) |
TODO: TurtleBrains: Documentation: Teach the user how to use this.