Skip to content

A library that offers a suite of components to create engaging animations and transformations based on user interactions like mouse movements, scroll events, and even audio input.

Notifications You must be signed in to change notification settings

SpaceBlocks/Kinesis.js

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

65 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Kinesis.js

@amineyarman/kinesis is a versatile library for adding dynamic, interactive, and physics-based animations to your web components. It includes features like transforming elements based on mouse movement, scroll events, and even audio frequency data.

Installation

You can install kinesis via npm:

npm install @amineyarman/kinesis

Usage

Basic Initialization

To initialize the library, import the initializeKinesis function and call it after your DOM elements are loaded:

import { initializeKinesis } from "@amineyarman/kinesis";

document.addEventListener("DOMContentLoaded", () => {
  initializeKinesis();
});

This will automatically find and initialize all elements that use the Kinesis attributes.

Components

KinesisTransformer

The KinesisTransformer class applies transformations such as translations, rotations, or scaling to child elements based on mouse movements or scroll events.

Example

<div data-kinesistransformer data-ks-duration="1000" data-ks-perspective="800">
  <div data-kinesistransformer-element data-ks-strength="20"></div>
</div>

Attributes

Attribute Type Default Value Description
data-kinesistransformer Boolean (presence) Required Marks the element as a Kinesis Transformer container. Must be present to enable transformer effects.
data-ks-active Boolean true Enables or disables the transformer. Set to false to deactivate without removing the component.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-interaction Enum (mouse or scroll) mouse Defines the interaction mode. Use mouse for mouse movements or scroll for scroll-based interactions.
data-ks-perspective Number 1000 Sets the CSS perspective for 3D transformations in pixels.
data-ks-preserve3d Boolean true Determines whether the container should preserve 3D transformations across child elements. Set to false to disable.
data-ks-scroll-element String (CSS Selector) window (For scroll interaction) Specifies the scroll container element. Use a CSS selector to target a specific scrollable element. Defaults to window.

KinesisTransformerElement

The KinesisTransformerElement class is a child element within the KinesisTransformer container. It applies the specified transformations (e.g., translate, rotate) when the container’s interaction (mouse or scroll) is triggered.

Attributes

Attribute Type Default Value Description
data-kinesistransformer-element Boolean (presence) Required Marks the element as a transformer element. Must be present to apply transformations.
data-ks-strength Number 10 Determines the intensity of the transformation effect. Higher values result in more pronounced transformations.
data-ks-transform Enum (translate, rotate, scale, tilt, tilt_inv) translate Specifies the type of transformation to apply.
data-ks-transformaxis String X, Y (or Z for rotate) Defines the axes along which the transformation is applied. Use a comma-separated list (e.g., X, Y, Z).
data-ks-interactionaxis Enum (X, Y) or null null Restricts the interaction to a specific axis. Set to X or Y to limit transformations to that axis. If not set, interactions affect both axes.
data-ks-transformorigin String center center Sets the CSS transform-origin property, defining the point around which transformations are applied (e.g., top left, 50% 50%).

KinesisDepth

The KinesisDepth class applies 3D depth transformations to child elements based on mouse movement, making them move along the Z-axis.

Example

<div data-kinesisdepth data-ks-perspective="1200" data-ks-sensitivity="15">
  <div data-kinesisdepth-element data-ks-depth="5"></div>
</div>

Attributes

Attribute Type Default Value Description
data-kinesisdepth Boolean (presence) Required Marks the element as a Kinesis Depth container. Must be present to enable depth effects.
data-ks-active Boolean true Enables or disables the depth effects. Set to false to deactivate without removing the component.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-perspective Number 1000 Sets the CSS perspective for 3D transformations in pixels.
data-ks-sensitivity Number 40 Determines the sensitivity of rotation based on mouse position. Higher values result in more pronounced rotations.
data-ks-inverted Boolean false Inverts the direction of rotation. Set to true to reverse the rotation effects.
data-ks-throttle Number 100 Throttling duration in milliseconds for mousemove events to optimize performance. Default is 100ms.

KinesisDepthElement

A child element inside the KinesisDepth container. It moves along the Z-axis based on the depth.

Attributes

Attribute Type Default Value Description
data-kinesisdepth-element Boolean (presence) Required Marks the element as a depth-enabled child. Must be present to apply depth translations.
data-ks-depth Number 10 Determines the depth translation along the Z-axis. Higher values move the element further away from the viewer.
data-ks-transformorigin String center center Sets the CSS transform-origin property, defining the point around which transformations are applied.

KinesisAudio

Transforms elements based on audio data. Elements move or scale according to audio frequency values.

Example

<div data-kinesisaudio data-ks-audio="audiofile.mp3" data-ks-playaudio="true">
  <div data-kinesisaudio-element data-ks-strength="30"></div>
</div>

Attributes

Attribute Type Default Value Description
data-kinesisaudio Boolean (presence) Required Marks the element as a Kinesis Audio container. Must be present to enable audio-responsive effects.
data-ks-active Boolean true Enables or disables the audio effects. Set to false to deactivate without removing the component.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-perspective Number 1000 Sets the CSS perspective for 3D transformations in pixels.
data-ks-audio String (URL) Required Specifies the source URL of the audio file to be analyzed and played.
data-ks-playaudio Boolean false Determines whether the audio should play automatically. Set to true to enable auto-play.
data-ks-throttle Number 100 Throttling duration in milliseconds for mousemove events to optimize performance. Default is 100ms.

