JavaScript+Canvas实现带跳动效果的粒子动画

yizhihongxing

实现带跳动效果的粒子动画可以使用JavaScript和Canvas,下面是具体步骤:

步骤一:创建画布和粒子对象

首先,在HTML中创建一个canvas画布,并用JavaScript获取该画布对象。然后,定义粒子对象,包括粒子的位置、半径、速度、弹性等属性,以及在画布上绘制粒子的方法。以下是示例代码:

<canvas id="myCanvas"></canvas>
const canvas = document.getElementById("myCanvas");
const ctx = canvas.getContext("2d");

class Particle{
  constructor(x, y, r, speedX, speedY, color){
    this.x = x;
    this.y = y;
    this.r = r;
    this.speedX = speedX;
    this.speedY = speedY;
    this.color = color;
    this.bounce = -0.7; // 弹性系数
  }
  draw(){
    ctx.beginPath();
    ctx.arc(this.x, this.y, this.r, 0, 2 * Math.PI);
    ctx.fillStyle = this.color;
    ctx.fill();
    ctx.closePath();
  }
  update(){
    this.x += this.speedX;
    this.y += this.speedY;
    if(this.y + this.r > canvas.height){ // 下落到画布底部时的弹性反弹
      this.y = canvas.height - this.r;
      this.speedY *= this.bounce;
    }
  }
}

步骤二:创建粒子数组

然后,定义一个数组来存储粒子对象,以及初始化该数组,生成一定数量的粒子对象。以下是示例代码:

const particles = [];

function init(){
  const particleNumber = 100;
  for(let i = 0; i < particleNumber ; i++){
    const x = Math.random() * canvas.width;
    const y = Math.random() * canvas.height;
    const r = 5 + Math.random() * 10;
    const speedX = -5 + Math.random() * 10;
    const speedY = -10 + Math.random() * 5;
    const color = `hsl(${Math.random() * 360},50%,50%)`;
    const particle = new Particle(x, y, r, speedX, speedY, color);
    particles.push(particle);
  }
}
init();

步骤三:实现画布清除和粒子更新

接下来,定义一个方法来清除画布,并在每一帧更新粒子数组,实现粒子位置的更新和画布的重绘。以下是示例代码:

function clear(){
  ctx.clearRect(0,0,canvas.width,canvas.height);
}

function update(){
  clear();
  particles.forEach((particle)=>{
    particle.update();
    particle.draw();
  });
}

步骤四:设置动画帧和粒子跳动效果

最后,在动画帧中调用update方法,实现动画效果。为了让粒子具有跳动的效果,需要在update方法中添加一个时间因子,使得粒子的y轴方向速度会随时间变化,从而实现跳动效果。以下是示例代码:

function animate(){
  requestAnimationFrame(animate);
  update();
  const time = Date.now() / 1000;
  particles.forEach((particle)=>{
    particle.speedY += Math.sin(time + particle.x) * 0.1;
  });
}
animate();

上述代码中,time是当前时间戳除以1000,得到单位为秒的时间因子;然后,通过sin函数计算出x和time的和值,再乘以0.1,得到y轴方向上的速度变化量,从而实现跳动效果。

示例说明1:增加粒子数量

我们可以增加粒子数量,让动画更加流畅。只需要修改init方法中的particleNumber值即可。

function init(){
  const particleNumber = 200; // 修改粒子数量
  for(let i = 0; i < particleNumber ; i++){
    const x = Math.random() * canvas.width;
    const y = Math.random() * canvas.height;
    const r = 5 + Math.random() * 10;
    const speedX = -5 + Math.random() * 10;
    const speedY = -10 + Math.random() * 5;
    const color = `hsl(${Math.random() * 360},50%,50%)`;
    const particle = new Particle(x, y, r, speedX, speedY, color);
    particles.push(particle);
  }
}

示例说明2:修改粒子弹性系数

我们也可以修改粒子的弹性系数,让粒子的跳动效果更加明显。只需要修改Particle类中的bounce值即可。

