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

This feedback will let you animate the scale of the target object over time, with a spring effect More...

Inheritance diagram for MoreMountains.Feedbacks.MMF_ScaleSpring:
MoreMountains.Feedbacks.MMF_Feedback

Public Types

enum  Modes { Modes.MoveTo, Modes.MoveToAdditive, Modes.Bump }
 

Public Attributes

override bool HasAutomatedTargetAcquisition => true
 sets the inspector color for this feedback More...
 
override bool CanForceInitialValue => true
 
override bool HasRandomness => true
 
Transform AnimateScaleTarget
 the object to animate More...
 
float DeclaredDuration = 0f
 spring duration is determined by the spring (and could be impacted real time), so it's up to you to determine how long this feedback should last, from the point of view of its parent MMF Player More...
 
float DampingX = 0.4f
 the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly More...
 
float FrequencyX = 6f
 the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second More...
 
float DampingY = 0.4f
 the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly More...
 
float FrequencyY = 6f
 the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second More...
 
float DampingZ = 0.4f
 the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly More...
 
float FrequencyZ = 6f
 the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second More...
 
Modes Mode = Modes.Bump
 the chosen mode for this spring. MoveTo will move the target the specified scale (randomized between min and max). MoveToAdditive will add the specified scale (randomized between min and max) to the target's current scale. Bump will bump the target's scale by the specified power (randomized between min and max) More...
 
Vector3 MoveToScaleMin = new Vector3(1f, 1f, 1f)
 the min value from which to pick a random target value when in MoveTo or MoveToAdditive modes More...
 
Vector3 MoveToScaleMax = new Vector3(2f, 2f, 2f)
 the max value from which to pick a random target value when in MoveTo or MoveToAdditive modes More...
 
Vector3 BumpScaleMin = new Vector3(20f, 20f, 20f)
 the min value from which to pick a random bump amount when in Bump mode More...
 
Vector3 BumpScaleMax = new Vector3(30f, 30f, 30f)
 the max value from which to pick a random bump amount when in Bump mode More...
 

Static Public Attributes

static bool FeedbackTypeAuthorized = true
 a static bool used to disable all feedbacks of this type at once More...
 

Protected Member Functions

override void AutomateTargetAcquisition ()
 A method meant to be implemented per feedback letting you specify what happens (usually setting a target) More...
 
override void CustomInitialization (MMF_Player owner)
 On init we store our initial scale More...
 
virtual void GetInitialValues ()
 Stores initial scale for future use More...
 
override void CustomPlayFeedback (Vector3 position, float feedbacksIntensity=1.0f)
 On Play, triggers the scale animation More...
 
virtual IEnumerator Spring ()
 a coroutine running on the Owner used to move the spring More...
 
virtual void UpdateSpring ()
 Updates the spring's values More...
 
virtual void ApplyValue ()
 Applies the current spring value to the target More...
 
override void CustomStopFeedback (Vector3 position, float feedbacksIntensity=1.0f)
 On stop, we interrupt movement if it was active More...
 
override void CustomSkipToTheEnd (Vector3 position, float feedbacksIntensity=1.0f)
 Skips to the end, matching the target value More...
 
override void CustomRestoreInitialValues ()
 On restore, we restore our initial state More...
 

Protected Attributes

Vector3 _currentValue = Vector3.zero
 
Vector3 _targetValue = Vector3.zero
 
Vector3 _velocity = Vector3.zero
 
Vector3 _initialScale
 
virtual bool LowVelocity => (Mathf.Abs(_velocity.x) + Mathf.Abs(_velocity.y) + Mathf.Abs(_velocity.z)) < _velocityLowThreshold
 
Coroutine _coroutine
 
float _velocityLowThreshold = 0.001f
 
Vector3 _newScale
 

Properties

override float FeedbackDuration [get, set]
 the duration of this feedback is the duration of the scale animation More...
 

Additional Inherited Members

Detailed Description

This feedback will let you animate the scale of the target object over time, with a spring effect

Member Enumeration Documentation

◆ Modes

Enumerator
MoveTo 
MoveToAdditive 
Bump 

Member Function Documentation

◆ ApplyValue()

virtual void MoreMountains.Feedbacks.MMF_ScaleSpring.ApplyValue ( )
protectedvirtual

Applies the current spring value to the target

◆ AutomateTargetAcquisition()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.AutomateTargetAcquisition ( )
protectedvirtual

A method meant to be implemented per feedback letting you specify what happens (usually setting a target)

Reimplemented from MoreMountains.Feedbacks.MMF_Feedback.

◆ CustomInitialization()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.CustomInitialization ( MMF_Player  owner)
protectedvirtual

On init we store our initial scale

Parameters
owner

Reimplemented from MoreMountains.Feedbacks.MMF_Feedback.

◆ CustomPlayFeedback()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.CustomPlayFeedback ( Vector3  position,
float  feedbacksIntensity = 1.0f 
)
protectedvirtual

On Play, triggers the scale animation

Parameters
position
feedbacksIntensity

Implements MoreMountains.Feedbacks.MMF_Feedback.

◆ CustomRestoreInitialValues()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.CustomRestoreInitialValues ( )
protectedvirtual

On restore, we restore our initial state

Reimplemented from MoreMountains.Feedbacks.MMF_Feedback.

◆ CustomSkipToTheEnd()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.CustomSkipToTheEnd ( Vector3  position,
float  feedbacksIntensity = 1.0f 
)
protectedvirtual

