Feel  4.3
The best way to improve your game's feel and make it extra juicy
MoreMountains.Feedbacks.MMCameraFieldOfViewShaker Class Reference

Add this to a camera and it'll let you control its field of view over time, can be piloted by a MMFeedbackCameraFieldOfView More...

Inheritance diagram for MoreMountains.Feedbacks.MMCameraFieldOfViewShaker:
MoreMountains.Feedbacks.MMShaker MoreMountains.Tools.MMMonoBehaviour

Public Member Functions

virtual void OnMMCameraFieldOfViewShakeEvent (AnimationCurve distortionCurve, float duration, float remapMin, float remapMax, bool relativeDistortion=false, float feedbacksIntensity=1.0f, MMChannelData channelData=null, bool resetShakerValuesAfterShake=true, bool resetTargetValuesAfterShake=true, bool forwardDirection=true, TimescaleModes timescaleMode=TimescaleModes.Scaled, bool stop=false, bool restore=false)
 When we get the appropriate event, we trigger a shake More...
 
override void StartListening ()
 Starts listening for events More...
 
override void StopListening ()
 Stops listening for events More...
 
- Public Member Functions inherited from MoreMountains.Feedbacks.MMShaker
virtual float GetTime ()
 
virtual float GetDeltaTime ()
 
virtual void ForceInitialization ()
 Call this externally if you need to force a new initialization More...
 
virtual void StartShaking ()
 Starts shaking the values More...
 
virtual void Play ()
 Starts this shaker More...
 
virtual void Stop ()
 Stops this shaker More...
 
virtual float ComputeRangeIntensity (bool useRange, float rangeDistance, bool useRangeFalloff, AnimationCurve rangeFalloff, Vector2 remapRangeFalloff, Vector3 rangePosition)
 

Public Attributes

bool RelativeFieldOfView = false
 whether or not to add to the initial value More...
 
AnimationCurve ShakeFieldOfView = new AnimationCurve(new Keyframe(0, 0), new Keyframe(0.5f, 1), new Keyframe(1, 0))
 the curve used to animate the intensity value on More...
 
float RemapFieldOfViewZero = 60f
 the value to remap the curve's 0 to More...
 
float RemapFieldOfViewOne = 120f
 the value to remap the curve's 1 to More...
 
- Public Attributes inherited from MoreMountains.Feedbacks.MMShaker
MMChannelModes ChannelMode = MMChannelModes.Int
 
int Channel = 0
 the channel to listen to - has to match the one on the feedback More...
 
MMChannel MMChannelDefinition = null
 
float ShakeDuration = 0.2f
 the duration of the shake, in seconds More...
 
bool PlayOnAwake = false
 if this is true this shaker will play on awake More...
 
bool PermanentShake = false
 if this is true, the shaker will shake permanently as long as its game object is active More...
 
bool Interruptible = true
 if this is true, a new shake can happen while shaking More...
 
bool AlwaysResetTargetValuesAfterShake = false
 if this is true, this shaker will always reset target values, regardless of how it was called More...
 
bool OnlyUseShakerValues = false
 if this is true, this shaker will ignore any value passed in an event that triggered it, and will instead use the values set on its inspector More...
 
float CooldownBetweenShakes = 0f
 a cooldown, in seconds, after a shake, during which no other shake can start More...
 
bool Shaking = false
 whether or not this shaker is shaking right now More...
 
bool ForwardDirection = true
 
TimescaleModes TimescaleMode = TimescaleModes.Scaled
 
virtual MMChannelData ChannelData => new MMChannelData(ChannelMode, Channel, MMChannelDefinition)
 
virtual bool ListeningToEvents => _listeningToEvents
 

Protected Member Functions

override void Initialization ()
 On init we initialize our values More...
 
virtual void Reset ()
 When that shaker gets added, we initialize its shake duration More...
 
override void Shake ()
 Shakes values over time More...
 
override void GrabInitialValues ()
 Collects initial values on the target More...
 
override void ResetTargetValues ()
 Resets the target's values More...
 
override void ResetShakerValues ()
 Resets the shaker's values More...
 
- Protected Member Functions inherited from MoreMountains.Feedbacks.MMShaker
virtual void Awake ()
 On Awake we grab our volume and profile More...
 
virtual void ShakeStarts ()
 Describes what happens when a shake starts More...
 
virtual void Update ()
 On Update, we shake our values if needed, or reset if our shake has ended More...
 
virtual float ShakeFloat (AnimationCurve curve, float remapMin, float remapMax, bool relativeIntensity, float initialValue)
 A method used to "shake" a flot over time along a curve More...
 
