• Stars
    star
    10,072
  • Rank 3,464 (Top 0.07 %)
  • Language
    JavaScript
  • License
    ISC License
  • Created almost 7 years ago
  • Updated 7 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

πŸŽ‰ performant confetti animation in the browser

Canvas Confetti

github actions ci jsdelivr npm-downloads npm-version

Demo

catdad.github.io/canvas-confetti

Install

You can install this module as a component from NPM:

npm install --save canvas-confetti

You can then require('canvas-confetti'); to use it in your project build. Note: this is a client component, and will not run in Node. You will need to build your project with something like webpack in order to use this.

You can also include this library in your HTML page directly from a CDN:

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/confetti.browser.min.js"></script>

Note: you should use the latest version at the time that you include your project. You can see all versions on the releases page.

Reduced Motion

Thank you for joining me in this very important message about motion on your website. See, not everyone likes it, and some actually prefer no motion. They have ways to tell us about it and we should listen. While I don't want to go as far as tell you not to have confetti on your page just yet, I do want to make it easy for you to respect what your users want. There is a disableForReducedMotion option you can use so that users that have trouble with chaotic animations don't need to struggle on your website. This is disabled by default, but I am considering changing that in a future major release. If you have strong feelings about this, please let me know. For now, please confetti responsibly.

API

When installed from npm, this library can be required as a client component in your project build. When using the CDN version, it is exposed as a confetti function on window.

confetti([options {Object}]) β†’ Promise|null

confetti takes a single optional object. When window.Promise is available, it will return a Promise to let you know when it is done. When promises are not available (like in IE), it will return null. You can polyfill promises using any of the popular polyfills. You can also provide a promise implementation to confetti through:

const MyPromise = require('some-promise-lib');
const confetti = require('canvas-confetti');
confetti.Promise = MyPromise;

If you call confetti multiple times before it is done, it will return the same promise every time. Internally, the same canvas element will be reused, continuing the existing animation with the new confetti added. The promise returned by each call to confetti will resolve once all animations are done.

options

The confetti parameter is a single optional options object, which has the following properties:

  • particleCount Integer (default: 50): The number of confetti to launch. More is always fun... but be cool, there's a lot of math involved.
  • angle Number (default: 90): The angle in which to launch the confetti, in degrees. 90 is straight up.
  • spread Number (default: 45): How far off center the confetti can go, in degrees. 45 means the confetti will launch at the defined angle plus or minus 22.5 degrees.
  • startVelocity Number (default: 45): How fast the confetti will start going, in pixels.
  • decay Number (default: 0.9): How quickly the confetti will lose speed. Keep this number between 0 and 1, otherwise the confetti will gain speed. Better yet, just never change it.
  • gravity Number (default: 1): How quickly the particles are pulled down. 1 is full gravity, 0.5 is half gravity, etc., but there are no limits. You can even make particles go up if you'd like.
  • drift Number (default: 0): How much to the side the confetti will drift. The default is 0, meaning that they will fall straight down. Use a negative number for left and positive number for right.
  • ticks Number (default: 200): How many times the confetti will move. This is abstract... but play with it if the confetti disappear too quickly for you.
  • origin Object: Where to start firing confetti from. Feel free to launch off-screen if you'd like.
    • origin.x Number (default: 0.5): The x position on the page, with 0 being the left edge and 1 being the right edge.
    • origin.y Number (default: 0.5): The y position on the page, with 0 being the top edge and 1 being the bottom edge.
  • colors Array<String>: An array of color strings, in the HEX format... you know, like #bada55.
  • shapes Array<String>: An array of shapes for the confetti. The possible values are square, circle, and star. The default is to use both squares and circles in an even mix. To use a single shape, you can provide just one shape in the array, such as ['star']. You can also change the mix by providing a value such as ['circle', 'circle', 'square'] to use two third circles and one third squares.
  • scalar Number (default: 1): Scale factor for each confetti particle. Use decimals to make the confetti smaller. Go on, try teeny tiny confetti, they are adorable!
  • zIndex Integer (default: 100): The confetti should be on top, after all. But if you have a crazy high page, you can set it even higher.
  • disableForReducedMotion Boolean (default: false): Disables confetti entirely for users that prefer reduced motion. The confetti() promise will resolve immediately in this case.

