GithubHelp home page GithubHelp logo

donkeyclip / motorcortex-anime Goto Github PK

View Code? Open in Web Editor NEW
1.0 5.0 0.0 30.54 MB

License: MIT License

JavaScript 98.62% Shell 1.38%
anime-library motorcortex-anime anime-incident animation motorcortex-plugin motorcortex anime

motorcortex-anime's Introduction

MotorCortex-Anime

Table of Contents

Demo

Check it out here

Intro / Features

Anime.js library as a MotorCortex CSS Layer. The library exposes CSSEffect which implementes an alternative CSS Layer for MotorCortex while the second (MotionPath) performs motion path animation.

The Plugin exposes two Incidents:

  • CSSEffect (CSS Layer implementation)
  • MotionPath

Browser compatibility

Chrome Safari IE / Edge Firefox Opera
24+ 6+ 10+ 32+ 15+

Getting Started

Installation

$ npm install @donkeyclip/motorcortex-anime
# OR
$ yarn add @donkeyclip/motorcortex-anime

Importing and loading

You can load Anime plugin in a two different ways, based on what you want to do with this plugin (you will find out more information below):

As a MotorCortex's core CSS Layer:

import { setCSSCore } from "@donkeyclip/motorcortex";
import AnimePluginDefinition from "@donkeyclip/motorcortex-anime";
setCSSCore(AnimePluginDefinition.CSSEffect);

As a simple plugin:

import { loadPlugin } from "@donkeyclip/motorcortex";
import AnimePluginDefinition from "@donkeyclip/motorcortex-anime";
const AnimePlugin = loadPlugin(AnimePluginDefinition);

Creating Incidents

CSSEffect

Use the provided CSSEffect as the CSS core of MotorCortex.

const MyAnime = new CSSEffect({
  animatedAttrs: {
    left: '120px',
    top: '220px',
    background: 'orange',
    width: '10px;
  }
}, {
  selector: '.a',
  duration: 2000,
  easing: 'linear'
});

IMPORTANT

Don't forget ฯ„ฮฟ import and load the Anime Plugin using the first way.

MotionPath

The MotioPath Incident implements the motion path capability of anime.js library. This feature allows motion of any element on any given (svg) path.

The syntax is simple:

const motionPath = new AnimePlugin.MotionPath(
  {
    pixelsAccuracy: 5,
    animatedAttrs: {
      positionOn: {
        pathElement: "the selector that targets your path element",
      },
    },
  },
  {
    selector: ".a",
    duration: 2000,
    easing: "linear",
  }
);

MotionPath Attrs

As you can notice the animated attribute here is positionOn which in turn is an object expecting only one key, the pathElement which is a selctor to the path element that defines the motion path.

The selected elements will sleep into this path on the given duration.

One more thing to notice is the pixelsAccuracy attribute. This attribute sets the distance threshold between two sequential points of the path that the element should move. This attribute can be used so the motion path effect gets more performant (less processing is required). The default value is 4.

IMPORTANT

For the MotionPath Incident you should import and load MotorCortex-Anime as a simple Plugin.

Adding Incidents in your clip

clipName.addIncident(incidentName, startTime);

Contributing

In general, we follow the "fork-and-pull" Git workflow, so if you want to submit patches and additions you should follow the next steps:

  1. Fork the repo on GitHub
  2. Clone the project to your own machine
  3. Commit changes to your own branch
  4. Push your work back up to your fork
  5. Submit a Pull request so that we can review your changes

License

MIT License

Sponsored by

motorcortex-anime's People

Contributors

alexdor avatar andreas-trad avatar dependabot[bot] avatar elisavetampatzidou avatar github-actions[bot] avatar ivanvl01 avatar kissmybutton-bot avatar potouridisio avatar prieston avatar renovate-bot avatar renovate[bot] avatar

Stargazers

 avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

motorcortex-anime's Issues

Action Required: Fix Renovate Configuration

There is an error with this repository's Renovate configuration that needs to be fixed. As a precaution, Renovate will stop PRs until it is resolved.

File: renovate.json
Error type: The renovate configuration file contains some invalid settings
Message: Invalid configuration option: separateMajorReleases

Dependency Dashboard

This issue lists Renovate updates and detected dependencies. Read the Dependency Dashboard docs to learn more.

Rate-Limited

