Urho3D::Camera Class Reference
Public Member Functions |
Static Public Member Functions |
Protected Member Functions |
Private Member Functions |
Private Attributes |
List of all members
Urho3D::Camera Class Reference
Camera component. More...
#include <Urho3D/Graphics/Camera.h>
Inheritance diagram for Urho3D::Camera:
Collaboration diagram for Urho3D::Camera:
Public Member Functions | |
Camera (Context *context) | |
Construct. | |
virtual | ~Camera () |
Destruct. | |
virtual void | DrawDebugGeometry (DebugRenderer *debug, bool depthTest) |
Visualize the component as debug geometry. | |
void | SetNearClip (float nearClip) |
Set near clip distance. | |
void | SetFarClip (float farClip) |
Set far clip distance. | |
void | SetFov (float fov) |
Set vertical field of view in degrees. | |
void | SetOrthoSize (float orthoSize) |
Set orthographic mode view uniform size. | |
void | SetOrthoSize (const Vector2 &orthoSize) |
Set orthographic mode view non-uniform size. Disables the auto aspect ratio -mode. | |
void | SetAspectRatio (float aspectRatio) |
Set aspect ratio manually. Disables the auto aspect ratio -mode. | |
void | SetFillMode (FillMode mode) |
Set polygon fill mode to use when rendering a scene. | |
void | SetZoom (float zoom) |
Set zoom. | |
void | SetLodBias (float bias) |
Set LOD bias. | |
void | SetViewMask (unsigned mask) |
Set view mask. Will be and'ed with object's view mask to see if the object should be rendered. | |
void | SetViewOverrideFlags (unsigned flags) |
Set view override flags. | |
void | SetOrthographic (bool enable) |
Set orthographic mode enabled/disabled. | |
void | SetAutoAspectRatio (bool enable) |
Set automatic aspect ratio based on viewport dimensions. Enabled by default. | |
void | SetProjectionOffset (const Vector2 &offset) |
Set projection offset. It needs to be calculated as (offset in pixels) / (viewport dimensions.) | |
void | SetUseReflection (bool enable) |
Set reflection mode. | |
void | SetReflectionPlane (const Plane &plane) |
Set reflection plane in world space for reflection mode. | |
void | SetUseClipping (bool enable) |
Set whether to use a custom clip plane. | |
void | SetClipPlane (const Plane &plane) |
Set custom clipping plane in world space. | |
void | SetFlipVertical (bool enable) |
Set vertical flipping mode. Called internally by View to resolve OpenGL / Direct3D9 rendertarget sampling differences. | |
float | GetFarClip () const |
Return far clip distance. | |
float | GetNearClip () const |
Return near clip distance. | |
float | GetFov () const |
Return vertical field of view in degrees. | |
float | GetOrthoSize () const |
Return orthographic mode size. | |
float | GetAspectRatio () const |
Return aspect ratio. | |
float | GetZoom () const |
Return zoom. | |
float | GetLodBias () const |
Return LOD bias. | |
unsigned | GetViewMask () const |
Return view mask. | |
unsigned | GetViewOverrideFlags () const |
Return view override flags. | |
FillMode | GetFillMode () const |
Return fill mode. | |
bool | IsOrthographic () const |
Return orthographic flag. | |
bool | GetAutoAspectRatio () const |
Return auto aspect ratio flag. | |
const Frustum & | GetFrustum () const |
Return frustum in world space. | |
const Matrix4 & | GetProjection () const |
Return API-specific projection matrix. | |
Matrix4 | GetProjection (bool apiSpecific) const |
Return either API-specific or API-independent (D3D convention) projection matrix. | |
const Matrix3x4 & | GetView () const |
Return view matrix. | |
void | GetFrustumSize (Vector3 &near, Vector3 &far) const |
Return frustum near and far sizes. | |
float | GetHalfViewSize () const |
Return half view size. | |
Frustum | GetSplitFrustum (float nearClip, float farClip) const |
Return frustum split by custom near and far clip distances. | |
Frustum | GetViewSpaceFrustum () const |
Return frustum in view space. | |
Frustum | GetViewSpaceSplitFrustum (float nearClip, float farClip) const |
Return split frustum in view space. | |
Ray | GetScreenRay (float x, float y) const |
Return ray corresponding to normalized screen coordinates (0.0 - 1.0), with origin on the near clip plane. | |
Vector2 | WorldToScreenPoint (const Vector3 &worldPos) const |
Convert a world space point to normalized screen coordinates (0.0 - 1.0). | |
Vector3 | ScreenToWorldPoint (const Vector3 &screenPos) const |
Convert normalized screen coordinates (0.0 - 1.0) and distance along view Z axis (in Z coordinate) to a world space point. The distance can not be closer than the near clip plane. More... | |
const Vector2 & | GetProjectionOffset () const |
Return projection offset. | |
bool | GetUseReflection () const |
Return whether is using reflection. | |
const Plane & | GetReflectionPlane () const |
Return the reflection plane. | |
bool | GetUseClipping () const |
Return whether is using a custom clipping plane. | |
const Plane & | GetClipPlane () const |
Return the custom clipping plane. | |
bool | GetFlipVertical () const |
Return vertical flipping mode. | |
bool | GetReverseCulling () const |
Return whether to reverse culling; affected by vertical flipping and reflection. | |
float | GetDistance (const Vector3 &worldPos) const |
Return distance to position. In orthographic mode uses only Z coordinate. | |
float | GetDistanceSquared (const Vector3 &worldPos) const |
Return squared distance to position. In orthographic mode uses only Z coordinate. | |
float | GetLodDistance (float distance, float scale, float bias) const |
Return a scene node's LOD scaled distance. | |
Quaternion | GetFaceCameraRotation (const Vector3 &position, const Quaternion &rotation, FaceCameraMode mode) |
Return a world rotation for facing a camera on certain axes based on the existing world rotation. | |
Matrix3x4 | GetEffectiveWorldTransform () const |
Get effective world transform for matrix and frustum calculations including reflection but excluding node scaling. | |
bool | IsProjectionValid () const |
Return if projection parameters are valid for rendering and raycasting. | |
void | SetAspectRatioInternal (float aspectRatio) |
Set aspect ratio without disabling the "auto aspect ratio" mode. Called internally by View. | |
void | SetOrthoSizeAttr (float orthoSize) |
Set orthographic size attribute without forcing the aspect ratio. | |
void | SetReflectionPlaneAttr (const Vector4 &value) |
Set reflection plane attribute. | |
Vector4 | GetReflectionPlaneAttr () const |
Return reflection plane attribute. | |
void | SetClipPlaneAttr (const Vector4 &value) |
Set clipping plane attribute. | |
Vector4 | GetClipPlaneAttr () const |
Return clipping plane attribute. | |
Public Member Functions inherited from Urho3D::Component | |
Component (Context *context) | |
Construct. | |
virtual | ~Component () |
Destruct. | |
virtual void | OnSetEnabled () |
Handle enabled/disabled state change. | |
virtual bool | Save (Serializer &dest) const |
Save as binary data. Return true if successful. | |
virtual bool | SaveXML (XMLElement &dest) const |
Save as XML data. Return true if successful. | |
virtual bool | SaveJSON (JSONValue &dest) const |
Save as JSON data. Return true if successful. | |
virtual void | MarkNetworkUpdate () |
Mark for attribute check on the next network update. | |
virtual void | GetDependencyNodes (PODVector< Node * > &dest) |
Return the depended on nodes to order network updates. | |
void | SetEnabled (bool enable) |
Set enabled/disabled state. | |
void | Remove () |
Remove from the scene node. If no other shared pointer references exist, causes immediate deletion. | |
unsigned | GetID () const |
Return ID. | |
Node * | GetNode () const |
Return scene node. | |
Scene * | GetScene () const |
Return the scene the node belongs to. | |
bool | IsEnabled () const |
Return whether is enabled. | |
bool | IsEnabledEffective () const |
Return whether is effectively enabled (node is also enabled.) | |
Component * | GetComponent (StringHash type) const |
Return component in the same scene node by type. If there are several, returns the first. | |
void | GetComponents (PODVector< Component * > &dest, StringHash type) const |
Return components in the same scene node by type. | |
template<class T > | |
T * | GetComponent () const |
Template version of returning a component in the same scene node by type. | |
template<class T > | |
void | GetComponents (PODVector< T * > &dest) const |
Template version of returning components in the same scene node by type. | |
void | AddReplicationState (ComponentReplicationState *state) |
Add a replication state that is tracking this component. | |
void | PrepareNetworkUpdate () |
Prepare network update by comparing attributes and marking replication states dirty as necessary. | |
void | CleanupConnection (Connection *connection) |
Clean up all references to a network connection that is about to be removed. | |
Public Member Functions inherited from Urho3D::Animatable | |
Animatable (Context *context) | |
Construct. | |
virtual | ~Animatable () |
Destruct. | |
virtual bool | LoadXML (const XMLElement &source, bool setInstanceDefault=false) |
Load from XML data. When setInstanceDefault is set to true, after setting the attribute value, store the value as instance's default value. Return true if successful. | |
virtual bool | LoadJSON (const JSONValue &source, bool setInstanceDefault=false) |
Load from JSON data. When setInstanceDefault is set to true, after setting the attribute value, store the value as instance's default value. Return true if successful. | |
void | SetAnimationEnabled (bool enable) |
Set automatic update of animation, default true. | |
void | SetAnimationTime (float time) |
Set time position of all attribute animations or an object animation manually. Automatic update should be disabled in this case. | |
void | SetObjectAnimation (ObjectAnimation *objectAnimation) |
Set object animation. | |
void | SetAttributeAnimation (const String &name, ValueAnimation *attributeAnimation, WrapMode wrapMode=WM_LOOP, float speed=1.0f) |
Set attribute animation. | |
void | SetAttributeAnimationWrapMode (const String &name, WrapMode wrapMode) |
Set attribute animation wrap mode. | |
void | SetAttributeAnimationSpeed (const String &name, float speed) |
Set attribute animation speed. | |
void | SetAttributeAnimationTime (const String &name, float time) |
Set attribute animation time position manually. Automatic update should be disabled in this case. | |
void | RemoveObjectAnimation () |
Remove object animation. Same as calling SetObjectAnimation with a null pointer. | |
void | RemoveAttributeAnimation (const String &name) |
Remove attribute animation. Same as calling SetAttributeAnimation with a null pointer. | |
bool | GetAnimationEnabled () const |
Return animation enabled. | |
ObjectAnimation * | GetObjectAnimation () const |
Return object animation. | |
ValueAnimation * | GetAttributeAnimation (const String &name) const |
Return attribute animation. | |
WrapMode | GetAttributeAnimationWrapMode (const String &name) const |
Return attribute animation wrap mode. | |
float | GetAttributeAnimationSpeed (const String &name) const |
Return attribute animation speed. | |
float | GetAttributeAnimationTime (const String &name) const |
Return attribute animation time position. | |
void | SetObjectAnimationAttr (const ResourceRef &value) |
Set object animation attribute. | |
ResourceRef | GetObjectAnimationAttr () const |
Return object animation attribute. | |
Public Member Functions inherited from Urho3D::Serializable | |
Serializable (Context *context) | |
Construct. | |
virtual | ~Serializable () |
Destruct. | |
virtual void | OnSetAttribute (const AttributeInfo &attr, const Variant &src) |
Handle attribute write access. Default implementation writes to the variable at offset, or invokes the set accessor. | |
virtual void | OnGetAttribute (const AttributeInfo &attr, Variant &dest) const |
Handle attribute read access. Default implementation reads the variable at offset, or invokes the get accessor. | |
virtual const Vector < AttributeInfo > * | GetAttributes () const |
Return attribute descriptions, or null if none defined. | |
virtual const Vector < AttributeInfo > * | GetNetworkAttributes () const |
Return network replication attribute descriptions, or null if none defined. | |
virtual bool | Load (Deserializer &source, bool setInstanceDefault=false) |
Load from binary data. When setInstanceDefault is set to true, after setting the attribute value, store the value as instance's default value. Return true if successful. | |
virtual void | ApplyAttributes () |
Apply attribute changes that can not be applied immediately. Called after scene load or a network update. | |
virtual bool | SaveDefaultAttributes () const |
Return whether should save default-valued attributes into XML. Default false. | |
bool | SetAttribute (unsigned index, const Variant &value) |
Set attribute by index. Return true if successfully set. | |
bool | SetAttribute (const String &name, const Variant &value) |
Set attribute by name. Return true if successfully set. | |
void | ResetToDefault () |
Reset all editable attributes to their default values. | |
void | RemoveInstanceDefault () |
Remove instance's default values if they are set previously. | |
void | SetTemporary (bool enable) |
Set temporary flag. Temporary objects will not be saved. | |
void | SetInterceptNetworkUpdate (const String &attributeName, bool enable) |
Enable interception of an attribute from network updates. Intercepted attributes are sent as events instead of applying directly. This can be used to implement client side prediction. | |
void | AllocateNetworkState () |
Allocate network attribute state. | |
void | WriteInitialDeltaUpdate (Serializer &dest, unsigned char timeStamp) |
Write initial delta network update. | |
void | WriteDeltaUpdate (Serializer &dest, const DirtyBits &attributeBits, unsigned char timeStamp) |
Write a delta network update according to dirty attribute bits. | |
void | WriteLatestDataUpdate (Serializer &dest, unsigned char timeStamp) |
Write a latest data network update. | |
bool | ReadDeltaUpdate (Deserializer &source) |
Read and apply a network delta update. Return true if attributes were changed. | |
bool | ReadLatestDataUpdate (Deserializer &source) |
Read and apply a network latest data update. Return true if attributes were changed. | |
Variant | GetAttribute (unsigned index) const |
Return attribute value by index. Return empty if illegal index. | |
Variant | GetAttribute (const String &name) const |
Return attribute value by name. Return empty if not found. | |
Variant | GetAttributeDefault (unsigned index) const |
Return attribute default value by index. Return empty if illegal index. | |
Variant | GetAttributeDefault (const String &name) const |
Return attribute default value by name. Return empty if not found. | |
unsigned | GetNumAttributes () const |
Return number of attributes. | |
unsigned | GetNumNetworkAttributes () const |
Return number of network replication attributes. | |
bool | IsTemporary () const |
Return whether is temporary. | |
bool | GetInterceptNetworkUpdate (const String &attributeName) const |
Return whether an attribute's network updates are being intercepted. | |
NetworkState * | GetNetworkState () const |
Return the network attribute state, if allocated. | |
Public Member Functions inherited from Urho3D::Object | |
Object (Context *context) | |
Construct. | |
virtual | ~Object () |
Destruct. Clean up self from event sender & receiver structures. | |
virtual StringHash | GetType () const =0 |
Return type hash. | |
virtual const String & | GetTypeName () const =0 |
Return type name. | |
virtual const TypeInfo * | GetTypeInfo () const =0 |
Return type info. | |
virtual void | OnEvent (Object *sender, StringHash eventType, VariantMap &eventData) |
Handle event. | |
bool | IsInstanceOf (StringHash type) const |
Check current instance is type of specified type. | |
bool | IsInstanceOf (const TypeInfo *typeInfo) const |
Check current instance is type of specified type. | |
template<typename T > | |
bool | IsInstanceOf () const |
Check current instance is type of specified class. | |
void | SubscribeToEvent (StringHash eventType, EventHandler *handler) |
Subscribe to an event that can be sent by any sender. | |
void | SubscribeToEvent (Object *sender, StringHash eventType, EventHandler *handler) |
Subscribe to a specific sender's event. | |
void | UnsubscribeFromEvent (StringHash eventType) |
Unsubscribe from an event. | |
void | UnsubscribeFromEvent (Object *sender, StringHash eventType) |
Unsubscribe from a specific sender's event. | |
void | UnsubscribeFromEvents (Object *sender) |
Unsubscribe from a specific sender's events. | |
void | UnsubscribeFromAllEvents () |
Unsubscribe from all events. | |
void | UnsubscribeFromAllEventsExcept (const PODVector< StringHash > &exceptions, bool onlyUserData) |
Unsubscribe from all events except those listed, and optionally only those with userdata (script registered events.) | |
void | SendEvent (StringHash eventType) |
Send event to all subscribers. | |
void | SendEvent (StringHash eventType, VariantMap &eventData) |
Send event with parameters to all subscribers. More... | |
VariantMap & | GetEventDataMap () const |
Return a preallocated map for event data. Used for optimization to avoid constant re-allocation of event data maps. | |
Context * | GetContext () const |
Return execution context. | |
const Variant & | GetGlobalVar (StringHash key) const |
Return global variable based on key. | |
const VariantMap & | GetGlobalVars () const |
Return all global variables. | |
void | SetGlobalVar (StringHash key, const Variant &value) |
Set global variable with the respective key and value. | |
Object * | GetSubsystem (StringHash type) const |
Return subsystem by type. | |
Object * | GetEventSender () const |
Return active event sender. Null outside event handling. | |
EventHandler * | GetEventHandler () const |
Return active event handler. Null outside event handling. | |
bool | HasSubscribedToEvent (StringHash eventType) const |
Return whether has subscribed to an event without specific sender. | |
bool | HasSubscribedToEvent (Object *sender, StringHash eventType) const |
Return whether has subscribed to a specific sender's event. | |
bool | HasEventHandlers () const |
Return whether has subscribed to any event. | |
template<class T > | |
T * | GetSubsystem () const |
Template version of returning a subsystem. | |
const String & | GetCategory () const |
Return object category. Categories are (optionally) registered along with the object factory. Return an empty string if the object category is not registered. | |
Public Member Functions inherited from Urho3D::RefCounted | |
RefCounted () | |
Construct. Allocate the reference count structure and set an initial self weak reference. | |
virtual | ~RefCounted () |
Destruct. Mark as expired and also delete the reference count structure if no outside weak references exist. | |
void | AddRef () |
Increment reference count. Can also be called outside of a SharedPtr for traditional reference counting. | |
void | ReleaseRef () |
Decrement reference count and delete self if no more references. Can also be called outside of a SharedPtr for traditional reference counting. | |
int | Refs () const |
Return reference count. | |
int | WeakRefs () const |
Return weak reference count. | |
RefCount * | RefCountPtr () |
Return pointer to the reference count structure. | |
Static Public Member Functions | |
static void | RegisterObject (Context *context) |
Register object factory. | |
Protected Member Functions | |
virtual void | OnNodeSet (Node *node) |
Handle node being assigned. | |
virtual void | OnMarkedDirty (Node *node) |
Handle node transform being dirtied. | |
Protected Member Functions inherited from Urho3D::Component | |
virtual void | OnAttributeAnimationAdded () |
Handle attribute animation added. | |
virtual void | OnAttributeAnimationRemoved () |
Handle attribute animation removed. | |
virtual void | OnSceneSet (Scene *scene) |
Handle scene being assigned. This may happen several times during the component's lifetime. Scene-wide subsystems and events are subscribed to here. | |
virtual void | OnNodeSetEnabled (Node *node) |
Handle scene node enabled status changing. | |
void | SetID (unsigned id) |
Set ID. Called by Scene. | |
void | SetNode (Node *node) |
Set scene node. Called by Node when creating the component. | |
void | HandleAttributeAnimationUpdate (StringHash eventType, VariantMap &eventData) |
Handle scene attribute animation update event. | |
Component * | GetFixedUpdateSource () |
Return a component from the scene root that sends out fixed update events (either PhysicsWorld or PhysicsWorld2D). Return null if neither exists. | |
Protected Member Functions inherited from Urho3D::Animatable | |
virtual Animatable * | FindAttributeAnimationTarget (const String &name, String &outName) |
Find target of an attribute animation from object hierarchy by name. | |
void | SetObjectAttributeAnimation (const String &name, ValueAnimation *attributeAnimation, WrapMode wrapMode, float speed) |
Set object attribute animation internal. | |
void | OnObjectAnimationAdded (ObjectAnimation *objectAnimation) |
Handle object animation added. | |
void | OnObjectAnimationRemoved (ObjectAnimation *objectAnimation) |
Handle object animation removed. | |
void | UpdateAttributeAnimations (float timeStep) |
Update attribute animations. | |
bool | IsAnimatedNetworkAttribute (const AttributeInfo &attrInfo) const |
Is animated network attribute. | |
AttributeAnimationInfo * | GetAttributeAnimationInfo (const String &name) const |
Return attribute animation info. | |
void | HandleAttributeAnimationAdded (StringHash eventType, VariantMap &eventData) |
Handle attribute animation added. | |
void | HandleAttributeAnimationRemoved (StringHash eventType, VariantMap &eventData) |
Handle attribute animation removed. | |
Private Member Functions | |
URHO3D_OBJECT (Camera, Component) | |
Private Attributes | |
Matrix3x4 | view_ |
Cached view matrix. | |
Matrix4 | projection_ |
Cached projection matrix. | |
Frustum | frustum_ |
Cached frustum. | |
bool | viewDirty_ |
View matrix dirty flag. | |
bool | projectionDirty_ |
Projection matrix dirty flag. | |
bool | frustumDirty_ |
Frustum dirty flag. | |
bool | orthographic_ |
Orthographic mode flag. | |
float | nearClip_ |
Near clip distance. | |
float | farClip_ |
Far clip distance. | |
float | fov_ |
Field of view. | |
float | orthoSize_ |
Orthographic view size. | |
float | aspectRatio_ |
Aspect ratio. | |
float | zoom_ |
Zoom. | |
float | lodBias_ |
LOD bias. | |
unsigned | viewMask_ |
View mask. | |
unsigned | viewOverrideFlags_ |
View override flags. | |
FillMode | fillMode_ |
Fill mode. | |
Vector2 | projectionOffset_ |
Projection offset. | |
Plane | reflectionPlane_ |
Reflection plane. | |
Plane | clipPlane_ |
Clipping plane. | |
Matrix3x4 | reflectionMatrix_ |
Reflection matrix calculated from the plane. | |
bool | autoAspectRatio_ |
Auto aspect ratio flag. | |
bool | flipVertical_ |
Flip vertical flag. | |
bool | useReflection_ |
Reflection mode enabled flag. | |
bool | useClipping_ |
Use custom clip plane flag. | |
Additional Inherited Members | |
Protected Attributes inherited from Urho3D::Component | |
Node * | node_ |
Scene node. | |
unsigned | id_ |
Unique ID within the scene. | |
bool | networkUpdate_ |
Network update queued flag. | |
bool | enabled_ |
Enabled flag. | |
Detailed Description
Camera component.
Member Function Documentation
Convert normalized screen coordinates (0.0 - 1.0) and distance along view Z axis (in Z coordinate) to a world space point. The distance can not be closer than the near clip plane.
Note that a HitDistance() from the camera screen ray is not the same as distance along the view Z axis, as under a perspective projection the ray is likely to not be Z-aligned.
Here is the call graph for this function:
The documentation for this class was generated from the following files:
- Source/Urho3D/Graphics/Camera.h
- Source/Urho3D/Graphics/Camera.cpp