class Particle{
  constructor(x, y, r, speedX, speedY, color){
    this.x = x;
    this.y = y;
    this.r = r;
    this.speedX = speedX;
    this.speedY = speedY;
    this.color = color;
    this.bounce = -0.9; // 修改弹性系数
  }
}

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript+Canvas实现带跳动效果的粒子动画 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • 详解JS同源策略和CSRF

    JS同源策略指的是浏览器的一种安全策略,限制了一个源加载的文档或脚本如何与另一个源的资源进行交互。一般来说,源指的是协议+域名+端口号的组合,如果两个资源不属于同一个源,那么它们之间的交互就会受到限制。 常见的一些跨域问题,例如通过 XMLHttpRequest 发起的请求或者使用 iframe 加载的页面,都受到同源策略的限制。在前端开发过程中,我们通常使…

    JavaScript 2023年6月11日
    00
  • js实现盒子滚动动画效果

    下面是关于”js实现盒子滚动动画效果”的完整攻略: 1.编写HTML结构 首先,在HTML文件中编写盒子结构,例如: <div class="container"> <div class="box" style="background-color: red;">Box 1&l…

    JavaScript 2023年6月10日
    00
  • javascript 获取HTML DOM父、子、临近节点

    获取 HTML DOM 的父、子、相邻节点是 JavaScript 开发中经常需要用到的功能之一。下面,我将为您详细讲解这个过程,包含两个示例说明。 获取父节点 如果需要获取一个节点的父节点,可以使用 parentNode 属性。例如,要获取一个 id 为 “child” 的节点的父节点,可以使用以下代码: const childNode = documen…

    JavaScript 2023年6月10日
    00
  • 网站被恶意镜像怎么办 php一段代码轻松搞定(全面版)

    首先要明确一点,网站被恶意镜像是一件非常严重的事情,因为恶意镜像可能会导致网站被盗取或者篡改。因此我们需要尽快采取措施,防止恶意镜像对我们的网站造成更大的伤害。 一种简单而又有效的方法是在网站的PHP代码中加入以下一段代码: if (isset($_SERVER[‘HTTP_USER_AGENT’]) && preg_match(‘/bot|…

    JavaScript 2023年6月11日
    00
  • element中form组件prop嵌套属性的问题解决

    当我们在使用element组件库的form组件进行表单处理时,可能会遇到prop属性中需要嵌套传递另一个属性值的情况。比如,我们需要将一个表单项的验证规则(rules)传递给另外一个表单项,例如两个密码输入框输入必须相同。 以下是解决此类问题的攻略: 步骤一:在模板中添加ref属性 在模板中,我们需要添加一个ref属性来标识这个表单项,这样我们在代码中就可以…

    JavaScript 2023年6月10日
    00
  • JavaScript检查子字符串是否在字符串中的方法

    当需要判断一个字符串是否包含某个子字符串时,我们可以使用JavaScript中提供的字符串方法来实现。以下是常用的三种方法: 方法一:indexOf() indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。如果要检查的子字符串在主字符串中不存在,那么该方法会返回 -1。 例如:我们要检查字符串 “hello world” 是否包含 “w…

    JavaScript 2023年5月28日
    00
  • 原生js实现简单轮播图效果

    下面我来详细讲解如何用原生JS实现简单轮播图效果。 步骤1:HTML结构 我们首先需要在HTML文件中创建轮播图的骨架,通常可以使用<ul>标签和若干个<li>标签来实现。例如: <div id="slider"> <ul> <li><img src="slide…

    JavaScript 2023年6月11日
    00
  • 老生常谈ES6中的类

    ES6中的类是JavaScript语言中的一种新的语法糖,它提供了一种更加优雅的面向对象的编程方式,让JavaScript变得更加易读、易维护。在ES6之前,我们在JavaScript中实现继承是通过原型链来实现的。但是这种方式缺少了一个明确的语法结构,不够直观,而且容易出现错误。ES6中引入了类的概念,让我们能够更加方便、清晰地定义类和继承关系。下面我将详…

    JavaScript 2023年6月11日
    00
合作推广
合作推广
分享本页
返回顶部