KinesisAudioElement

A child element inside the KinesisAudio container. It responds to audio frequency data to animate transformations like scaling or translation.

Attributes

Attribute Type Default Value Description
data-kinesisaudio-element Boolean (presence) Required Marks the element as an audio-responsive child. Must be present to apply audio-based transformations.
data-ks-audioindex Number 50 Specifies the frequency bin index to be used for transforming the element. Higher indices correspond to higher frequencies.
data-ks-strength Number 10 Determines the intensity of the transformation effect. Higher values result in more pronounced transformations.
data-ks-transform Enum (translate, rotate, scale) translate Specifies the type of transformation to apply based on audio data.
data-ks-transformaxis String X, Y (or Z for rotate) Defines the axes along which the transformation is applied. Use a comma-separated list (e.g., X, Y, Z).
data-ks-transformorigin String center Sets the CSS transform-origin property, defining the point around which transformations are applied (e.g., top left).

KinesisScrollItem

Transforms elements based on scroll position. Ideal for parallax effects. This is a standalone component. It doesn't need to be wrapped by one of the containers.

Example

<div
  data-kinesisscroll-item
  data-ks-transform="scale"
  data-ks-strength="15"
></div>

Attributes

Attribute Type Default Value Description
data-kinesisscroll-item Boolean (presence) Required Marks the element as a Kinesis Scroll Item. Must be present to enable scroll-based transformations.
data-ks-active Boolean true Enables or disables the scroll effects. Set to false to deactivate without removing the component.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-transform Enum (translate, rotate, scale) translate Specifies the type of transformation to apply based on scroll progress.
data-ks-transformaxis String X, Y (or Z for rotate) Defines the axes along which the transformation is applied. Use a comma-separated list (e.g., X, Y, Z).
data-ks-strength Number 10 Determines the intensity of the transformation effect. Higher values result in more pronounced transformations.
data-ks-throttle Number 100 Throttling duration in milliseconds for scroll event handling to optimize performance. Default is 100ms.

KinesisPath

Moves elements along an SVG path based on mouse movement or scroll events.

Example

<div data-kinesispath data-ks-path="M10,10 C20,20 40,20 50,10">
  <div data-kinesispath-element></div>
</div>

Attributes

Attribute Type Default Value Description
data-kinesispath Boolean (presence) Required Marks the element as a Kinesis Path container. Must be present to enable path-based animations.
data-ks-active Boolean true Enables or disables the path effects. Set to false to deactivate without removing the component.
data-ks-duration Number 800 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-path String (SVG Path Data) Required Specifies the global SVG path data that child elements will follow.
data-ks-interaction Enum (mouse or scroll) mouse Defines the interaction mode. Use mouse for mouse movements or scroll for scroll-based interactions.
data-ks-throttle Number 100 Throttling duration in milliseconds for event handling to optimize performance. Default is 100ms.

KinesisPathElement

A child element inside the KinesisPath container. It moves along the specified SVG path.

Attributes

Attribute Type Default Value Description
data-kinesispath-element Boolean (presence) Required Marks the element as a path-enabled child. Must be present to apply path-based transformations.
data-ks-strength Number 1 Determines the strength or speed of the transformation effect. Higher values result in faster or more intense movements.
data-ks-offset Number 0 Sets the initial offset distance along the path in percentage.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-transform Enum (translate, rotate, scale) translate Specifies the type of transformation to apply based on path data.
data-ks-transformaxis String X, Y (or Z for rotate) Defines the axes along which the transformation is applied. Use a comma-separated list (e.g., X, Y, Z).
data-ks-transformorigin String center Sets the CSS transform-origin property, defining the point around which transformations are applied (e.g., top left).

KinesisDistanceItem

Transforms elements based on the distance between the mouse pointer and the element. This is a standalone component. It doesn't need to be wrapped in one of the containers.

Example

<div
  data-kinesisdistance-item
  data-ks-strength="15"
  data-ks-startdistance="200"
></div>

Attributes

Attribute Type Default Value Description
data-kinesisdistance-item Boolean (presence) Required Marks the element as a Kinesis Distance item. Must be present to enable distance-based transformations.
data-ks-active Boolean true Enables or disables the distance effects. Set to false to deactivate without removing the component.
data-ks-strength Number 20 Determines the intensity of the transformation effect. Higher values result in more pronounced transformations.
data-ks-transformorigin String center Sets the CSS transform-origin property, defining the point around which transformations are applied (e.g., top left).
data-ks-startdistance Number 100 Defines the distance threshold (in pixels) at which transformations begin to take effect.
data-ks-interaction Enum (linear, attraction, repulsion) linear Specifies the interaction type. linear applies transformations based purely on distance, attraction pulls the element towards the cursor, and repulsion pushes it away.
data-ks-transform Enum (translate, rotate, scale) translate Specifies the type of transformation to apply based on cursor distance.
data-ks-easing String cubic-bezier(0.23, 1, 0.32, 1) CSS easing function for the transformation transition.
data-ks-duration Number 1000 Duration of the transformation transition in milliseconds.

License

This project is licensed under the MIT License.

About

A library that offers a suite of components to create engaging animations and transformations based on user interactions like mouse movements, scroll events, and even audio input.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%