Introduction

After animating some property in Blender using keyframes you can edit their corresponding curves. When something is “animated”, it changes over time. This curve is shown as something called an F-curve. Basically what an F-curve does is an interpolation between two animated properties. In Blender, animating an object means changing one of its properties, such as the object’s location, or its scale.

As mentioned, Blender’s fundamental unit of time is the “frame”, which usually lasts just a fraction of a second, depending on the frame rate of the scene. As animation is composed of incremental changes spanning multiple frames, usually these properties are not manually modified frame-by-frame, because:

  • It would take ages!

  • It would be very difficult to get smooth variations of the property (unless you compute mathematical functions and type a precise value for each frame, which would be crazy).

This is why nearly all direct animation is done using interpolation.

The idea is simple: you define a few Keyframes, which are multiple frames apart. Between these keyframes, the properties’ values are computed (interpolated) by Blender and filled in. Thus, the animators’ workload is significantly reduced.

../../../_images/editors_graph-editor_fcurves_introduction_f-curves-concept.png

Example of an interpolation.

For example, if you have:

  • A control point of value 0 at frame 0,

  • another one of value 10 at frame 25,

  • and you use linear interpolation, then, at frame 5 we get a value of 2.

The same goes for all intermediate frames: with just two points, you get a smooth increase from (0 to 10) along the 25 frames. Obviously, if you would like the frame 15 to have a value of 9, you would have to add another control point (or keyframe)…

Direction of Time

Although F-curves are very similar to Bézier, there are some important differences.

For obvious reasons, a property represented by a curve cannot have more than one value at a given time, hence:

  • When you move a control point ahead of a control point that was previously ahead of the point that you are moving, the two control points switch their order in the edited curve, to avoid the curve going back in time.

  • For the above reason, it is impossible to have a closed F-curve.

Two control points switching: the curve cannot go back in time!
../../../_images/editors_graph-editor_fcurves_introduction_moving1.png

Before moving the second keyframe.

../../../_images/editors_graph-editor_fcurves_introduction_moving2.png

After moving the second keyframe.

Settings

F-Curves have three additional properties, which control the interpolation between points, extension behavior, and the type of handles.

Interpolation Mode

Reference

Menu

Key ‣ Interpolation Mode

Shortcut

T

Mode for the Interpolation between the current and next keyframe.

Interpolation

Constant

There is no interpolation at all. The curve holds the value of its last keyframe, giving a discrete (stairway) “curve”. Usually only used during the initial “blocking” stage in pose-to-pose animation workflows.

../../../_images/editors_graph-editor_fcurves_introduction_constant.png

Constant.

Linear

This simple interpolation creates a straight segment, giving a non-continuous line. It can be useful when using only two keyframes and the Extrapolation extend mode, to easily get an infinite straight line (i.e. a linear curve).

../../../_images/editors_graph-editor_fcurves_introduction_linear.png

Linear.

Bézier

The more powerful and useful interpolation, and the default one. It gives nicely smoothed curves, i.e. smooth animations!

../../../_images/editors_graph-editor_fcurves_editing_clean1.png

Bézier.

Note

Remember that some F-curves can only take discrete values, in which case they are always shown as if constant interpolated, whatever option you chose.

Easing (by strength)

Different methods of easing interpolations for F-curve segment. The “Robert Penner easing equations” (basically, equations which define some preset ways that one keyframe transitions to another) which reduce the amount of manual work (inserting and tweaking keyframes) to achieve certain common effects. For example, snappy movements.

  • Linear

  • Sinusoidal

  • Quadratic

  • Cubic

  • Quartic

  • Quintic

  • Exponential

  • Circular

See also

For more info and a few live demos, see https://easings.net and http://www.robertpenner.com/easing/

Dynamic Effects

These additional easing types imitate (fake) physics-based effects like bouncing/springing effects. The corresponding settings can be found in the Sidebar region ‣ Active Keyframe panel.

Elastic

Exponentially decaying sine wave, like an elastic band. This is like bending a stiff pole stuck to some surface, and watching it rebound and settle back to its original state.

Amplitude

The amplitude property controls how strongly the oscillation diverges from the basic curve. At 0.0, there is no oscillation (i.e. it just snaps to the B-value like an extreme exponential transition), and at 1.0 a profile similar to the one shown in the icon occurs.

Period

The period property controls the frequency with which oscillations occur. Higher values result in denser oscillations.

Bounce

Exponentially decaying parabolic bounce, like when objects collide. e.g. for Bouncing balls, etc.

Back

Cubic easing with overshoot and settle. Use this one when you want a bit of an overshoot coming into the next keyframe, or perhaps for some wind-up anticipation.

Back

The back property controls the size and direction (i.e. above/below the curve) of the overshoot.

Easing Type

Reference

Menu

Key ‣ Easing Type

Shortcut

Ctrl-E

The Easing Type controls which end of the segment between the two keyframes that the easing effects apply to.

Automatic Easing

The most commonly expected of the below behaviors is used. For the transitional effects, this is basically ease in, while for the physics effects it is ease out.

Ease In

Effect builds up to the second keyframe.

Ease Out

Effect fades out from the first keyframe.

Ease In Out

Effect occurs on both ends of the segment.

Extrapolation Mode

Reference

Menu

Channel ‣ Extrapolation Mode

Shortcut

Shift-E

Extrapolation defines the behavior of a curve before the first and after the last keyframes.

There are two basic extrapolation modes:

Constant

The default one, curves before their first keyframe and after their last one have a constant value (the one of these first and last keyframes).

../../../_images/editors_graph-editor_fcurves_introduction_extrapolate1.png

Constant extrapolation.

Linear

Curves ends are straight lines (linear), as defined by the slope of their first and last keyframes.

../../../_images/editors_graph-editor_fcurves_introduction_extrapolate2.png

Linear extrapolation.

Additional extrapolation methods (e.g. the Cycles modifier) are located in the F-Curve Modifiers.

Handle Type

Reference

Menu

Key ‣ Handle Type

Shortcut

V

When using Bézier-interpolated curves it is possible to control the slope of the curve at the control points. This is done via the curve point handles; you can set the type of handle to use for the curve points by pressing V or choosing Key, Handle Type in the Graph editor menu. Each curve point can have a different handle type, even within the same curve.

There are three automatic modes, Automatic, Auto Clamped, and Vector, where Blender automatically determines the curve’s slope at each control point. The neighboring control points have the most influence of the slope, and points further away have a smaller influence. This can be controlled per F-curve with the Auto Handle Smoothing properties.

By using the other, non-automatic modes, you have full manual control over the slope.

Automatic

Handle positions are automatically chosen to produce smooth curves.

../../../_images/editors_graph-editor_fcurves_introduction_auto.png

Auto handles.

Auto Clamped

Automatic handles clamped to prevent overshoots and changes in the curve direction between keyframes (S-shapes).

../../../_images/editors_graph-editor_fcurves_introduction_autoclamped.png

Auto clamped handles.

Vector

Creates automatic linear interpolation between keyframes. The segments remain linear when keyframe centers are moved. However, when the handles are moved, the handle type switches to Free.

../../../_images/editors_graph-editor_fcurves_introduction_vector.png

Vector handles.

Aligned

The two handles of the curve point are locked together to always point in exactly opposite directions. This results in a curve that is always smooth at the control point.

../../../_images/editors_graph-editor_fcurves_introduction_aligned.png

Aligned handles.

Free

The handles can be moved completely independently, and thus can result in a sharp change of direction.

../../../_images/editors_graph-editor_fcurves_introduction_free.png

Free handles.