首页 > 其他分享 >createjs、canvas烟花

createjs、canvas烟花

时间:2025-01-03 10:09:44浏览次数:1  
标签:canvas sky ctx 烟花 createjs ref stage

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        html,
        body {
            margin: 0;
            padding: 0;
        }

        body {
            background-color: #000;
        }

        canvas {
            display: block;
            margin: auto;
            -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
            -webkit-user-select: none;
        }
    </style>
</head>

<body>
    <canvas id="canvas"></canvas>
    <script src="https://code.createjs.com/createjs-2015.11.26.min.js"></script>
    <script>
        (function () {
            var Fireworks, GRAVITY, K, SPEED, ToRadian, canvas, context, ctx, fireBoss, repeat, stage;

            canvas = document.getElementById("canvas");

            context = canvas.getContext("2d");

            canvas.width = window.innerWidth;

            canvas.height = window.innerHeight;

            stage = new createjs.Stage(canvas);

            stage.autoClear = false;

            ctx = canvas.getContext("2d");

            ctx.fillStyle = "rgba(0, 0, 0, 0)";

            ctx.fillRect(0, 0, canvas.width, canvas.height);

            createjs.Ticker.setFPS(50);

            // createjs.Ticker.timingMode = createjs.Ticker.RAF_SYNCHED
            createjs.Touch.enable(stage);

            stage.update();

            // 重力
            GRAVITY = 0.6;

            // 抵抗
            K = 0.9;

            // 速度
            SPEED = 6;

            // 角度弧度(degree)(radian)変換
            ToRadian = function (degree) {
                return degree * Math.PI / 180.0;
            };

            // 制作烟火
            Fireworks = class Fireworks {
                constructor(sx = 100, sy = 100, particles = 70) {
                    var circle, i, j, rad, ref, speed;
                    this.sx = sx;
                    this.sy = sy;
                    this.particles = particles;
                    this.sky = new createjs.Container();
                    this.r = 0;
                    this.h = Math.random() * 360 | 0;
                    this.s = 100;
                    this.l = 50;
                    this.size = 3;
                    for (i = j = 0, ref = this.particles; (0 <= ref ? j < ref : j > ref); i = 0 <= ref ? ++j : --j) {
                        speed = Math.random() * 12 + 2;
                        circle = new createjs.Shape();
                        circle.graphics.f(`hsla(${this.h}, ${this.s}%, ${this.l}%, 1)`).dc(0, 0, this.size);
                        circle.snapToPixel = true;
                        circle.compositeOperation = "lighter";
                        rad = ToRadian(Math.random() * 360 | 0);
                        circle.set({
                            x: this.sx,
                            y: this.sy,
                            vx: Math.cos(rad) * speed,
                            vy: Math.sin(rad) * speed,
                            rad: rad
                        });
                        this.sky.addChild(circle);
                    }
                    stage.addChild(this.sky);
                }

                explode () {
                    var circle, j, p, ref;
                    if (this.sky) {
                        ++this.h;
                        for (p = j = 0, ref = this.sky.getNumChildren(); (0 <= ref ? j < ref : j > ref); p = 0 <= ref ? ++j : --j) {
                            circle = this.sky.getChildAt(p);
                            // 加速度
                            circle.vx = circle.vx * K;
                            circle.vy = circle.vy * K;
                            // 位置计算
                            circle.x += circle.vx;
                            circle.y += circle.vy + GRAVITY;
                            // 颜色
                            this.l = Math.random() * 100;
                            // 粒子大小
                            this.size = this.size - 0.001;
                            if (this.size > 0) {
                                circle.graphics.c().f(`hsla(${this.h}, 100%, ${this.l}%, 1)`).dc(0, 0, this.size);
                            }
                        }
                        if (this.sky.alpha > 0.1) {
                            this.sky.alpha -= K / 50;
                        } else {
                            stage.removeChild(this.sky);
                            this.sky = null;
                        }
                    } else {

                    }
                }

            };

            fireBoss = [];

            setInterval(function () {
                ctx.fillStyle = "rgba(0, 0, 0, 0.1)";
                ctx.fillRect(0, 0, canvas.width, canvas.height);
            }, 40);

            setInterval(function () {
                var x, y;
                x = Math.random() * canvas.width | 0;
                y = Math.random() * canvas.height | 0;
                fireBoss.push(new Fireworks(x, y));
                return fireBoss.push(new Fireworks(x, y));
            }, 1300);

            repeat = function () {
                var fireworks, j, ref;
                for (fireworks = j = 0, ref = fireBoss.length; (0 <= ref ? j < ref : j > ref); fireworks = 0 <= ref ? ++j : --j) {
                    if (fireBoss[fireworks].sky) {
                        fireBoss[fireworks].explode();
                    }
                }
                stage.update();
            };

            createjs.Ticker.on("tick", repeat);

            stage.addEventListener("stagemousedown", function () {
                fireBoss.push(new Fireworks(stage.mouseX, stage.mouseY));
                return fireBoss.push(new Fireworks(stage.mouseX, stage.mouseY));
            });

        }).call(this);

        //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":["<anonymous>"],"names":[],"mappings":"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","sourcesContent":["canvas = document.getElementById(\"canvas\")\ncontext = canvas.getContext(\"2d\")\ncanvas.width  = window.innerWidth\ncanvas.height = window.innerHeight\nstage = new createjs.Stage(canvas)\nstage.autoClear = false\nctx = canvas.getContext(\"2d\")\nctx.fillStyle = \"rgba(0, 0, 0, 0)\"\nctx.fillRect 0,0,canvas.width,canvas.height\ncreatejs.Ticker.setFPS(50)\n# createjs.Ticker.timingMode = createjs.Ticker.RAF_SYNCHED\ncreatejs.Touch.enable(stage)\nstage.update()\n\n# 重力\nGRAVITY = 1\n\n# 抵抗\nK = 0.9\n\n# スピード\nSPEED = 12\n\n# 角度(degree)からラジアン(radian)に変換\nToRadian = (degree) ->\n  degree * Math.PI / 180.0\n\n# 花火を作り上げるクラス\nclass Fireworks\n  constructor: (@sx = 100,@sy = 100,@particles = 70) ->\n    @sky = new createjs.Container()\n    @r = 0\n    @h = Math.random() * 360 | 0\n    @s = 100\n    @l = 50\n    @size = 3\n\n    for i in [0...@particles]\n      speed = Math.random() * 12 + 2\n      circle = new createjs.Shape()\n      circle.graphics.f(\"hsla(#{@h}, #{@s}%, #{@l}%, 1)\").dc(0, 0, @size)\n      circle.snapToPixel = true\n      circle.compositeOperation = \"lighter\"\n      rad = ToRadian(Math.random() * 360 | 0)\n\n      circle.set({\n        x: @sx\n        y: @sy\n        vx: Math.cos(rad) * speed\n        vy: Math.sin(rad) * speed\n        rad: rad\n      })\n\n      @sky.addChild circle\n\n    stage.addChild @sky\n\n  explode: ->\n    if @sky\n      ++@h\n      for p in [0...@sky.getNumChildren()]\n        circle = @sky.getChildAt(p)\n\n        # 加速度\n        circle.vx = circle.vx * K\n        circle.vy = circle.vy * K\n\n        # 位置計算\n        circle.x += circle.vx\n        circle.y += circle.vy + GRAVITY\n\n        # 色\n        @l = Math.random() * 100\n        # パーティクルのサイズ\n        @size = @size - 0.001\n        if @size > 0\n          circle.graphics.c().f(\"hsla(#{@h}, 100%, #{@l}%, 1)\").dc(0, 0, @size)\n\n      if @sky.alpha > 0.1\n        @sky.alpha -= K / 50\n      else\n        stage.removeChild @sky\n        @sky = null\n\n    else\n\n    return\n\nfireBoss = []\n\nsetInterval(->\n  ctx.fillStyle = \"rgba(0, 0, 0, 0.1)\"\n  ctx.fillRect 0,0,canvas.width,canvas.height\n  return\n,40)\n\nsetInterval(->\n  x = Math.random() * canvas.width | 0\n  y = Math.random() * canvas.height | 0\n  fireBoss.push new Fireworks(x,y)\n  fireBoss.push new Fireworks(x,y)\n,1300)\n\nrepeat = ->\n  for fireworks in [0...fireBoss.length]\n    if fireBoss[fireworks].sky\n      fireBoss[fireworks].explode()\n\n  stage.update()\n\n  return\n\ncreatejs.Ticker.on(\"tick\", repeat)\n\nstage.addEventListener \"stagemousedown\", ->\n  fireBoss.push new Fireworks(stage.mouseX,stage.mouseY)\n  fireBoss.push new Fireworks(stage.mouseX,stage.mouseY)"]}
        //# sourceURL=coffeescript
    </script>
