|  | OGRE
    1.10.12
    Object-Oriented Graphics Rendering Engine | 
Specialisation of HardwareBuffer for D3D11. More...
#include <OgreD3D11HardwareUniformBuffer.h>
 Inheritance diagram for Ogre::D3D11HardwareUniformBuffer:
 Inheritance diagram for Ogre::D3D11HardwareUniformBuffer:| Public Types | |
| enum | LockOptions { HBL_NORMAL, HBL_DISCARD, HBL_READ_ONLY, HBL_NO_OVERWRITE, HBL_WRITE_ONLY } | 
| Locking options.  More... | |
| enum | UploadOptions { HBU_DEFAULT = 0x0000, HBU_ON_DEMAND = 0x0001 } | 
| Device load options The following enum is used to controls how data is loaded to devices in a multi device environment This enum only works with the Direct3D 9 render system (5/2013).  More... | |
| enum | Usage { HBU_STATIC = 1, HBU_DYNAMIC = 2, HBU_WRITE_ONLY = 4, HBU_DISCARDABLE = 8, HBU_STATIC_WRITE_ONLY = HBU_STATIC | HBU_WRITE_ONLY, HBU_DYNAMIC_WRITE_ONLY = HBU_DYNAMIC | HBU_WRITE_ONLY, HBU_DYNAMIC_WRITE_ONLY_DISCARDABLE = HBU_DYNAMIC_WRITE_ONLY | HBU_DISCARDABLE } | 
| Enums describing buffer usage; not mutually exclusive.  More... | |
| Public Member Functions | |
| D3D11HardwareUniformBuffer (HardwareBufferManagerBase *mgr, size_t sizeBytes, HardwareBuffer::Usage usage, bool useShadowBuffer, const String &name, D3D11Device &device) | |
| ~D3D11HardwareUniformBuffer () | |
| virtual void | _updateFromShadow (void) | 
| Updates the real buffer from the shadow buffer, if required.  More... | |
| void | copyData (HardwareBuffer &srcBuffer, size_t srcOffset, size_t dstOffset, size_t length, bool discardWholeBuffer=false) | 
| Copy data from another buffer into this one.  More... | |
| virtual void | copyData (HardwareBuffer &srcBuffer) | 
| Copy all data from another buffer into this one.  More... | |
| ID3D11Buffer * | getD3DConstantBuffer (void) const | 
| Get the D3D-specific vertex buffer.  More... | |
| HardwareBufferManagerBase * | getManager () const | 
| Return the manager of this buffer, if any.  More... | |
| const String & | getName () const | 
| size_t | getSizeInBytes (void) const | 
| Returns the size of this buffer in bytes.  More... | |
| Usage | getUsage (void) const | 
| Returns the Usage flags with which this buffer was created.  More... | |
| bool | hasShadowBuffer (void) const | 
| Returns whether this buffer has a system memory shadow for quicker reading.  More... | |
| bool | isLocked (void) const | 
| bool | isSystemMemory (void) const | 
| Returns whether this buffer is held in system memory.  More... | |
| void * | lock (size_t offset, size_t length, LockOptions options, UploadOptions uploadOpt=HBU_DEFAULT) | 
| Lock the buffer for (potentially) reading / writing.  More... | |
| void * | lock (LockOptions options, UploadOptions uploadOpt=HBU_DEFAULT) | 
| void | readData (size_t offset, size_t length, void *pDest) | 
| Reads data from the buffer and places it in the memory pointed to by pDest.  More... | |
| void | suppressHardwareUpdate (bool suppress) | 
| Pass true to suppress hardware upload of shadow buffer changes.  More... | |
| void | unlock (void) | 
| Releases the lock on this buffer.  More... | |
| void | writeData (size_t offset, size_t length, const void *pSource, bool discardWholeBuffer=false) | 
| Writes data to the buffer from an area of system memory; note that you must ensure that your buffer is big enough.  More... | |
Specialisation of HardwareBuffer for D3D11.
| 
 | inherited | 
Enums describing buffer usage; not mutually exclusive.
| 
 | inherited | 
Locking options.
| 
 | inherited | 
Device load options The following enum is used to controls how data is loaded to devices in a multi device environment This enum only works with the Direct3D 9 render system (5/2013).
| Enumerator | |
|---|---|
| HBU_DEFAULT | |
| HBU_ON_DEMAND | |
| Ogre::D3D11HardwareUniformBuffer::D3D11HardwareUniformBuffer | ( | HardwareBufferManagerBase * | mgr, | 
| size_t | sizeBytes, | ||
| HardwareBuffer::Usage | usage, | ||
| bool | useShadowBuffer, | ||
| const String & | name, | ||
| D3D11Device & | device | ||
| ) | 
| Ogre::D3D11HardwareUniformBuffer::~D3D11HardwareUniformBuffer | ( | ) | 
| 
 | virtual | 
Lock the buffer for (potentially) reading / writing.
| offset | The byte offset from the start of the buffer to lock | 
| length | The size of the area to lock, in bytes | 
| options | Locking options | 
| uploadOpt | 
Reimplemented from Ogre::HardwareBuffer.
| 
 | virtual | 
Releases the lock on this buffer.
Reimplemented from Ogre::HardwareBuffer.
| 
 | virtual | 
Reads data from the buffer and places it in the memory pointed to by pDest.
| offset | The byte offset from the start of the buffer to read | 
| length | The size of the area to read, in bytes | 
| pDest | The area of memory in which to place the data, must be large enough to accommodate the data! | 
Implements Ogre::HardwareBuffer.
| 
 | virtual | 
Writes data to the buffer from an area of system memory; note that you must ensure that your buffer is big enough.
| offset | The byte offset from the start of the buffer to start writing | 
| length | The size of the data to write to, in bytes | 
| pSource | The source of the data to be written | 
| discardWholeBuffer | If true, this allows the driver to discard the entire buffer when writing, such that DMA stalls can be avoided; use if you can. | 
Implements Ogre::HardwareBuffer.
| 
 | virtual | 
Copy data from another buffer into this one.
| srcBuffer | The buffer from which to read the copied data | 
| srcOffset | Offset in the source buffer at which to start reading | 
| dstOffset | Offset in the destination buffer to start writing | 
| length | Length of the data to copy, in bytes. | 
| discardWholeBuffer | If true, will discard the entire contents of this buffer before copying | 
Reimplemented from Ogre::HardwareBuffer.
| bool Ogre::D3D11HardwareUniformBuffer::isLocked | ( | void | ) | const | 
| ID3D11Buffer* Ogre::D3D11HardwareUniformBuffer::getD3DConstantBuffer | ( | void | ) | const | 
Get the D3D-specific vertex buffer.
| 
 | inlineinherited | 
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
| 
 | inlinevirtualinherited | 
Copy all data from another buffer into this one.
References Ogre::HardwareBuffer::getSizeInBytes().
| 
 | inlinevirtualinherited | 
Updates the real buffer from the shadow buffer, if required.
Reimplemented in Ogre::D3D11HardwareBuffer, Ogre::GLES2HardwareVertexBuffer, Ogre::GLES2HardwareIndexBuffer, Ogre::GL3PlusHardwareVertexBuffer, Ogre::GL3PlusHardwareIndexBuffer, Ogre::GLHardwareVertexBuffer, and Ogre::GLHardwareIndexBuffer.
| 
 | inlineinherited | 
Returns the size of this buffer in bytes.
Referenced by Ogre::HardwareBuffer::copyData().
| 
 | inlineinherited | 
Returns the Usage flags with which this buffer was created.
Referenced by Ogre::Lod0Stripifier::~Lod0Stripifier().
| 
 | inlineinherited | 
Returns whether this buffer is held in system memory.
| 
 | inlineinherited | 
Returns whether this buffer has a system memory shadow for quicker reading.
Referenced by Ogre::Lod0Stripifier::~Lod0Stripifier().
| 
 | inlineinherited | 
Pass true to suppress hardware upload of shadow buffer changes.