npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

particle-shift

v1.0.2

Published

Particle shift is a library for creating animations with simple particle systems. Can be used to transition between any scene drawn onto a 2d canvas context, whether it be text, images, svgs, or just drawn shapes.

Downloads

3

Readme

Particle Shift

Particle shift is a library for creating animations with simple particle systems. Can be used to transition between any scene drawn onto a 2d canvas context, whether it be text, images, svgs, or just drawn shapes.

Particle Shift Banner

Demo

Visit demo site

Install

Webpack Require

Particle Shift can be included as a module through npm or yarn

npm install @ihansson/particle-shift
import { Scene, Screen, Body } from 'particle-shift'
Sceen.create({
	...
})

CDN

Alternatively the library can be included separately and accessed via the ParticleShift global.

<script src="https://cdn.jsdelivr.net/gh/ihansson/[email protected]/dist/particle-shift.min.js"></script>
<script>
ParticleShift.Sceen.create({
	...
})
</script>

Basic Example

<script src="https://cdn.jsdelivr.net/gh/ihansson/[email protected]/dist/particle-shift.min.js"></script>
<canvas id="canvas" width=500 height=300></canvas>
<script>
const scene = ParticleShift.Scene.create({
	selector: '#canvas',
	particle_size: 2,
	step_width: 6,
	draw_width: 500,
	draw_height: 300
})

const screen1 = ParticleShift.Screen.create(scene, {
	render: function(scene, ctx){
		ctx.font = '170px Georgia'
		ctx.fillStyle = 'black';
		ctx.fillText('Hello', 25, 200)
	}
})

const screen2 = ParticleShift.Screen.create(scene, {
	render: function(scene, ctx){
		ctx.fillText('There', 25, 200)
	}
})

scene.play_screen(screen1);

window.setTimeout(function(){
	scene.play_screen(screen2)
},2000)
</script>

Options

Scene

The scene in particle shift represents the canvas for the particle system and is used to controlled what is drawn and when. The most important properties of the scene are the particle_size and step_width which will control the level of detail of the particle system.

Responsive

The scene had a separate draw_width and draw_height from the actual width and heigh to allow for the canvas itself to be responsive. You should always sepcify a draw_width and draw_height and if you then want this to be responsive you can make the canvas responsive using css (100% width), or you can specify a different height and width in css to scale up to.

Pre Render

The pre_render_frames_count property can be set to create a sheet of all rendered frames if you have a scene which is too demanding to be rendered in real time. There is currently no option to directly output a gif or video so these would then need to be converted to your required format via another tool.

Example

const scene = ParticleShift.Scene.create({
	selector: '#canvas',
	particle_size: 2,
	step_width: 6,
	draw_width: 500,
	draw_height: 300
})

Settings

| property | type | default | notes | |-------------------------|------------|---------|--------------------------------------------------------------------------------------------| | selector | string | n/a | CSS Selector for a canvas element | | draw_width | num | n/a | Draw width for the scene (will be scaled up/down to the size of the canvas when rendered) | | draw_height | num | n/a | Draw height for the scene | | particle_size | num | 2 | Pixel size of each particle | | step_width | num | 6 | The distance to travel between sampling each pixel in a scene | | particle_type | rect, circ | rect | Whether to render each particle as a rect or circ | | spawn_scatter | num | 250 | Random distance maximum from which a new particle will be spawned to the final destination | | shuffle_spawn | bool | true | Whether particle positions will be shuffled between each scene. | | particle_speed | num | 1 | Base speed of particle | | particle_speed_distance | num | 0.05 | Distance multiplier to the speed of a particle | | particle_wobble | num | 0.2 | Adds a sin() position modifier to make movement appear less linear | | color_shift_speed | num | 4 | Speed at which particles will change color | | show_fps | bool | false | Enable the fps meter in the top left | | pre_render_frames_count | num, false | false | If used will store each frame generated and output a canvas with each frame stacked. |

Scene Object

| property | type | default | notes | |-------------|----------------|---------|-----------------------------------------------------------------------| | play_screen | method(screen) | n/a | Triggers the scene to animate particles to match the specified screen |

Screen

A particle shift screen represents a single drawn image on a canvas which can be used for the particles to transition from and to. Anything can be drawn to the screen through the standard canvas 2d context api.

Example

const screen1 = ParticleShift.Screen.create(scene, {
	render: function(scene, ctx){
		ctx.font = '170px Georgia'
		ctx.fillStyle = 'black';
		ctx.fillText('Hello', 25, 200)
	}
})

Settings

| property | type | default | notes | |----------|------------------|---------|-------------------------------------------------------------------------------------------| | bodies | array(body) | n/a | An array of bodies to be considered for the screen | | render | func(scene, ctx) | n/a | Called on setup to generate an image which can then be used to create the particle system |

Screen Object

| property | type | default | notes | | debug | method | n/a | Used on an instantiated screen object to output the rendered scene |

Body

Particle shift bodies are used to add basic attractors or deflectors to the particle system. Bodies are circles with a force which will be applied as a portion of the distance to the center of the body. The most common use case is to bind the update function to mouse position x/y to create mouse interaction.

Example

const example_body = ParticleShift.Body.create({
	x: 0,
	y: 0,
	radius: 50,
	force: -0.75,
	update: function(scene, ctx){},
	draw: function(scene, ctx){}
})

Settings

| property | type | default | notes | |----------|------------------|---------|-------------------------------------------------------------------------------| | x | num | n/a | Starting x position of body | | y | num | n/a | Starting y position of body | | radius | num | n/a | Radius of influence | | force | num | n/a | Force of influence on particles (can be negative) | | update | func(scene, ctx) | n/a | Called on every frame to update body properties, such as moving the body. | | draw | func(scene, ctx) | n/a | Called when drawing a frame, this is used if you want the body to be visible. |

License

MIT

Author

Ian Hansson