</body>

</html>

 

标签:canvas,sky,ctx,烟花,createjs,ref,stage
From: https://www.cnblogs.com/yuwen1995/p/18649446

相关文章

  • 8k分辨率下html2canvas不支持文本缩放的解决方案
    文章目录背景常规方案安装依赖引入依赖使用出现问题html2canvas原理解析局限性解决方案dom-to-image库安装依赖引入dom-to-image使用dom-to-image原理创建虚拟DOM副本渲染虚拟DOM为SVG或其他格式导出为图片数据`dom-to-image`的相关方法背景前端同......
  • 【源码解读】25年跨年 一起来放个烟花吧
    跨年烟花前端代码分析最近我研究了一个跨年烟花的前端项目,代码非常有趣且复杂。通过分析这个项目,我学到了很多关于前端动画、Canvas渲染、物理模拟以及状态管理的知识。以下是我对这个项目的详细分析。项目预览地址》》源代码传送门》》跨年烟花项目概述这个项......
  • 如何快速写一个跨年放烟花的代码(动态效果)
    1.新建一个txt文档2.将以下代码复制粘贴到你新建的txt文档里面<!DOCTYPEhtml><htmllang="zh-CN"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0">......
  • 《2025烟花代码:为家人与爱人定制专属的烟花记忆》
    《2025烟花代码:为家人与爱人定制专属的烟花记忆》......
  • canvas使用方法
    <canvasid="canvas"width="600"height="600"></canvas>constcanvas=document.getElementById("canvas");constctx=canvas.getContext("2d");//获取2D渲染上下文对象ctx.fillStyle="green"......
  • 使用canvas制作一个烟花的动画效果
    要使用HTML5的<canvas>元素来制作一个烟花动画效果,你需要遵循以下步骤:设置HTML结构:<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-sca......
  • 如何在canvas画布上特定位置监听鼠标事件?
    在HTML5的Canvas元素上监听特定位置的鼠标事件稍微有些复杂,因为Canvas本身是一个像素画布,它不像DOM元素那样具有内置的事件处理机制来直接处理特定位置的事件。不过,你可以通过监听Canvas元素的鼠标事件,并在事件处理函数中检查鼠标的位置来实现类似的功能。以下是一个简单的示例,展......
  • 使用canvas制作一张优惠券
    使用HTML的<canvas>元素来制作一张优惠券是一个有趣且实用的前端开发项目。以下是一个简单的步骤指南,帮助你开始制作自己的优惠券:1.创建HTML结构首先,你需要在HTML文件中创建一个<canvas>元素。<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><meta......
  • 使用Canvas画一只会跟着鼠标走的小狗
    在前端开发中,使用HTML5的<canvas>元素和JavaScript来创建一个会跟随鼠标移动的小狗是一个有趣的项目。下面是一个基本的步骤指南,帮助你开始这个项目:1.设置HTML结构首先,你需要在HTML文件中创建一个<canvas>元素。<!DOCTYPEhtml><htmllang="en"><head><metacharset="U......
  • 使用canvas制作一个画板
    创建一个简单的画板应用使用HTML5的<canvas>元素是一个很好的项目,可以帮助你理解前端开发中的一些基本概念。以下是一个简单的画板应用的实现步骤:HTML结构首先,你需要在HTML中放置一个<canvas>元素,并给它一个ID,以便我们可以在JavaScript中引用它。<!DOCTYPEhtml><htmllang=......