Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/malerba118/react-particle-image
Render images as interactive particles
https://github.com/malerba118/react-particle-image
Last synced: 4 days ago
JSON representation
Render images as interactive particles
- Host: GitHub
- URL: https://github.com/malerba118/react-particle-image
- Owner: malerba118
- Created: 2020-01-18T02:09:00.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-03-01T02:03:05.000Z (almost 2 years ago)
- Last Synced: 2024-10-01T10:33:47.214Z (4 months ago)
- Language: TypeScript
- Homepage: https://malerba118.github.io/react-particle-image-demo/
- Size: 4.63 MB
- Stars: 460
- Watchers: 6
- Forks: 20
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-react-components - react-particle-image - [demo](https://malerba118.github.io/react-particle-image-demo/) - Render images as interactive particles. (UI Components / Photo / Image)
- awesome-react - react-particle-image - Render images as interactive particles. ![](https://img.shields.io/github/stars/malerba118/react-particle-image.svg?style=social&label=Star) (UI Components / Photo / Image)
- awesome-react-components - react-particle-image - [demo](https://malerba118.github.io/react-particle-image-demo/) - Render images as interactive particles. (UI Components / Photo / Image)
- fucking-awesome-react-components - react-particle-image - 🌎 [demo](malerba118.github.io/react-particle-image-demo/) - Render images as interactive particles. (UI Components / Photo / Image)
- awesome-react-components - react-particle-image - [demo](https://malerba118.github.io/react-particle-image-demo/) - Render images as interactive particles. (UI Components / Photo / Image)
- awesome-react-components - react-particle-image - [demo](https://malerba118.github.io/react-particle-image-demo/) - Render images as interactive particles. (UI Components / Photo / Image)
README
# react-particle-image
> Render images as interactive particles
[![NPM](https://img.shields.io/npm/v/react-particle-image.svg)](https://www.npmjs.com/package/react-particle-image) [![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
![react-particles-demo-3](https://user-images.githubusercontent.com/5760059/74112617-d6741a00-4b63-11ea-9757-81c55fe8e9b5.gif)
## Install
```bash
npm install --save react-particle-image
```## Links
- [Demo](https://malerba118.github.io/react-particle-image-demo/) ([source](https://github.com/malerba118/react-particle-image-demo/blob/master/src/App.tsx))
- [Docs](https://malerba118.github.io/react-particle-image/interfaces/_particleimage_particleimage_.particleimageprops.html)## Simple Usage
[codesandbox](https://codesandbox.io/s/react-particle-image-simple-ei97k)
```tsx
import * as React from "react";
import ParticleImage, { ParticleOptions } from "react-particle-image";const particleOptions: ParticleOptions = {
filter: ({ x, y, image }) => {
// Get pixel
const pixel = image.get(x, y);
// Make a particle for this pixel if blue > 50 (range 0-255)
return pixel.b > 50;
},
color: ({ x, y, image }) => "#61dafb"
};export default function App() {
return (
);
}
```## Complex Usage
[codesandbox](https://codesandbox.io/s/react-particle-image-complex-pbzo9)
```tsx
import * as React from "react";
import useWindowSize from "@rooks/use-window-size";
import ParticleImage, {
ParticleOptions,
Vector,
forces,
ParticleForce
} from "react-particle-image";
import "./styles.css";const particleOptions: ParticleOptions = {
filter: ({ x, y, image }) => {
// Get pixel
const pixel = image.get(x, y);
// Make a particle for this pixel if blue > 50 (range 0-255)
return pixel.b > 50;
},
color: ({ x, y, image }) => "#61dafb",
radius: () => Math.random() * 1.5 + 0.5,
mass: () => 40,
friction: () => 0.15,
initialPosition: ({ canvasDimensions }) => {
return new Vector(canvasDimensions.width / 2, canvasDimensions.height / 2);
}
};const motionForce = (x: number, y: number): ParticleForce => {
return forces.disturbance(x, y, 5);
};export default function App() {
const { innerWidth, innerHeight } = useWindowSize();return (
);
}
```## Performance Tips
`ParticleImage` has a target frame rate of 30fps, but with thousands of particles updating positions and repainting 30 times per second, performance can be a problem.If animations are choppy try:
- Reducing the number of distinct particle colors (particles of the same color will be batched while painting)
- Reducing the number of particles (less than 6000 is ideal)
- Reducing the resolution of the src image.Here's a [codesandbox of a good boy](https://codesandbox.io/s/react-particle-image-multicolor-dp8up) to show what I mean. Note the `round` function to reduce the number of colors painted on the canvas.
MIT © [malerba118](https://github.com/malerba118)