confetti.create(canvas, [globalOptions]) β†’ function

This method creates an instance of the confetti function that uses a custom canvas. This is useful if you want to limit the area on your page in which confetti appear. By default, this method will not modify the canvas in any way (other than drawing to it).

Canvas can be misunderstood a bit though, so let me explain why you might want to let the module modify the canvas just a bit. By default, a canvas is a relatively small image -- somewhere around 300x150, depending on the browser. When you resize it using CSS, this sets the display size of the canvas, but not the image being represented on that canvas. Think of it as loading a 300x150 jpeg image in an img tag and then setting the CSS for that tag to 1500x600 -- your image will end up stretched and blurry. In the case of a canvas, you need to also set the width and height of the canvas image itself. If you don't want to do that, you can allow confetti to set it for you.

Note also that you should persist the custom instance and avoid initializing an instance of confetti with the same canvas element more than once.

The following global options are available:

  • resize Boolean (default: false): Whether to allow setting the canvas image size, as well as keep it correctly sized if the window changes size (e.g. resizing the window, rotating a mobile device, etc.). By default, the canvas size will not be modified.
  • useWorker Boolean (default: false): Whether to use an asynchronous web worker to render the confetti animation, whenever possible. This is turned off by default, meaning that the animation will always execute on the main thread. If turned on and the browser supports it, the animation will execute off of the main thread so that it is not blocking any other work your page needs to do. Using this option will also modify the canvas, but more on that directly below -- do read it. If it is not supported by the browser, this value will be ignored.
  • disableForReducedMotion Boolean (default: false): Disables confetti entirely for users that prefer reduced motion. When set to true, use of this confetti instance will always respect a user's request for reduced motion and disable confetti for them.

Important: If you use useWorker: true, I own your canvas now. It's mine now and I can do whatever I want with it (don't worry... I'll just put confetti inside it, I promise). You must not try to use the canvas in any way (other than I guess removing it from the DOM), as it will throw an error. When using workers for rendering, control of the canvas must be transferred to the web worker, preventing any usage of that canvas on the main thread. If you must manipulate the canvas in any way, do not use this option.

var myCanvas = document.createElement('canvas');
document.body.appendChild(myCanvas);

var myConfetti = confetti.create(myCanvas, {
  resize: true,
  useWorker: true
});
myConfetti({
  particleCount: 100,
  spread: 160
  // any other options from the global
  // confetti function
});

confetti.reset()

Stops the animation and clears all confetti, as well as immediately resolves any outstanding promises. In the case of a separate confetti instance created with confetti.create, that instance will have its own reset method.

confetti();

setTimeout(() => {
  confetti.reset();
}, 100);
var myCanvas = document.createElement('canvas');
document.body.appendChild(myCanvas);

var myConfetti = confetti.create(myCanvas, { resize: true });

myConfetti();

setTimeout(() => {
  myConfetti.reset();
}, 100);

Examples

Launch some confetti the default way:

confetti();

Launch a bunch of confetti:

confetti({
  particleCount: 150
});

Launch some confetti really wide:

confetti({
  spread: 180
});

Get creative. Launch a small poof of confetti from a random part of the page:

confetti({
  particleCount: 100,
  startVelocity: 30,
  spread: 360,
  origin: {
    x: Math.random(),
    // since they fall down, start a bit higher than random
    y: Math.random() - 0.2
  }
});

I said creative... we can do better. Since it doesn't matter how many times we call confetti (just the total number of confetti in the air), we can do some fun things, like continuously launch more and more confetti for 30 seconds, from multiple directions:

// do this for 30 seconds
var duration = 30 * 1000;
var end = Date.now() + duration;

(function frame() {
  // launch a few confetti from the left edge
  confetti({
    particleCount: 7,
    angle: 60,
    spread: 55,
    origin: { x: 0 }
  });
  // and launch a few from the right edge
  confetti({
    particleCount: 7,
    angle: 120,
    spread: 55,
    origin: { x: 1 }
  });

  // keep going until we are out of time
  if (Date.now() < end) {
    requestAnimationFrame(frame);
  }
}());

More Repositories

1

electronmon

πŸ–₯ run, watch, and restart electron apps using magic
JavaScript
140
star
2