These updates are currently rate-limited. Click on a checkbox below to force their creation now.

  • chore(deps): replace dependency eslint-plugin-node with eslint-plugin-n 14.0.0
  • chore(deps): replace dependency rollup-plugin-terser with @rollup/plugin-terser 0.1.0
  • chore(deps): update dependency caniuse-lite to v1.0.30001621
  • chore(deps): update dependency webpack-dev-server to v4.15.2
  • chore(deps): update babel monorepo to v7.24.6 (@babel/cli, @babel/core, @babel/eslint-parser, @babel/plugin-syntax-jsx, @babel/plugin-transform-react-jsx, @babel/preset-env)
  • chore(deps): update dependency @donkeyclip/motorcortex to v9.17.1
  • chore(deps): update dependency browserslist to v4.23.0
  • chore(deps): update dependency core-js to v3.37.1
  • chore(deps): update dependency css-loader to v6.11.0
  • chore(deps): update dependency eslint to v8.57.0
  • chore(deps): update dependency webpack to v5.91.0
  • chore(deps): update reviewdog/action-eslint action to v1.24.0
  • chore(deps): update dependency css-loader to v7
  • chore(deps): update dependency eslint to v9
  • chore(deps): update dependency eslint-config-prettier to v9
  • chore(deps): update dependency husky to v9
  • chore(deps): update dependency lint-staged to v15
  • chore(deps): update dependency rollup to v4
  • chore(deps): update dependency webpack-dev-server to v5
  • chore(deps): update googlecloudplatform/release-please-action action to v4
  • chore(deps): update peaceiris/actions-gh-pages action to v4
  • chore(deps): update peter-evans/create-pull-request action to v6
  • ๐Ÿ” Create all rate-limited PRs at once ๐Ÿ”

Open

These updates have all been created already. Click a checkbox below to force a retry/rebase of any.

Detected dependencies

github-actions
.github/workflows/bundle-size.yml
  • actions/checkout v3.6.0
  • actions/setup-node v3.8.2
  • pkg-size/action v1
.github/workflows/eslint.yml
  • actions/checkout v3.6.0
  • reviewdog/action-eslint v1.22.0
.github/workflows/github-page.yml
  • actions/checkout v3.6.0
  • actions/setup-node v3.8.2
  • peaceiris/actions-gh-pages v3.9.3
.github/workflows/misspell.yml
  • actions/checkout v3.6.0
  • sobolevn/misspell-fixer-action 0.1.0
  • peter-evans/create-pull-request v4.2.4
.github/workflows/release-please.yml
  • actions/checkout v3.6.0
  • GoogleCloudPlatform/release-please-action v3.7.13
  • actions/checkout v3.6.0
  • actions/setup-node v3.8.2
.github/workflows/test.yaml
  • actions/checkout v3.6.0
  • actions/setup-node v3.8.2
npm
package.json
  • mc-animejs-core 3.1.5
  • @babel/cli 7.23.9
  • @babel/core 7.23.9
  • @babel/eslint-parser 7.23.10
  • @babel/plugin-syntax-jsx 7.23.3
  • @babel/plugin-transform-react-jsx 7.23.4
  • @babel/preset-env 7.23.9
  • @donkeyclip/motorcortex 9.14.0
  • @donkeyclip/motorcortex-player 2.10.11
  • @rollup/plugin-babel 6.0.4
  • @rollup/plugin-commonjs 22.0.2
  • @rollup/plugin-json 4.1.0
  • @rollup/plugin-node-resolve 15.2.3
  • babel-loader 8.3.0
  • browserslist 4.22.3
  • caniuse-lite 1.0.30001582
  • concurrently 7.6.0
  • core-js 3.35.1
  • css-loader 6.10.0
  • eslint 8.56.0
  • eslint-config-prettier 8.10.0
  • eslint-plugin-babel 5.3.1
  • eslint-plugin-import 2.29.1
  • eslint-plugin-node 11.1.0
  • eslint-plugin-prettier 4.2.1
  • eslint-plugin-promise 6.1.1
  • husky 8.0.3
  • lint-staged 13.3.0
  • prettier 2.8.8
  • rimraf 3.0.2
  • rollup 2.79.1
  • rollup-plugin-terser 7.0.2
  • webpack 5.90.1
  • webpack-cli 4.10.0
  • webpack-dev-server 4.15.1
  • node >=12

  • Check this box to trigger a request for Renovate to run again on this repository

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.