在好例子网,分享、交流、成长!
您当前所在位置:首页CSS 开发实例Box Model → canvas实现流星雨效果(棒棒哒)

canvas实现流星雨效果(棒棒哒)

Box Model

下载此实例
  • 开发语言:CSS
  • 实例大小:0.05M
  • 下载次数:19
  • 浏览次数:678
  • 发布时间:2018-08-24
  • 实例类别:Box Model
  • 发 布 人:crazycode
  • 文件格式:.zip
  • 所需积分:2
 相关标签: Canvas 流星雨

实例介绍

【实例简介】

【实例截图】

【核心代码】

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/***/ function(module, exports) {
 
    'use strict';
     
    var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i  ) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
     
    function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
     
    // 坐标
    var Crood = function () {
        function Crood() {
            var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
            var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
     
            _classCallCheck(this, Crood);
     
            this.x = x;
            this.y = y;
        }
     
        _createClass(Crood, [{
            key: 'setCrood',
            value: function setCrood(x, y) {
                this.x = x;
                this.y = y;
            }
        }, {
            key: 'copy',
            value: function copy() {
                return new Crood(this.x, this.y);
            }
        }]);
     
        return Crood;
    }();
     
    // 流星
     
     
    var ShootingStar = function () {
        function ShootingStar() {
            var init = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Crood();
            var final = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Crood();
            var size = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 3;
            var speed = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 200;
            var onDistory = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
     
            _classCallCheck(this, ShootingStar);
     
            this.init = init; // 初始位置
            this.final = final; // 最终位置
            this.size = size; // 大小
            this.speed = speed; // 速度:像素/s
     
            // 飞行总时间
            this.dur = Math.sqrt(Math.pow(this.final.x - this.init.x, 2)   Math.pow(this.final.y - this.init.y, 2)) * 1000 / this.speed;
     
            this.pass = 0; // 已过去的时间
            this.prev = this.init.copy(); // 上一帧位置
            this.now = this.init.copy(); // 当前位置
            this.onDistory = onDistory;
        }
     
        _createClass(ShootingStar, [{
            key: 'draw',
            value: function draw(ctx, delta) {
                this.pass  = delta;

标签: Canvas 流星雨

实例下载地址

canvas实现流星雨效果(棒棒哒)

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警