TimelineDegreesTrack
Entity → TimelineTrack → ceramic.TimelineDegreesTrack (Class)
A specialized timeline track for animating rotation values in degrees.
TimelineDegreesTrack handles the complexities of angular interpolation, automatically choosing the shortest path between angles. For example, animating from 350° to 10° will rotate 20° clockwise, not 340° counter-clockwise.
Key features:
- Automatic angle normalization (0-360 range)
- Shortest path interpolation (never more than 180°)
- Smooth transitions across the 0°/360° boundary
- Support for all standard easing functions
Common uses:
- Object rotation animations
- Compass/direction indicators
- Circular UI elements
- Any property representing angular values
Example usage:
var track = new TimelineDegreesTrack();
// Rotate from 0° to 270° (will go clockwise)
track.add(new TimelineFloatKeyframe(0, 0, LINEAR));
track.add(new TimelineFloatKeyframe(270, 30, EASE_IN_OUT));
// Then to 45° (will take shortest path: 270° -> 360° -> 45°)
track.add(new TimelineFloatKeyframe(45, 60, EASE_OUT));
track.onChange(this, t -> {
    myObject.rotation = t.value;
});
timeline.add(track);Instance Members
value: FloatThe current interpolated angle in degrees. Always normalized to the 0-360 range. Updated automatically as the timeline plays. Default is 0.0.
Apply the current timeline position to update the angle value.
Performs smart angular interpolation:
- Normalizes all angles to 0-360 range
- Chooses the shortest rotation path (max 180°)
- Handles wrapping across the 0°/360° boundary
- Applies easing to the interpolated value
For example:
- 350° to 10° animates as 350° -> 360° -> 10° (20° total)
- 10° to 350° animates as 10° -> 0° -> 350° (-20° total)
| Name | Type | Default | Description | 
|---|---|---|---|
| forceChange | Bool | false | If true, triggers the change event even if value hasn't changed | 
new(): VoidPrivate Members
emitChange(track: TimelineDegreesTrack): VoidEvent triggered when the degree value changes. Fired whenever the interpolated angle is different from the previous frame.
| Name | Type | Description | 
|---|---|---|
| track | TimelineDegreesTrack | This track instance (for convenience in handlers) | 
Metadata
| Name | Parameters | 
|---|---|
| :build | tracker.macros.EventsMacro.build() | 
| :autoBuild | tracker.macros.EventsMacro.build() | 
| :build | ceramic.macros.EntityMacro.buildForCompletion() | 
| :autoBuild | ceramic.macros.EntityMacro.buildForCompletion() |