Package com.jme3.asset.cache
Class WeakRefCloneAssetCache
java.lang.Object
com.jme3.asset.cache.WeakRefCloneAssetCache
- All Implemented Interfaces:
AssetCache
WeakRefCloneAssetCache caches cloneable assets in a weak-key
cache, allowing them to be collected when memory is low.
The cache stores weak references to the asset keys, so that
when all clones of the original asset are collected, will cause the
asset to be automatically removed from the cache.-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescription<T> voidaddToCache(AssetKey<T> originalKey, T obj) Adds an asset to the cache.voidDeletes all assets from the cache.booleandeleteFromCache(AssetKey key) Deletes an asset from the cache.<T> TgetFromCache(AssetKey<T> key) Retrieves an asset from the cache.voidNotifies the cache that even though the methodsAssetCache.addToCache(com.jme3.asset.AssetKey, java.lang.Object)orAssetCache.getFromCache(com.jme3.asset.AssetKey)were used, there won't be a call toAssetCache.registerAssetClone(com.jme3.asset.AssetKey, java.lang.Object)for some reason.<T> voidregisterAssetClone(AssetKey<T> key, T clone) This should be called by the asset manager when it has successfully acquired a cached asset (withAssetCache.getFromCache(com.jme3.asset.AssetKey)) and cloned it for use.
-
Constructor Details
-
WeakRefCloneAssetCache
public WeakRefCloneAssetCache()
-
-
Method Details
-
addToCache
Description copied from interface:AssetCacheAdds an asset to the cache. Once added, it should be possible to retrieve the asset by using theAssetCache.getFromCache(com.jme3.asset.AssetKey)method. However, the caching criteria may at some point decide that the asset should be removed from the cache to save memory. In that case,AssetCache.getFromCache(com.jme3.asset.AssetKey)will return null.Thread-Safe
- Specified by:
addToCachein interfaceAssetCache- Type Parameters:
T- The type of the asset to cache.- Parameters:
originalKey- The asset key that can be used to look up the asset.obj- The asset data to cache.
-
registerAssetClone
Description copied from interface:AssetCacheThis should be called by the asset manager when it has successfully acquired a cached asset (withAssetCache.getFromCache(com.jme3.asset.AssetKey)) and cloned it for use.Thread-Safe
- Specified by:
registerAssetClonein interfaceAssetCache- Type Parameters:
T- The type of the asset to register.- Parameters:
key- The asset key of the loaded asset (used to retrieve from cache)clone- The clone of the asset retrieved from the cache.
-
notifyNoAssetClone
public void notifyNoAssetClone()Description copied from interface:AssetCacheNotifies the cache that even though the methodsAssetCache.addToCache(com.jme3.asset.AssetKey, java.lang.Object)orAssetCache.getFromCache(com.jme3.asset.AssetKey)were used, there won't be a call toAssetCache.registerAssetClone(com.jme3.asset.AssetKey, java.lang.Object)for some reason. For example, if an error occurred during loading or if the addToCache/getFromCache were used from user code.- Specified by:
notifyNoAssetClonein interfaceAssetCache
-
getFromCache
Description copied from interface:AssetCacheRetrieves an asset from the cache. It is possible to add an asset to the cache usingAssetCache.addToCache(com.jme3.asset.AssetKey, java.lang.Object). The asset may be removed from the cache automatically even if it was added previously, in that case, this method will return null.Thread-Safe
- Specified by:
getFromCachein interfaceAssetCache- Type Parameters:
T- The type of the asset to retrieve- Parameters:
key- The key used to look up the asset.- Returns:
- The asset that was previously cached, or null if not found.
-
deleteFromCache
Description copied from interface:AssetCacheDeletes an asset from the cache.Thread-Safe
- Specified by:
deleteFromCachein interfaceAssetCache- Parameters:
key- The asset key to find the asset to delete.- Returns:
- True if the asset was successfully found in the cache and removed.
-
clearCache
public void clearCache()Description copied from interface:AssetCacheDeletes all assets from the cache.Thread-Safe
- Specified by:
clearCachein interfaceAssetCache
-