前言
粒子动画,顾名思义,就是页面上存在大量的粒子构建而成的动画。
传统的粒子动画重要由 Canvas、WebGL 实现,我们经常用来用作网站的动画配景。
今天介绍两个个可以轻松创建高度可定制的粒子动画库。
一、particle-bg
1. git地点:
https://github.com/PengJiyuan/particle-bg
不带连线结果:
data:image/s3,"s3://crabby-images/75b59/75b5944c387e798b38431c4e273f260eb4d634a9" alt=""
带连线的结果:
data:image/s3,"s3://crabby-images/281c7/281c71ae4941634d0b9ce9991e2d2bed29dd377c" alt=""
2. 安装
NPM
CDN
- https://unpkg.com/particle-bg/lib/particle-bg.umd.min.js
复制代码 3. 使用
ES Module
- import particleBg from 'particle-bg';
- particleBg('body');
复制代码 Browser
- <script src="https://unpkg.com/particle-bg/lib/particle-bg.umd.min.js
- "></script><script> particleBg('body');</script>
复制代码 API
- particleBg(element, config)
- element
- 要插入粒子背景的DOM。
- config [Object]
- 粒子背景的一些配置。
- config.color
- default: '#fff'
- 粒子的颜色。
- config.count
- default: 100
- 粒子的数量
- config.radius
- default: 2
- 粒子的半径
- config.distance
- default: width / 10
- 粒子间距小于多少会连线
- config.rate
- default: width / 10000
- 粒子运动的速率
- config.zIndex
- default: 1
- canvas的z-index.
- config.resize
- default: true
- 是否监听window.resize,自动缩放粒子背景。
- config.line
- default: true
- 粒子之间是否连线。
- config.bounce
- default: false
- 是否触碰边界进行反弹。
复制代码 4. 完备demo
- <div style="width: 100%;height: 200px;background-color: rgb(109, 108, 106);" id="Bg"></div><script src="https://unpkg.com/particle-bg/lib/particle-bg.umd.min.js
- "></script><script> particleBg('#Bg', { color: '#fff', count: 100, radius: 2, distance: 70, rate:1, zIndex: 1, resize: true, line: true, bounce: true, });</script>
复制代码 结果
data:image/s3,"s3://crabby-images/56d06/56d066c38259d9f2a4fa2cadee3f672365af6c0b" alt=""
二、tsParticles
TypeScript Particles 是在 particles.js 底子上重写的一个库,目标是更轻易地创建更多的配景动画,并提供更多的实用步调和支持功能。
这个库最大的亮点在于它可以用于许多差异的框架,比方 React.js, Vue.js (2.x and 3.x), Angular, Svelte, jQuery等等JS框架、Web组件。
1. 源码地点:
GitHub地点:https://github.com/matteobruni/tsparticles
官网地点:https://particles.js.org/
更多demo地点:https://codepen.io/collection/DPOage
2. 安装
npm
- npm install tsparticles-engine
复制代码 yarn
- yarn add tsparticles-engine
复制代码 pnpm
- pnpm install tsparticles-engine
复制代码 3. 引入
从版本1.12.11开始使用import和require导入tsParticles了。
- const tsParticles = require("tsparticles-engine");
- // or
- import { tsParticles } from "tsparticles-engine";
复制代码 4. 使用
index.html
- <div id="tsparticles"></div>
- <script src="tsparticles.engine.min.js"></script>
复制代码 app.js
- tsParticles
- .loadJSON("tsparticles", "presets/default.json")
- .then(container => {
- console.log("callback - tsparticles config loaded");
- })
- .catch(error => {
- console.error(error);
- });
复制代码 5. 几个例子
5.1 ts粒子五彩纸屑烟花
- <script src="https://cdn.jsdelivr.net/npm/tsparticles-confetti@2.11.0/tsparticles.confetti.bundle.min.js"></script>
- <script id="rendered-js">
- const duration = 60 * 60 * 1000,
- animationEnd = Date.now() + duration,
- defaults = { startVelocity: 30, spread: 360, ticks: 20, zIndex: 0 };
- function randomInRange(min, max) {
- return Math.random() * (max - min) + min;
- }
- const interval = setInterval(function () {
- const timeLeft = animationEnd - Date.now();
- if (timeLeft <= 0) {
- return clearInterval(interval);
- }
- const particleCount = 20 * (timeLeft / duration);
- // since particles fall down, start a bit higher than random
- confetti(
- Object.assign({}, defaults, {
- particleCount,
- origin: { x: randomInRange(0.1, 0.3), y: Math.random() - 0.2 }
- }));
- confetti(
- Object.assign({}, defaults, {
- particleCount,
- origin: { x: randomInRange(0.7, 0.9), y: Math.random() - 0.2 }
- }));
- }, 250);
- </script>
复制代码 结果
data:image/s3,"s3://crabby-images/92c20/92c20d1e3a35e4987431fe6e53ad9db7f7d773b0" alt=""
5.2 多粒子产卵器-用tsParticles制作
- <div style="width: 100%;height: 200px;background-color: rgb(109, 108, 106);" id="tsparticles"></div>
- <script src="https://cdn.jsdelivr.net/npm/tsparticles@1.19.0-alpha.3/dist/tsparticles.min.js"></script>
- <script id="rendered-js">
- tsParticles.load("tsparticles", {
- fpsLimit: 60,
- particles: {
- number: {
- value: 0,
- density: {
- enable: true,
- value_area: 800
- }
- },
- color: {
- value: "#ffff00"
- },
- shape: {
- type: "circle"
- },
- opacity: {
- value: 1,
- random: false,
- animation: {
- enable: true,
- speed: 0.5,
- minimumValue: 0,
- sync: false
- }
- },
- size: {
- value: 8,
- random: { enable: true, minimumValue: 4 },
- animation: {
- enable: false,
- speed: 20,
- minimumValue: 4,
- sync: false
- }
- },
- move: {
- enable: true,
- gravity: {
- enable: true,
- acceleration: -0.5
- },
- speed: 5,
- direction: "top",
- random: false,
- straight: false,
- outModes: {
- default: "destroy",
- bottom: "none"
- },
- attract: {
- enable: true,
- distance: 300,
- rotate: {
- x: 600,
- y: 1200
- }
- }
- }
- },
- interactivity: {
- detectsOn: "canvas",
- events: {
- resize: true
- }
- },
- detectRetina: true,
- background: {
- color: "#000000"
- },
- emitters: [
- {
- direction: "top",
- particles: {
- color: "#f00"
- },
- rate: {
- quantity: 1,
- delay: 0.1
- },
- size: {
- width: 100,
- height: 10
- },
- position: {
- x: 50,
- y: 100
- }
- },
- {
- direction: "top",
- particles: {
- color: "#0f0"
- },
- rate: {
- quantity: 1,
- delay: 0.1
- },
- size: {
- width: 100,
- height: 10
- },
- position: {
- x: 50,
- y: 100
- }
- }]
- });
- //# sourceURL=pen.js
- </script>
复制代码 结果
data:image/s3,"s3://crabby-images/35f65/35f6533e8e7326b9a27e868a2780867e334e5314" alt=""
5.3 ts粒子鼠标吸引力
- <div style="width: 100%;height: 200px;background-color: rgb(109, 108, 106);" id="tsparticles1"></div>
- <script src="https://cdn.jsdelivr.net/npm/tsparticles@1.37.4/tsparticles.min.js"></script>
- <script id="rendered-js">
- tsParticles.load("tsparticles1", {
- fps_limit: 60,
- interactivity: {
- detect_on: "canvas",
- events: {
- onclick: { enable: true, mode: "push" },
- onhover: {
- enable: true,
- mode: "attract",
- parallax: { enable: false, force: 60, smooth: 10 }
- },
- resize: true
- },
- modes: {
- push: { quantity: 4 },
- attract: { distance: 200, duration: 0.4, factor: 5 }
- }
- },
- particles: {
- color: { value: "#ffffff" },
- line_linked: {
- color: "#ffffff",
- distance: 150,
- enable: true,
- opacity: 0.4,
- width: 1
- },
- move: {
- attract: { enable: false, rotateX: 600, rotateY: 1200 },
- bounce: false,
- direction: "none",
- enable: true,
- out_mode: "out",
- random: false,
- speed: 2,
- straight: false
- },
- number: { density: { enable: true, value_area: 800 }, value: 80 },
- opacity: {
- anim: { enable: false, opacity_min: 0.1, speed: 1, sync: false },
- random: false,
- value: 0.5
- },
- shape: {
- character: {
- fill: false,
- font: "Verdana",
- style: "",
- value: "*",
- weight: "400"
- },
- image: {
- height: 100,
- replace_color: true,
- src: "images/github.svg",
- width: 100
- },
- polygon: { nb_sides: 5 },
- stroke: { color: "#000000", width: 0 },
- type: "circle"
- },
- size: {
- anim: { enable: false, size_min: 0.1, speed: 40, sync: false },
- random: true,
- value: 5
- }
- },
- polygon: {
- draw: { enable: false, lineColor: "#ffffff", lineWidth: 0.5 },
- move: { radius: 10 },
- scale: 1,
- type: "none",
- url: ""
- },
- retina_detect: true
- });
- </script>
复制代码 结果
data:image/s3,"s3://crabby-images/97ce8/97ce899a1202a6148ff8f5735ca05c90d0b0910d" alt=""
5.4 粒子烟花
- <script src="https://cdn.jsdelivr.net/npm/tsparticles-fireworks@2.11.0/tsparticles.fireworks.bundle.min.js"></script>
- <script id="rendered-js">
- fireworks();
- </script>
复制代码 结果
data:image/s3,"s3://crabby-images/359f1/359f1db592de6b11b51e776dc8ffa188bf6818fc" alt=""
源码地点
https://gitcode.net/my12/particle
完结
赠人玫瑰,手有余香!如果文章内容对你有所帮助,请不要吝啬你的点赞评论和关注,以便我第一时间收到反馈,你的每一次支持都是我不停创作的最大动力。固然如果你发现了文章中存在错误大概有更好的解决方法,也欢迎评论私信告诉我哦!
好了,我是向宇,https://xiangyu.blog.csdn.net
一位在小公司冷静奋斗的开发者,出于兴趣爱好,于是迩来才开始自习unity。如果你碰到任何问题,也欢迎你评论私信找我, 虽然有些问题我大概也不肯定会,但是我会查阅各方资料,争取给出最好的发起,盼望可以帮助更多想学编程的人,共勉~
data:image/s3,"s3://crabby-images/6903b/6903ba497c7b86a6a0c2ce13748cc1d08a5c2dfd" alt=""
来源:https://blog.csdn.net/qq_36303853/article/details/132318746
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |