OGRE 14.3
Object-Oriented Graphics Rendering Engine
|
Represents a layer which is rendered on top of the 'normal' scene contents. More...
#include <OgreOverlay.h>
Public Types | |
typedef std::list< OverlayContainer * > | OverlayContainerList |
Public Member Functions | |
Overlay (const String &name) | |
Constructor: do not call direct, use OverlayManager::create. | |
virtual | ~Overlay () |
virtual void | _findVisibleObjects (Camera *cam, RenderQueue *queue, Viewport *vp) |
Internal method to put the overlay contents onto the render queue. | |
void | _getWorldTransforms (Matrix4 *xform) const |
Used to transform the overlay when scrolling, scaling etc. | |
void | _notifyOrigin (const String &origin) |
Notify this overlay of it's origin. | |
void | add2D (OverlayContainer *cont) |
Adds a 2D 'container' to the overlay. | |
void | add3D (SceneNode *node) |
Adds a node capable of holding 3D objects to the overlay. | |
void | clear () |
Clears the overlay of all attached items. | |
virtual OverlayElement * | findElementAt (Real x, Real y) |
This returns a OverlayElement at position x,y. | |
const OverlayContainerList & | get2DElements () const |
Returns all 2D elements in this manager. | |
OverlayContainer * | getChild (const String &name) |
const String & | getName (void) const |
Gets the name of this overlay. | |
const String & | getOrigin (void) const |
Get the origin of this overlay, e.g. | |
const Radian & | getRotate (void) const |
Gets the rotation applied to this overlay, in degrees. | |
Real | getScaleX (void) const |
Gets the current X scale value. | |
Real | getScaleY (void) const |
Gets the current Y scale value. | |
Real | getScrollX (void) const |
Gets the current X scroll value. | |
Real | getScrollY (void) const |
Gets the current Y scroll value. | |
ushort | getZOrder (void) const |
Gets the Z-order of this overlay. | |
void | hide (void) |
Hides the overlay if it was visible. | |
bool | isInitialised (void) const |
Gets whether the overlay is initialised or not. | |
bool | isVisible (void) const |
Gets whether the overlay is displayed or not. | |
void | remove2D (OverlayContainer *cont) |
Removes a 2D container from the overlay. | |
void | remove3D (SceneNode *node) |
Removes a 3D element from the overlay. | |
void | rotate (const Radian &angle) |
Adds the passed in angle to the rotation applied to this overlay. | |
void | scroll (Real xoff, Real yoff) |
Scrolls the overlay by the offsets provided. | |
void | setRotate (const Radian &angle) |
Sets the rotation applied to this overlay. | |
void | setScale (Real x, Real y) |
Sets the scaling factor of this overlay. | |
void | setScroll (Real x, Real y) |
Sets the scrolling factor of this overlay. | |
void | setVisible (bool visible) |
Shows or hides this overlay. | |
void | setZOrder (ushort zorder) |
Alters the Z-order of this overlay. | |
void | show (void) |
Shows the overlay if it was hidden. | |
Represents a layer which is rendered on top of the 'normal' scene contents.
An overlay is a container for visual components (2D and 3D) which will be rendered after the main scene in order to composite heads-up-displays, menus or other layers on top of the contents of the scene.
Constructor: do not call direct, use OverlayManager::create.
|
virtual |
OverlayContainer * Ogre::Overlay::getChild | ( | const String & | name | ) |
Alters the Z-order of this overlay.
Values between 0 and 650 are valid here.
Gets whether the overlay is initialised or not.
void Ogre::Overlay::add2D | ( | OverlayContainer * | cont | ) |
Adds a 2D 'container' to the overlay.
Containers are created and managed using the OverlayManager. A container could be as simple as a square panel, or something more complex like a grid or tree view. Containers group collections of other elements, giving them a relative coordinate space and a common z-order. If you want to attach a GUI widget to an overlay, you have to do it via a container.
cont | Pointer to a container to add, created using OverlayManager. |
void Ogre::Overlay::remove2D | ( | OverlayContainer * | cont | ) |
Removes a 2D container from the overlay.
NOT FAST. Consider OverlayElement::hide.
Adds a node capable of holding 3D objects to the overlay.
Although overlays are traditionally associated with 2D elements, there are reasons why you might want to attach 3D elements to the overlay too. For example, if you wanted to have a 3D cockpit, which was overlaid with a HUD, then you would create 2 overlays, one with a 3D object attached for the cockpit, and one with the HUD elements attached (the zorder of the HUD overlay would be higher than the cockpit to ensure it was always on top).
A SceneNode can have any number of 3D objects attached to it. SceneNodes are usually created using SceneManager::createSceneNode, but in this case you should create a standard SceneNode instance manually; this is because these scene nodes are not managed by the SceneManager and some custom SceneManager plugins will rely on specialist behaviour the overlay does not support. By attaching a SceneNode to an overlay, you indicate that:
One major consideration when using 3D objects in overlays is the behaviour of the depth buffer. Overlays should use materials with depth checking off, to ensure that their contents are always displayed on top of the main scene (to do otherwise would result in objects 'poking through' the overlay). The problem with using 3D objects is that if they are concave, or self-overlap, then you can get artefacts because of the lack of depth buffer checking. So you should ensure that any 3D objects you us in the overlay are convex, and don't overlap each other. If they must overlap, split them up and put them in 2 overlays. Alternatively, use a 2D element underneath them which will clear the depth buffer values underneath ready for the 3D element to be rendered correctly.
void Ogre::Overlay::clear | ( | ) |
Clears the overlay of all attached items.
Sets the scrolling factor of this overlay.
You can use this to set an offset to be used to scroll an overlay around the screen.
x | Horizontal scroll value, where 0 = normal, -0.5 = scroll so that only the right half the screen is visible etc |
y | Vertical scroll value, where 0 = normal, 0.5 = scroll down by half a screen etc. |
Scrolls the overlay by the offsets provided.
This method moves the overlay by the amounts provided. As with other methods on this object, a full screen width / height is represented by the value 1.0.
Gets the rotation applied to this overlay, in degrees.
Adds the passed in angle to the rotation applied to this overlay.
Sets the scaling factor of this overlay.
You can use this to set an scale factor to be used to zoom an overlay.
x | Horizontal scale value, where 1.0 = normal, 0.5 = half size etc |
y | Vertical scale value, where 1.0 = normal, 0.5 = half size etc |
Used to transform the overlay when scrolling, scaling etc.
|
virtual |
Internal method to put the overlay contents onto the render queue.
Reimplemented in Ogre::ImGuiOverlay.
|
virtual |
This returns a OverlayElement at position x,y.
|
inline |
Returns all 2D elements in this manager.
Get the origin of this overlay, e.g.
a script file name.
This property will only contain something if the creator of this overlay chose to populate it. Script loaders are advised to populate it.
Notify this overlay of it's origin.