Skips to the end, matching the target value

Parameters
position
feedbacksIntensity

Reimplemented from MoreMountains.Feedbacks.MMF_Feedback.

◆ CustomStopFeedback()

override void MoreMountains.Feedbacks.MMF_ScaleSpring.CustomStopFeedback ( Vector3  position,
float  feedbacksIntensity = 1.0f 
)
protectedvirtual

On stop, we interrupt movement if it was active

Parameters
position
feedbacksIntensity

Reimplemented from MoreMountains.Feedbacks.MMF_Feedback.

◆ GetInitialValues()

virtual void MoreMountains.Feedbacks.MMF_ScaleSpring.GetInitialValues ( )
protectedvirtual

Stores initial scale for future use

◆ Spring()

virtual IEnumerator MoreMountains.Feedbacks.MMF_ScaleSpring.Spring ( )
protectedvirtual

a coroutine running on the Owner used to move the spring

Returns

◆ UpdateSpring()

virtual void MoreMountains.Feedbacks.MMF_ScaleSpring.UpdateSpring ( )
protectedvirtual

Updates the spring's values

Member Data Documentation

◆ _coroutine

Coroutine MoreMountains.Feedbacks.MMF_ScaleSpring._coroutine
protected

◆ _currentValue

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring._currentValue = Vector3.zero
protected

◆ _initialScale

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring._initialScale
protected

◆ _newScale

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring._newScale
protected

◆ _targetValue

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring._targetValue = Vector3.zero
protected

◆ _velocity

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring._velocity = Vector3.zero
protected

◆ _velocityLowThreshold

float MoreMountains.Feedbacks.MMF_ScaleSpring._velocityLowThreshold = 0.001f
protected

◆ AnimateScaleTarget

Transform MoreMountains.Feedbacks.MMF_ScaleSpring.AnimateScaleTarget

the object to animate

◆ BumpScaleMax

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring.BumpScaleMax = new Vector3(30f, 30f, 30f)

the max value from which to pick a random bump amount when in Bump mode

◆ BumpScaleMin

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring.BumpScaleMin = new Vector3(20f, 20f, 20f)

the min value from which to pick a random bump amount when in Bump mode

◆ CanForceInitialValue

override bool MoreMountains.Feedbacks.MMF_ScaleSpring.CanForceInitialValue => true

◆ DampingX

float MoreMountains.Feedbacks.MMF_ScaleSpring.DampingX = 0.4f

the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly

◆ DampingY

float MoreMountains.Feedbacks.MMF_ScaleSpring.DampingY = 0.4f

the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly

◆ DampingZ

float MoreMountains.Feedbacks.MMF_ScaleSpring.DampingZ = 0.4f

the dumping ratio determines how fast the spring will evolve after a disturbance. At a low value, it'll oscillate for a long time, while closer to 1 it'll stop oscillating quickly

◆ DeclaredDuration

float MoreMountains.Feedbacks.MMF_ScaleSpring.DeclaredDuration = 0f

spring duration is determined by the spring (and could be impacted real time), so it's up to you to determine how long this feedback should last, from the point of view of its parent MMF Player

◆ FeedbackTypeAuthorized

bool MoreMountains.Feedbacks.MMF_ScaleSpring.FeedbackTypeAuthorized = true
static

a static bool used to disable all feedbacks of this type at once

◆ FrequencyX

float MoreMountains.Feedbacks.MMF_ScaleSpring.FrequencyX = 6f

the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second

◆ FrequencyY

float MoreMountains.Feedbacks.MMF_ScaleSpring.FrequencyY = 6f

the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second

◆ FrequencyZ

float MoreMountains.Feedbacks.MMF_ScaleSpring.FrequencyZ = 6f

the frequency determines how fast the spring will oscillate when disturbed, low frequency means less oscillations per second, high frequency means more oscillations per second

◆ HasAutomatedTargetAcquisition

override bool MoreMountains.Feedbacks.MMF_ScaleSpring.HasAutomatedTargetAcquisition => true

sets the inspector color for this feedback

◆ HasRandomness

override bool MoreMountains.Feedbacks.MMF_ScaleSpring.HasRandomness => true

◆ LowVelocity

virtual bool MoreMountains.Feedbacks.MMF_ScaleSpring.LowVelocity => (Mathf.Abs(_velocity.x) + Mathf.Abs(_velocity.y) + Mathf.Abs(_velocity.z)) < _velocityLowThreshold
protected

◆ Mode

Modes MoreMountains.Feedbacks.MMF_ScaleSpring.Mode = Modes.Bump

the chosen mode for this spring. MoveTo will move the target the specified scale (randomized between min and max). MoveToAdditive will add the specified scale (randomized between min and max) to the target's current scale. Bump will bump the target's scale by the specified power (randomized between min and max)

◆ MoveToScaleMax

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring.MoveToScaleMax = new Vector3(2f, 2f, 2f)

the max value from which to pick a random target value when in MoveTo or MoveToAdditive modes

◆ MoveToScaleMin

Vector3 MoreMountains.Feedbacks.MMF_ScaleSpring.MoveToScaleMin = new Vector3(1f, 1f, 1f)

the min value from which to pick a random target value when in MoveTo or MoveToAdditive modes

Property Documentation

◆ FeedbackDuration

override float MoreMountains.Feedbacks.MMF_ScaleSpring.FeedbackDuration
getset

the duration of this feedback is the duration of the scale animation


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