canvas粒子流喷射动画效果代码

代码语言:html

所属分类:粒子

代码描述:canvas粒子流喷射动画效果代码

代码标签: 粒子流 喷射

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html>

<head>
   
<title>JavaScript Particle System</title>
   
<style>
        body
,html {
           
margin:0;
           
padding:0;
       
}
        canvas
{
           
background-color: black;
       
}
   
</style>
</head>

<body>
   
<canvas></canvas>


   
<script>
        "use strict";
       
        var maxParticles = 20000,
        particleSize = 1,
        emissionRate = 20,
        objectSize = 3; // drawSize of emitter/field
       
       
        var canvas = document.querySelector('canvas');
        var ctx = canvas.getContext('2d');
       
        canvas.width = window.innerWidth;
        canvas.height = window.innerHeight;
       
        function Particle(point, velocity, acceleration) {
          this.position = point || new Vector(0, 0);
          this.velocity = velocity || new Vector(0, 0);
          this.acceleration = acceleration || new Vector(0, 0);
        }
       
        Particle.prototype.submitToFields = function (fields) {
          // our starting acceleration this frame
          var totalAccelerationX = 0;
          var totalAccelerationY = 0;
       
          // for each passed field
          for (var i = 0; i < fields.length; i++) {
            var field = fields[i];
       
            // find the distance between the particle and the field
            var vectorX = field.position.x - this.position.x;
            var vectorY = field.position.y - this.position.y;
       
            // calculate the force via MAGIC and HIGH SCHOOL SCIENCE!
            var force = field.mass / Math.pow(vectorX * vectorX + vectorY * vectorY, 1.5);
       
            // add to the total acceleration the force adjusted by distance
            totalAccelerationX += vectorX * force;
            totalAccelerationY += vectorY * force;
          }
       
          // update our particle's acceleration
          this.acceleration = new Vector(totalAccelerationX, totalAccelerationY);
        };
       
        Particle.prototype.move = function () {
          this.velocity.add(this.acceleration);
          this.position.add(this.velocity);
        };
       
        function Field(point, mass) {
          this.position = point;
          this.setMass(mass);
        }
       
        Field.prototype.setMass = function (mass) {
          this.mass = mass || 100;
          this.drawColor = mass < 0 ? "#f00" : ".........完整代码请登录后点击上方下载按钮下载查看

网友评论0