A global cache of images that have been loaded from files or memory. More...
#include <juce_ImageCache.h>
Static Public Member Functions | |
static void | addImageToCache (const Image &image, int64 hashCode) |
Adds an image to the cache with a user-defined hash-code. More... | |
static Image | getFromFile (const File &file) |
Loads an image from a file, (or just returns the image if it's already cached). More... | |
static Image | getFromHashCode (int64 hashCode) |
Checks the cache for an image with a particular hashcode. More... | |
static Image | getFromMemory (const void *imageData, int dataSize) |
Loads an image from an in-memory image file, (or just returns the image if it's already cached). More... | |
static void | releaseUnusedImages () |
Releases any images in the cache that aren't being referenced by active Image objects. More... | |
static void | setCacheTimeout (int millisecs) |
Changes the amount of time before an unused image will be removed from the cache. More... | |
Private Member Functions | |
ImageCache () | |
~ImageCache () | |
Friends | |
struct | Pimpl |
A global cache of images that have been loaded from files or memory.
If you're loading an image and may need to use the image in more than one place, this is used to allow the same image to be shared rather than loading multiple copies into memory.
Another advantage is that after images are released, they will be kept in memory for a few seconds before it is actually deleted, so if you're repeatedly loading/deleting the same image, it'll reduce the chances of having to reload it each time.
@tags{Graphics}
|
private |
|
private |
Adds an image to the cache with a user-defined hash-code.
The image passed-in will be referenced (not copied) by the cache, so it's probably a good idea not to draw into it after adding it, otherwise this will affect all instances of it that may be in use.
image | the image to add |
hashCode | the hash-code to associate with it |
Loads an image from a file, (or just returns the image if it's already cached).
If the cache already contains an image that was loaded from this file, that image will be returned. Otherwise, this method will try to load the file, add it to the cache, and return it.
Remember that the image returned is shared, so drawing into it might affect other things that are using it! If you want to draw on it, first call Image::duplicateIfShared()
file | the file to try to load |
Checks the cache for an image with a particular hashcode.
If there's an image in the cache with this hashcode, it will be returned, otherwise it will return an invalid image.
hashCode | the hash code that was associated with the image by addImageToCache() |
Loads an image from an in-memory image file, (or just returns the image if it's already cached).
If the cache already contains an image that was loaded from this block of memory, that image will be returned. Otherwise, this method will try to load the file, add it to the cache, and return it.
Remember that the image returned is shared, so drawing into it might affect other things that are using it! If you want to draw on it, first call Image::duplicateIfShared()
imageData | the block of memory containing the image data |
dataSize | the data size in bytes |
|
static |
Releases any images in the cache that aren't being referenced by active Image objects.
|
static |
Changes the amount of time before an unused image will be removed from the cache.
By default this is about 5 seconds.
|
friend |