mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-18 13:12:50 +00:00
235 lines
8.3 KiB
Lua
235 lines
8.3 KiB
Lua
---
|
|
-- `openmw.camera` controls camera.
|
|
-- Can be used only by player scripts.
|
|
-- @module camera
|
|
-- @usage local camera = require('openmw.camera')
|
|
|
|
---
|
|
-- Camera mode; see @{openmw.camera#MODE} for possible values
|
|
-- @type Mode
|
|
|
|
---
|
|
-- @type MODE Camera modes.
|
|
-- @field #Mode Static Camera doesn't track player; player inputs doesn't affect camera; use `setStaticPosition` to move the camera.
|
|
-- @field #Mode FirstPerson First person mode.
|
|
-- @field #Mode ThirdPerson Third person mode; player character turns to the view direction.
|
|
-- @field #Mode Vanity Similar to Preview; camera slowly moves around the player.
|
|
-- @field #Mode Preview Third person mode, but player character doesn't turn to the view direction.
|
|
|
|
---
|
|
-- Camera modes.
|
|
-- @field [parent=#camera] #MODE MODE
|
|
|
|
---
|
|
-- Return the current @{openmw.camera#MODE}.
|
|
-- @function [parent=#camera] getMode
|
|
-- @return #Mode
|
|
|
|
---
|
|
-- Return the mode the camera will switch to after the end of the current animation. Can be nil.
|
|
-- @function [parent=#camera] getQueuedMode
|
|
-- @return #Mode
|
|
|
|
---
|
|
-- Change @{openmw.camera#MODE}; if the second (optional, true by default) argument is set to false, the switching can be delayed (see `getQueuedMode`).
|
|
-- @function [parent=#camera] setMode
|
|
-- @param #Mode mode
|
|
-- @param #boolean force
|
|
|
|
---
|
|
-- If set to true then after switching from Preview to ThirdPerson the player character turns to the camera view direction. Otherwise the camera turns to the character view direction.
|
|
-- @function [parent=#camera] allowCharacterDeferredRotation
|
|
-- @param #boolean boolValue
|
|
|
|
---
|
|
-- Show/hide crosshair.
|
|
-- @function [parent=#camera] showCrosshair
|
|
-- @param #boolean boolValue
|
|
|
|
---
|
|
-- Current position of the tracked object (the characters head if there is no animation).
|
|
-- @function [parent=#camera] getTrackedPosition
|
|
-- @return openmw.util#Vector3
|
|
|
|
---
|
|
-- Current position of the camera.
|
|
-- @function [parent=#camera] getPosition
|
|
-- @return openmw.util#Vector3
|
|
|
|
---
|
|
-- Camera pitch angle (radians) without taking extraPitch into account.
|
|
-- Full pitch is `getPitch()+getExtraPitch()`.
|
|
-- @function [parent=#camera] getPitch
|
|
-- @return #number
|
|
|
|
---
|
|
-- Force the pitch angle to the given value (radians); player input on this axis is ignored in this frame.
|
|
-- @function [parent=#camera] setPitch
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Camera yaw angle (radians) without taking extraYaw into account.
|
|
-- Full yaw is `getYaw()+getExtraYaw()`.
|
|
-- @function [parent=#camera] getYaw
|
|
-- @return #number
|
|
|
|
---
|
|
-- Force the yaw angle to the given value (radians); player input on this axis is ignored in this frame.
|
|
-- @function [parent=#camera] setYaw
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Get camera roll angle (radians).
|
|
-- @function [parent=#camera] getRoll
|
|
-- @return #number
|
|
|
|
---
|
|
-- Set camera roll angle (radians).
|
|
-- @function [parent=#camera] setRoll
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Additional summand for the pitch angle that is not affected by player input.
|
|
-- Full pitch is `getPitch()+getExtraPitch()`.
|
|
-- @function [parent=#camera] getExtraPitch
|
|
-- @return #number
|
|
|
|
---
|
|
-- Additional summand for the pitch angle; useful for camera shaking effects.
|
|
-- Setting extra pitch doesn't block player input.
|
|
-- Full pitch is `getPitch()+getExtraPitch()`.
|
|
-- @function [parent=#camera] setExtraPitch
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Additional summand for the yaw angle that is not affected by player input.
|
|
-- Full yaw is `getYaw()+getExtraYaw()`.
|
|
-- @function [parent=#camera] getExtraYaw
|
|
-- @return #number
|
|
|
|
---
|
|
-- Additional summand for the yaw angle; useful for camera shaking effects.
|
|
-- Setting extra pitch doesn't block player input.
|
|
-- Full yaw is `getYaw()+getExtraYaw()`.
|
|
-- @function [parent=#camera] setExtraYaw
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Additional summand for the roll angle that is not affected by player input.
|
|
-- Full yaw is `getRoll()+getExtraRoll()`.
|
|
-- @function [parent=#camera] getExtraRoll
|
|
-- @return #number
|
|
|
|
---
|
|
-- Additional summand for the roll angle; useful for camera shaking effects.
|
|
-- Full yaw is `getRoll()+getExtraRoll()`.
|
|
-- @function [parent=#camera] setExtraRoll
|
|
-- @param #number value
|
|
|
|
---
|
|
-- Set camera position; can be used only if camera is in Static mode.
|
|
-- @function [parent=#camera] setStaticPosition
|
|
-- @param openmw.util#Vector3 pos
|
|
|
|
---
|
|
-- The offset between the characters head and the camera in first person mode (3d vector).
|
|
-- @function [parent=#camera] getFirstPersonOffset
|
|
-- @return openmw.util#Vector3
|
|
|
|
---
|
|
-- Set the offset between the characters head and the camera in first person mode (3d vector).
|
|
-- @function [parent=#camera] setFirstPersonOffset
|
|
-- @param openmw.util#Vector3 offset
|
|
|
|
---
|
|
-- Preferred offset between tracked position (see `getTrackedPosition`) and the camera focal point (the center of the screen) in third person mode.
|
|
-- See `setFocalPreferredOffset`.
|
|
-- @function [parent=#camera] getFocalPreferredOffset
|
|
-- @return openmw.util#Vector2
|
|
|
|
---
|
|
-- Set preferred offset between tracked position (see `getTrackedPosition`) and the camera focal point (the center of the screen) in third person mode.
|
|
-- The offset is a 2d vector (X, Y) where X is horizontal (to the right from the character) and Y component is vertical (upward).
|
|
-- The real offset can differ from the preferred one during smooth transition of if blocked by an obstacle.
|
|
-- Smooth transition happens by default every time when the preferred offset was changed. Use `instantTransition()` to skip the current transition.
|
|
-- @function [parent=#camera] setFocalPreferredOffset
|
|
-- @param openmw.util#Vector2 offset
|
|
|
|
---
|
|
-- The actual distance between the camera and the character in third person mode; can differ from the preferred one if there is an obstacle.
|
|
-- @function [parent=#camera] getThirdPersonDistance
|
|
-- @return #number
|
|
|
|
---
|
|
-- Set preferred distance between the camera and the character in third person mode.
|
|
-- @function [parent=#camera] setPreferredThirdPersonDistance
|
|
-- @param #number distance
|
|
|
|
---
|
|
-- The current speed coefficient of focal point (the center of the screen in third person mode) smooth transition.
|
|
-- @function [parent=#camera] getFocalTransitionSpeed
|
|
-- @return #number
|
|
|
|
---
|
|
-- Set the speed coefficient of focal point (the center of the screen in third person mode) smooth transition.
|
|
-- Smooth transition happens by default every time when the preferred offset was changed. Use `instantTransition()` to skip the current transition.
|
|
-- @function [parent=#camera] setFocalTransitionSpeed
|
|
-- Set the speed coefficient
|
|
-- @param #number speed
|
|
|
|
---
|
|
-- Make instant the current transition of camera focal point and the current deferred rotation (see `allowCharacterDeferredRotation`).
|
|
-- @function [parent=#camera] instantTransition
|
|
|
|
--- Get current camera collision type (see @{openmw.nearby#COLLISION_TYPE}).
|
|
-- @function [parent=#camera] getCollisionType
|
|
-- @return #number
|
|
|
|
--- Set camera collision type (see @{openmw.nearby#COLLISION_TYPE}).
|
|
-- @function [parent=#camera] setCollisionType
|
|
-- @param #number collisionType
|
|
|
|
--- Return base field of view vertical angle in radians
|
|
-- @function [parent=#camera] getBaseFieldOfView
|
|
-- @return #number
|
|
|
|
--- Return current field of view vertical angle in radians
|
|
-- @function [parent=#camera] getFieldOfView
|
|
-- @return #number
|
|
|
|
--- Set field of view
|
|
-- @function [parent=#camera] setFieldOfView
|
|
-- @param #number fov Field of view vertical angle in radians
|
|
|
|
--- Return base view distance.
|
|
-- @function [parent=#camera] getBaseViewDistance
|
|
-- @return #number
|
|
|
|
--- Return current view distance.
|
|
-- @function [parent=#camera] getViewDistance
|
|
-- @return #number
|
|
|
|
--- Set view distance.
|
|
--- Takes effect on the next frame.
|
|
-- @function [parent=#camera] setViewDistance
|
|
-- @param #number distance View distance in game units
|
|
|
|
--- Get world to local transform for the camera.
|
|
-- @function [parent=#camera] getViewTransform
|
|
-- @return openmw.util#Transform
|
|
|
|
--- Get vector from the camera to the world for the given point in viewport.
|
|
-- (0, 0) is the top left corner of the screen.
|
|
-- @function [parent=#camera] viewportToWorldVector
|
|
-- @param openmw.util#Vector2 normalizedScreenPos
|
|
-- @return openmw.util#Vector3
|
|
|
|
--- Get vector from the world to the viewport for the given point in world space.
|
|
-- (0, 0) is the top left corner of the screen.
|
|
-- The z component of the return value holds the distance from the camera to the position, in world space
|
|
-- @function [parent=#camera] worldToViewportVector
|
|
-- @param openmw.util#Vector3 worldPos
|
|
-- @return openmw.util#Vector3
|
|
|
|
return nil
|