原生JS实现的雪花飘落动画效果


Posted in Javascript onMay 03, 2018

本文实例讲述了原生JS实现的雪花飘落动画效果。分享给大家供大家参考,具体如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <title>3water.com JS下雪动画</title>
  <meta name="description" content="">
  <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<style>
  .masthead {
    background-color:#333;
    display:block;
    width:100%;
    height:400px;
  }
</style>
<body>
<div class="masthead"></div>
<script>
  (function () {
    var COUNT = 300;
    var masthead = document.querySelector('.masthead');
    var canvas = document.createElement('canvas');
    var ctx = canvas.getContext('2d');
    var width = masthead.clientWidth;
    var height = masthead.clientHeight;
    var i = 0;
    var active = false;
    function onResize() {
      width = masthead.clientWidth;
      height = masthead.clientHeight;
      canvas.width = width;
      canvas.height = height;
      ctx.fillStyle = '#FFF';
      var wasActive = active;
      active = width > 600;
      if (!wasActive && active)
        requestAnimFrame(update);
    }
    var Snowflake = function () {
      this.x = 0;
      this.y = 0;
      this.vy = 0;
      this.vx = 0;
      this.r = 0;
      this.reset();
    };
    Snowflake.prototype.reset = function() {
      this.x = Math.random() * width;
      this.y = Math.random() * -height;
      this.vy = 1 + Math.random() * 3;
      this.vx = 0.5 - Math.random();
      this.r = 1 + Math.random() * 2;
      this.o = 0.5 + Math.random() * 0.5;
    };
    canvas.style.position = 'absolute';
    canvas.style.left = canvas.style.top = '0';
    var snowflakes = [], snowflake;
    for (i = 0; i < COUNT; i++) {
      snowflake = new Snowflake();
      snowflakes.push(snowflake);
    }
    function update() {
      ctx.clearRect(0, 0, width, height);
      if (!active)
        return;
      for (i = 0; i < COUNT; i++) {
        snowflake = snowflakes[i];
        snowflake.y += snowflake.vy;
        snowflake.x += snowflake.vx;
        ctx.globalAlpha = snowflake.o;
        ctx.beginPath();
        ctx.arc(snowflake.x, snowflake.y, snowflake.r, 0, Math.PI * 2, false);
        ctx.closePath();
        ctx.fill();
        if (snowflake.y > height) {
          snowflake.reset();
        }
      }
      requestAnimFrame(update);
    }
    // shim layer with setTimeout fallback
    window.requestAnimFrame = (function(){
      return window.requestAnimationFrame    ||
          window.webkitRequestAnimationFrame ||
          window.mozRequestAnimationFrame  ||
          function( callback ){
            window.setTimeout(callback, 1000 / 60);
          };
    })();
    onResize();
    window.addEventListener('resize', onResize, false);
    masthead.appendChild(canvas);
  })();
</script></body></html>

使用本站HTML/CSS/JS在线运行测试工具:http://tools.3water.com/code/HtmlJsRun,可得到如下测试运行效果:

原生JS实现的雪花飘落动画效果

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
用javascript实现的支持lrc歌词的播放器
May 17 Javascript
瀑布流布局代码一例
Apr 11 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
Feb 20 Javascript
Javascript中String的常用方法实例分析
Jun 13 Javascript
Jquery promise实现一张一张加载图片
Nov 13 Javascript
javascript实现简单加载随机色方块
Dec 25 Javascript
详解VUE-地区选择器(V-Distpicker)组件使用心得
May 07 Javascript
vue打包之后生成一个配置文件修改接口的方法
Dec 09 Javascript
JavaScript实现小球沿正弦曲线运动
Sep 07 Javascript
微信小程序如何修改本地缓存key中单个数据的详解
Apr 26 Javascript
vue-resource 拦截器interceptors使用详解
Jan 18 Vue.js
nestjs中异常过滤器Exceptionfilter的具体使用
Feb 07 Javascript
详解vuex结合localstorage动态监听storage的变化
May 03 #Javascript
React为 Vue 引入容器组件和展示组件的教程详解
May 03 #Javascript
VUE Error: getaddrinfo ENOTFOUND localhost
May 03 #Javascript
原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
May 03 #Javascript
Angular学习教程之RouterLink花式跳转
May 03 #Javascript
JS中判断某个字符串是否包含另一个字符串的五种方法
May 03 #Javascript
Vue表单类的父子组件数据传递示例
May 03 #Javascript
You might like
PHP mcrypt可逆加密算法分析
2011/07/19 PHP
JS JavaScript获取Url参数,src属性参数
2021/03/09 Javascript
使用CSS3实现字体颜色渐变的实现
2021/03/09 HTML / CSS
教您去掉ie网页加载进度条的方法
2010/12/09 Javascript
JavaScript自定义DateDiff函数(兼容所有浏览器)
2012/03/01 Javascript
JavaScript去除空格的三种方法(正则/传参函数/trim)
2013/02/06 Javascript
复选框全选与全不选操作实现思路
2013/08/18 Javascript
jquery表单验证需要做些什么
2015/11/17 Javascript
点击按钮出现60秒倒计时的简单js代码(推荐)
2016/06/07 Javascript
jquery实现图片上传前本地预览
2017/04/28 jQuery
JS实现的加减乘除四则运算计算器示例
2017/08/09 Javascript
vue.js默认路由不加载linkActiveClass问题的解决方法
2017/12/11 Javascript
Vue验证码60秒倒计时功能简单实例代码
2018/06/22 Javascript
Layui 数据表格批量删除和多条件搜索的实例
2019/09/04 Javascript
vue计算属性+vue中class与style绑定(推荐)
2020/03/30 Javascript
[05:41]2014DOTA2西雅图国际邀请赛 小组赛7月10日TOPPLAY
2014/07/10 DOTA
用Python编写一个国际象棋AI程序
2014/11/28 Python
Python中splitlines()方法的使用简介
2015/05/20 Python
python程序封装为win32服务的方法
2021/03/07 Python
对python For 循环的三种遍历方式解析
2019/02/01 Python
Django框架模板文件使用及模板文件加载顺序分析
2019/05/23 Python
python实现随机漫步方法和原理
2019/06/10 Python
python正则-re的用法详解
2019/07/28 Python
Django-rest-framework中过滤器的定制实例
2020/04/01 Python
零基础学python应该从哪里入手
2020/08/11 Python
CSS3的文字阴影—text-shadow的使用方法
2012/12/25 HTML / CSS
西班牙宠物用品和食品网上商店:Tiendanimal
2019/06/06 全球购物
七年级生物教学反思
2014/01/30 职场文书
2014新年元旦活动策划方案
2014/02/18 职场文书
人力资源主管职责范本
2014/03/05 职场文书
高中军训第一天感言
2014/03/06 职场文书
校庆筹备方案
2014/03/30 职场文书
祖国在我心中演讲稿600字
2014/05/04 职场文书
国旗下的讲话演讲稿
2014/05/08 职场文书
详细总结Python常见的安全问题
2021/05/21 Python
MySQL中varchar和char类型的区别
2021/11/17 MySQL