raw-viewer

πŸ“· raw image viewer
JavaScript
48
star
3

tiny.toast

🍞 minimal code for tiny notifications
JavaScript
25
star
4

mock-stdio

πŸ”‡ mock stdio output for tests
JavaScript
23
star
5

grandma

πŸ‘΅ fully programmable stress testing framework
JavaScript
20
star
6

svg-app-icon

🎨 create high-quality desktop icons from svg source
JavaScript
16
star
7

fork-ribbon-css-builder

πŸŽ€ pure CSS "For me on GitHub" ribbon generator
CSS
14
star
8

css-raw-loader

🌁 CSS Raw loader module for Webpack
JavaScript
13
star
9

unofficial-hipchat

πŸ’ˆ a hipper chat
JavaScript
11
star
10

puptron

🐢 automate your Electron application with Puppeteer
JavaScript
9
star
11

electron-template

βš› opinionated electron application template
JavaScript
9
star
12

github-emoji-cheatsheet

🍍 all the emoji as rendered by GitHub
JavaScript
9
star
13

ColorJS

✏️ convert and calculate colors in JavaScript
JavaScript
8
star
14

friendlyCast

A developer-friendly wrapper for the Chromecast API
JavaScript
8
star
15

watchboy

⌚ watch for file changes without the hassle
JavaScript
7
star
16

video-tools

🎬 cli tool for video processing
JavaScript
7
star
17

tiny.request

πŸ— Node.JS-style ajax requests for the browser
JavaScript
6
star
18

gulp-each

πŸ“‡ a for-each that provides the raw file content
JavaScript
6
star
19

chord-explorer

🎸 look up guitar and ukulele chords
JavaScript
5
star
20

video-tools-app

🎬 gui tool for video processing
JavaScript
4
star
21

mocha-slow-test-reporter

βŒ› list slow mocha tests
JavaScript
4
star
22

shellton

🐚 execute other stuff from node
JavaScript
2
star
23

fair-compare

🎑 simple and easy comparison of images and text across whole directories
JavaScript
2
star
24

glob-filestream

πŸ“„ read a glob of files into a single stream
JavaScript
2
star
25

fs-watch-file

πŸ—ƒ watch specific files for changes
JavaScript
2
star
26

PointBank

Research software for geocoded location and analysis of tweets.
JavaScript
2
star
27

localcast

πŸ“Ί send local videos to Chromecast - but maybe don't use it
JavaScript
2
star
28

gulp-multistream

πŸ’¦ write data to multiple streams in the pipeline, at the same time.
JavaScript
2
star
29

multispawn

β›“ run multiple processes in the foreground
JavaScript
2
star
30

json-cli-toolkit

πŸ™‰ work with json from the command line
JavaScript
2
star
31

repeatspawn

πŸ” execute a cli command repeatedly until it fails
JavaScript
1
star
32

read-vinyl-file-stream

πŸ“‡ iterate a vinyl file stream with minimal code
JavaScript
1
star
33

brackets-theme-one-gray

🍹 the dark Brackets theme
HTML
1
star
34

node-generate-readme-badges

πŸ“› just being lazy/smort
JavaScript
1
star
35

node--proxy

a super simple proxy for when you need one in a pinch
JavaScript
1
star
36

brackets-shebang-highligher

πŸ’’ i don't want to click buttons, you figure it out
JavaScript
1
star
37

unstyle

βœ‚οΈ unstyle CLI output
JavaScript
1
star
38

dcrawr

😺 dcraw with a little added r
JavaScript
1
star
39

jsForm

Easily create, validate, and submit forms
JavaScript
1
star
40

mocha-duplicate-reporter

Finds mocha tests that use the exact same full name
JavaScript
1
star
41

eol-fix-stream

πŸ”° end all the things with lf
JavaScript
1
star
42

tiny.cdn

πŸ‘€ my libraries, hosted
HTML
1
star
43

runtime-required

πŸ“’ get notified when a file is required
JavaScript
1
star
44

stack-source-mapper

🎰 decode a minified stacktrace using the source maps
JavaScript
1
star
45

wait-for-throwable

🧨 utility to retry an erroring function until it succeeds
JavaScript
1
star