virtual Color ShakeGradient (Gradient gradient)
 
virtual void ShakeComplete ()
 Describes what happens when the shake is complete More...
 
virtual void OnEnable ()
 On enable we start shaking if needed More...
 
virtual void OnDestroy ()
 On destroy we stop listening for events More...
 
virtual void OnDisable ()
 On disable we complete our shake if it was in progress More...
 
virtual bool CheckEventAllowed (MMChannelData channelData, bool useRange=false, float range=0f, Vector3 eventOriginPosition=default(Vector3))
 Returns true if this shaker should listen to events, false otherwise More...
 

Protected Attributes

Camera _targetCamera
 
float _initialFieldOfView
 
float _originalShakeDuration
 
bool _originalRelativeFieldOfView
 
AnimationCurve _originalShakeFieldOfView
 
float _originalRemapFieldOfViewZero
 
float _originalRemapFieldOfViewOne
 
- Protected Attributes inherited from MoreMountains.Feedbacks.MMShaker
float _shakeStartedTimestamp = -Single.MaxValue
 
float _remappedTimeSinceStart
 
bool _resetShakerValuesAfterShake
 
bool _resetTargetValuesAfterShake
 
float _journey
 

Detailed Description

Add this to a camera and it'll let you control its field of view over time, can be piloted by a MMFeedbackCameraFieldOfView

Member Function Documentation

◆ GrabInitialValues()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.GrabInitialValues ( )
protectedvirtual

Collects initial values on the target

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ Initialization()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.Initialization ( )
protectedvirtual

On init we initialize our values

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ OnMMCameraFieldOfViewShakeEvent()

virtual void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.OnMMCameraFieldOfViewShakeEvent ( AnimationCurve  distortionCurve,
float  duration,
float  remapMin,
float  remapMax,
bool  relativeDistortion = false,
float  feedbacksIntensity = 1.0f,
MMChannelData  channelData = null,
bool  resetShakerValuesAfterShake = true,
bool  resetTargetValuesAfterShake = true,
bool  forwardDirection = true,
TimescaleModes  timescaleMode = TimescaleModes.Scaled,
bool  stop = false,
bool  restore = false 
)
virtual

When we get the appropriate event, we trigger a shake

Parameters
distortionCurve
duration
amplitude
relativeDistortion
feedbacksIntensity
channel

◆ Reset()

virtual void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.Reset ( )
protectedvirtual

When that shaker gets added, we initialize its shake duration

◆ ResetShakerValues()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.ResetShakerValues ( )
protectedvirtual

Resets the shaker's values

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ ResetTargetValues()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.ResetTargetValues ( )
protectedvirtual

Resets the target's values

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ Shake()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.Shake ( )
protectedvirtual

Shakes values over time

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ StartListening()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.StartListening ( )
virtual

Starts listening for events

Reimplemented from MoreMountains.Feedbacks.MMShaker.

◆ StopListening()

override void MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.StopListening ( )
virtual

Stops listening for events

Reimplemented from MoreMountains.Feedbacks.MMShaker.

Member Data Documentation

◆ _initialFieldOfView

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._initialFieldOfView
protected

◆ _originalRelativeFieldOfView

bool MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._originalRelativeFieldOfView
protected

◆ _originalRemapFieldOfViewOne

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._originalRemapFieldOfViewOne
protected

◆ _originalRemapFieldOfViewZero

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._originalRemapFieldOfViewZero
protected

◆ _originalShakeDuration

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._originalShakeDuration
protected

◆ _originalShakeFieldOfView

AnimationCurve MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._originalShakeFieldOfView
protected

◆ _targetCamera

Camera MoreMountains.Feedbacks.MMCameraFieldOfViewShaker._targetCamera
protected

◆ RelativeFieldOfView

bool MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.RelativeFieldOfView = false

whether or not to add to the initial value

◆ RemapFieldOfViewOne

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.RemapFieldOfViewOne = 120f

the value to remap the curve's 1 to

◆ RemapFieldOfViewZero

float MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.RemapFieldOfViewZero = 60f

the value to remap the curve's 0 to

◆ ShakeFieldOfView

AnimationCurve MoreMountains.Feedbacks.MMCameraFieldOfViewShaker.ShakeFieldOfView = new AnimationCurve(new Keyframe(0, 0), new Keyframe(0.5f, 1), new Keyframe(1, 0))

the curve used to animate the intensity value on


The documentation for this class was generated from the following file: