Ion
|
A Sampler object represents texture parameters that control how texture data is accessed in shaders. More...
#include "sampler.h"
Public Types | |
enum | Changes { kAutoMipmappingChanged = kNumBaseChanges, kCompareFunctionChanged, kCompareModeChanged, kMagFilterChanged, kMaxAnisotropyChanged, kMaxLodChanged, kMinFilterChanged, kMinLodChanged, kWrapRChanged, kWrapSChanged, kWrapTChanged, kNumChanges } |
Changes that affect this resource. More... | |
enum | CompareFunction { kAlways, kEqual, kGreater, kGreaterOrEqual, kLess, kLessOrEqual, kNever, kNotEqual } |
Texture comparison functions for depth textures. More... | |
enum | CompareMode { kCompareToTexture, kNone } |
Texture comparison modes for depth textures. More... | |
enum | FilterMode { kNearest, kLinear, kNearestMipmapNearest, kNearestMipmapLinear, kLinearMipmapNearest, kLinearMipmapLinear } |
Texture filter modes. More... | |
enum | WrapMode { kClampToEdge, kRepeat, kMirroredRepeat } |
Texture filter modes. More... | |
enum | BaseChanges { kLabelChanged, kResourceChanged, kNumBaseChanges } |
All ResourceHolders derived from this should start their own change enums from kNumBaseChanges. More... | |
Public Member Functions | |
Sampler () | |
void | SetAutogenerateMipmapsEnabled (bool enable) |
Sets whether OpenGL should automatically generate mipmaps for this Sampler. More... | |
bool | IsAutogenerateMipmapsEnabled () const |
Gets whether this Sampler should use mipmapping. The default is false. More... | |
void | SetCompareMode (CompareMode mode) |
Sets/returns the comparison mode to use for the texture using this sampler. More... | |
CompareMode | GetCompareMode () const |
void | SetCompareFunction (CompareFunction func) |
Sets/returns the comparison function to use when texture comparison is enabled, e.g., when this is used with a depth texture. More... | |
CompareFunction | GetCompareFunction () const |
void | SetMaxAnisotropy (float aniso) |
Sets the maximum degree of anisotropy used when filtering textures. More... | |
float | GetMaxAnisotropy () const |
Gets the maximum anisotropy parameter. The default is 1. More... | |
void | SetMinFilter (const FilterMode &mode) |
Sets the minification mode. More... | |
FilterMode | GetMinFilter () const |
Gets the minification mode. The default is kNearest. More... | |
void | SetMagFilter (const FilterMode &mode) |
Sets the magnification mode. More... | |
FilterMode | GetMagFilter () const |
Gets the magnification mode. The default is kNearest. More... | |
void | SetMinLod (float lod) |
Sets the minimum level of detail parameter, which limits the selection of the highest resolution (lowest level) mipmap. More... | |
float | GetMinLod () const |
Gets the minimum level of detail parameter. The default is -1000. More... | |
void | SetMaxLod (float lod) |
Sets the maximum level of detail parameter, which limits the selection of the lowest resolution (highest level) mipmap. More... | |
float | GetMaxLod () const |
Gets the maximum level of detail parameter. The default is 1000. More... | |
void | SetWrapR (const WrapMode &mode) |
Sets the wrap along the r-coordinate (useful only for 3D textures). More... | |
WrapMode | GetWrapR () const |
Gets the wrap along the r-coordinate. The default is kRepeat. More... | |
void | SetWrapS (const WrapMode &mode) |
Sets the wrap along the s-coordinate. More... | |
WrapMode | GetWrapS () const |
Gets the wrap along the s-coordinate. The default is kRepeat. More... | |
void | SetWrapT (const WrapMode &mode) |
Sets the wrap along the t-coordinate. More... | |
WrapMode | GetWrapT () const |
Gets the wrap along the t-coordinate. The default is kRepeat. More... | |
void | SetResource (size_t index, ResourceKey key, ResourceBase *resource) const |
Sets the resource at the passed index and key. More... | |
ResourceBase * | GetResource (size_t index, ResourceKey key) const |
Returns the Resource at the given index and key, or NULL if no resource was previously set at that location. More... | |
int | GetResourceCount () const |
Returns the number of resources that this holder holds. More... | |
size_t | GetGpuMemoryUsed () const |
Returns the total amount of GPU memory used by this Holder's resource. More... | |
const std::string & | GetLabel () const |
Returns/sets the label of this. More... | |
void | SetLabel (const std::string &label) |
void | AddReceiver (Notifier *receiver) |
Adds a Notifier to be notified. More... | |
void | RemoveReceiver (Notifier *receiver) |
Removes a Notifier to be notified. More... | |
size_t | GetReceiverCount () const |
Returns the number of Notifiers that will be notified. More... | |
const AllocatorPtr & | GetAllocator () const |
Returns the Allocator that was used for the instance. More... | |
const AllocatorPtr & | GetNonNullAllocator () const |
Return our allocator, or the default allocator if the instance was declared on the stack. More... | |
const AllocatorPtr & | GetAllocatorForLifetime (AllocationLifetime lifetime) const |
Convenience function that returns the Allocator to use to allocate an object with a specific lifetime. More... | |
void * | operator new (size_t size) |
The standard no-parameter new operator uses the default Allocator. More... | |
void * | operator new (size_t size, AllocationLifetime lifetime) |
This overloaded version of the new operator uses the AllocationManager's default Allocator for the specified lifetime. More... | |
void * | operator new (size_t size, const AllocatorPtr &allocator) |
This overloaded version of the new operator takes the Allocator to use directly as a parameter. More... | |
void * | operator new (size_t size, const AllocatorPtr &allocator, void *ptr) |
Special operator new for using placement new with Allocatables. More... | |
void * | operator new (size_t size, void *ptr) |
The placement new operator is defined conventionally. More... | |
void | operator delete (void *ptr) |
Define the delete operator to use specialized functions dealing with an Allocator. More... | |
void | operator delete (void *ptr, AllocationLifetime lifetime) |
Windows requires these (or it issues C4291 warnings). More... | |
void | operator delete (void *ptr, const AllocatorPtr &allocator) |
void | operator delete (void *ptr, void *ptr2) |
The placement delete operator does nothing, as usual. More... | |
int | GetRefCount () const |
GetRefCount() is part of the interface necessary for SharedPtr. More... | |
Protected Types | |
typedef WeakReferentPtr< Notifier > | NotifierPtr |
typedef AllocVector< NotifierPtr > | NotifierPtrVector |
Protected Member Functions | |
~Sampler () override | |
The destructor is protected because all base::Referent classes must have protected or private destructors. More... | |
void | OnChanged (int bit) const |
Forwards OnChanged to all resources. More... | |
const NotifierPtrVector & | GetReceivers () const |
Returns the set of Notifiers that will be notified. More... | |
void | Notify () const |
Notifies all contained Notifiers by calling their OnNotify(). More... | |
virtual void | OnNotify (const Notifier *notifier) |
Subclasses can override this to provide custom behavior on notifications. More... | |
A Sampler object represents texture parameters that control how texture data is accessed in shaders.
|
protectedinherited |
Definition at line 49 of file notifier.h.
|
protectedinherited |
Definition at line 50 of file notifier.h.
|
inherited |
All ResourceHolders derived from this should start their own change enums from kNumBaseChanges.
Enumerator | |
---|---|
kLabelChanged | |
kResourceChanged | |
kNumBaseChanges |
Definition at line 56 of file resourceholder.h.
ion::gfx::Sampler::Sampler | ( | ) |
Definition at line 27 of file sampler.cc.
|
overrideprotected |
The destructor is protected because all base::Referent classes must have protected or private destructors.
Definition at line 42 of file sampler.cc.
|
inherited |
Adds a Notifier to be notified.
Does nothing if the receiver is NULL or is already in the receiver vector.
Definition at line 25 of file notifier.cc.
|
inlineinherited |
Returns the Allocator that was used for the instance.
This will be NULL if the instance was declared on the stack or created with normal placement new.
Definition at line 68 of file allocatable.h.
References allocator_.
Referenced by ion::base::DataContainer::CreateAndCopy(), ion::text::DynamicFontImage::FindContainingImageDataIndex(), and ion::text::DynamicFontImage::FindImageDataIndex().
|
inlineinherited |
Convenience function that returns the Allocator to use to allocate an object with a specific lifetime.
Definition at line 78 of file allocatable.h.
References ion::base::Allocator::GetAllocatorForLifetime().
Referenced by ion::text::BasicBuilder::BuildVertexData(), ion::text::OutlineBuilder::BuildVertexData(), ion::gfxutils::ShaderManager::CreateShaderProgram(), ion::text::DynamicFontImage::FindContainingImageDataIndex(), ion::text::DynamicFontImage::FindImageDataIndex(), ion::gfx::Renderer::Renderer(), and ion::gfx::UpdateStateTable().
|
inline |
|
inline |
|
inlineinherited |
Returns the total amount of GPU memory used by this Holder's resource.
Definition at line 78 of file resourceholder.h.
|
inlineinherited |
Returns/sets the label of this.
Definition at line 89 of file resourceholder.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inlineinherited |
Return our allocator, or the default allocator if the instance was declared on the stack.
Definition at line 72 of file allocatable.h.
References allocator_, and ion::base::AllocationManager::GetNonNullAllocator().
|
inherited |
Returns the number of Notifiers that will be notified.
Definition at line 71 of file notifier.cc.
|
protectedinherited |
Returns the set of Notifiers that will be notified.
Definition at line 77 of file notifier.cc.
|
inlineinherited |
GetRefCount() is part of the interface necessary for SharedPtr.
Definition at line 34 of file shareable.h.
Referenced by ion::base::Notifier::RemoveReceiver().
|
inherited |
Returns the Resource at the given index and key, or NULL if no resource was previously set at that location.
Definition at line 122 of file resourceholder.cc.
|
inlineinherited |
Returns the number of resources that this holder holds.
Note that this is not necessarily the number of indices that have non-NULL resources. This can be used as a fast trivial check to see if the holder has any resources.
Definition at line 73 of file resourceholder.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
protectedinherited |
Notifies all contained Notifiers by calling their OnNotify().
Any receivers that have been destroyed will be removed from the vector of receivers.
Definition at line 81 of file notifier.cc.
References ion::base::SharedPtr< T >::Get().
|
inlineprotectedinherited |
Forwards OnChanged to all resources.
Definition at line 326 of file resourceholder.h.
|
protectedvirtualinherited |
Subclasses can override this to provide custom behavior on notifications.
Definition at line 96 of file notifier.cc.
|
inlineinherited |
Define the delete operator to use specialized functions dealing with an Allocator.
Definition at line 109 of file allocatable.h.
|
inlineinherited |
Windows requires these (or it issues C4291 warnings).
Definition at line 112 of file allocatable.h.
|
inlineinherited |
Definition at line 113 of file allocatable.h.
|
inlineinherited |
The placement delete operator does nothing, as usual.
Definition at line 118 of file allocatable.h.
|
inlineinherited |
The standard no-parameter new operator uses the default Allocator.
Definition at line 84 of file allocatable.h.
|
inlineinherited |
This overloaded version of the new operator uses the AllocationManager's default Allocator for the specified lifetime.
Definition at line 88 of file allocatable.h.
|
inlineinherited |
This overloaded version of the new operator takes the Allocator to use directly as a parameter.
If the Allocator pointer is NULL, this uses the default Allocator.
Definition at line 95 of file allocatable.h.
|
inlineinherited |
Special operator new for using placement new with Allocatables.
Definition at line 100 of file allocatable.h.
|
inlineinherited |
The placement new operator is defined conventionally.
Definition at line 105 of file allocatable.h.
|
inherited |
Removes a Notifier to be notified.
Does nothing if the receiver is NULL or not in the set of receivers.
Definition at line 38 of file notifier.cc.
References ion::base::Shareable::GetRefCount().
Referenced by ion::gfx::AttributeArray::~AttributeArray().
|
inline |
|
inline |
|
inline |
|
inlineinherited |
Definition at line 90 of file resourceholder.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inherited |
Sets the resource at the passed index and key.
The size of the internal vector is automatically managed so that it has the smallest possible size.
Definition at line 51 of file resourceholder.cc.
References DCHECK, DCHECK_EQ, ion::gfx::ResourceBase::GetKey(), and ion::gfx::ResourceBase::OnChanged().
|
inline |
|
inline |
|
inline |