MaterialX 1.39.2
Loading...
Searching...
No Matches
GLTextureHandler Class Reference

An OpenGL texture handler class. More...

#include <GLTextureHandler.h>

Inheritance diagram for GLTextureHandler:
ImageHandler

Public Member Functions

bool bindImage (ImagePtr image, const ImageSamplingProperties &samplingProperties) override
 Bind an image.
 
bool unbindImage (ImagePtr image) override
 Unbind an image.
 
bool createRenderResources (ImagePtr image, bool generateMipMaps, bool useAsRenderTarget=false) override
 Create rendering resources for the given image.
 
void releaseRenderResources (ImagePtr image=nullptr) override
 Release rendering resources for the given image, or for all cached images if no image pointer is specified.
 
int getBoundTextureLocation (unsigned int resourceId)
 Return the bound texture location for a given resource.
 
- Public Member Functions inherited from ImageHandler
void addLoader (ImageLoaderPtr loader)
 Add another image loader to the handler, which will be invoked if existing loaders cannot load a given image.
 
StringSet supportedExtensions ()
 Get a list of extensions supported by the handler.
 
bool saveImage (const FilePath &filePath, ConstImagePtr image, bool verticalFlip=false)
 Save image to disk.
 
ImagePtr acquireImage (const FilePath &filePath, const Color4 &defaultColor=Color4(0.0f))
 Acquire an image from the cache or file system.
 
void unbindImages ()
 Unbind all images that are currently stored in the cache.
 
void setSearchPath (const FileSearchPath &path)
 Set the search path to be used for finding images on the file system.
 
const FileSearchPathgetSearchPath () const
 Return the image search path.
 
void setFilenameResolver (StringResolverPtr resolver)
 Set the filename resolver for images.
 
StringResolverPtr getFilenameResolver () const
 Return the filename resolver for images.
 
void clearImageCache ()
 Clear the contents of the image cache, first releasing any render resources associated with cached images.
 
ImagePtr getZeroImage () const
 Return a fallback image with zeroes in all channels.
 
ImageVec getReferencedImages (ConstDocumentPtr doc)
 Acquire all images referenced by the given document, and return the images in a vector.
 

Static Public Member Functions

static ImageHandlerPtr create (ImageLoaderPtr imageLoader)
 
static int mapAddressModeToGL (ImageSamplingProperties::AddressMode addressModeEnum)
 Utility to map an address mode enumeration to an OpenGL address mode.
 
static int mapFilterTypeToGL (ImageSamplingProperties::FilterType filterTypeEnum, bool enableMipmaps)
 Utility to map a filter type enumeration to an OpenGL filter type.
 
static void mapTextureFormatToGL (Image::BaseType baseType, unsigned int channelCount, bool srgb, int &glType, int &glFormat, int &glInternalFormat)
 Utility to map generic texture properties to OpenGL texture formats.
 
- Static Public Member Functions inherited from ImageHandler
static ImageHandlerPtr create (ImageLoaderPtr imageLoader)
 

Protected Member Functions

 GLTextureHandler (ImageLoaderPtr imageLoader)
 
int getNextAvailableTextureLocation ()
 
- Protected Member Functions inherited from ImageHandler
 ImageHandler (ImageLoaderPtr imageLoader)
 
ImagePtr loadImage (const FilePath &filePath)
 
void cacheImage (const string &filePath, ImagePtr image)
 
ImagePtr getCachedImage (const FilePath &filePath)
 

Protected Attributes

std::vector< unsigned int > _boundTextureLocations
 
- Protected Attributes inherited from ImageHandler
ImageLoaderMap _imageLoaders
 
ImageMap _imageCache
 
FileSearchPath _searchPath
 
StringResolverPtr _resolver
 
ImagePtr _zeroImage
 

Detailed Description

An OpenGL texture handler class.

Member Function Documentation

◆ bindImage()

bool bindImage ( ImagePtr image,
const ImageSamplingProperties & samplingProperties )
overridevirtual

Bind an image.

This method will bind the texture to an active texture unit as defined by the corresponding image description. The method will fail if there are not enough available image units to bind to.

Reimplemented from ImageHandler.

◆ createRenderResources()

bool createRenderResources ( ImagePtr image,
bool generateMipMaps,
bool useAsRenderTarget = false )
overridevirtual

Create rendering resources for the given image.

Reimplemented from ImageHandler.

◆ releaseRenderResources()

void releaseRenderResources ( ImagePtr image = nullptr)
overridevirtual

Release rendering resources for the given image, or for all cached images if no image pointer is specified.

Reimplemented from ImageHandler.

◆ unbindImage()

bool unbindImage ( ImagePtr image)
overridevirtual

Unbind an image.

Reimplemented from ImageHandler.


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