看到网上很多展示html5雪花飞动的效果,确实非常引人入胜,我相信大家也跟我一样看着心动的同时,也很好奇,想研究下代码如何实现;虽然很多地方也能下载这些源码,不过也不知道别人制作此类动画时的思路及难点分析。

我这几天刚好学习了一下,也趁着此刻有时间从需求分析、知识点、程序编写一步步给大家解剖下,要是在各位关公面前耍大刀了,可别见笑哟。

最终效果图如下:

HTML5 canvas实现雪花飘落特效-1.jpg (81.77 KB, 下载次数: 0)

2020-7-7 19:03 上传

图1

一、需求分析

1、圆形雪花

本示例中雪花形状使用圆形

2、雪花数量固定

根据图1仔细观察白色雪花数量,飘落过程中,整张图的雪花数量应该是固定的,这个需求是需要通过我们观察分析所得。这与我们现实生活中看到一幅雪花满天飞的场景是一致的。

3、雪花大小不一致

每朵雪花它们大小各有不同,也就意味着雪花的半径是随机的。这与我们现实生活中看到一幅雪花满天飞的场景也是一致的。

4、雪花位置在移动

雪花飘落,自然它们的位置也在移动。

二、知识点

1、使用Html5 Canvas+JavaScript画圆——构成圆形雪花

在Html5中,需要使用Canvas同时借助JavaScript画圆,以构成圆形雪花——arc(x,y,r,start,stop);

2、随机数—产生不同半径、坐标的圆形雪花

本示例中,网页第一次加载时,需要生成一定数量的不同半径及位置的雪花,故半径、坐标为随机数;雪花在飘落过程中,其半径不变,坐标在一定幅度内变化,故此时坐标也为随机数——Math.random()

三、程序编写

1、准备工作

放一个画布canvas,并且设置整个body背景色为黑色

HTML代码:

XML/HTML Code复制内容到剪贴板

您的浏览器不支持canvas画布

CSS代码:

CSS Code复制内容到剪贴板

* {       margin: 0;

padding: 0;   }

#mycanvas {

background: black;   }

此时效果如如下:

HTML5 canvas实现雪花飘落特效-2.jpg (2.35 KB, 下载次数: 0)

2020-7-7 19:03 上传

注意:canvas默认是有一个初始化高度和宽度的,所以不用去纠结

2、画布满屏显示

JavaScript代码如下:

JavaScript Code复制内容到剪贴板

//获取mycanvas画布       var can = document.getElementById("mycanvas");

var ctx = can.getContext("2d");       //画布宽度

var wid = window.innerWidth;       //画布高度

var hei = window.innerHeight;       can.width=wid;

can.height=hei;

此时效果如如下:

HTML5 canvas实现雪花飘落特效-3.jpg (2.35 KB, 下载次数: 0)

2020-7-7 19:03 上传

3、初始化生成固定数量的雪花

根据我们上述需求分析及知识点解读,首先雪花的数量是固定的,所以我们需要定义一个变量var snow = 100;这里假设雪花数量为100,;

生成雪花的时候,每个雪花半径、位置都不同,我们把每个雪花当做一个对象,那么这个对象的属性就包含:半径、坐标(X、Y),那么一个雪花对象可以写成var snowOject={x:1,y:10,r:5},这里就代表一个坐标为(1,10)半径为5的圆形雪花;本示例中由于半径和坐标都为随机数,故使用Math.random()分别为100个雪花生成半径、坐标(X、Y);

那我们这里是100个雪花,所以为了方便后面操作,就用一个数组保存这100个雪花对象。

JavaScript代码如下:

JavaScript Code复制内容到剪贴板

//雪花数目   var snow = 100;

//雪花坐标、半径   var arr = []; //保存各圆坐标及半径

for (var i = 0; i < snow; i++) {   arr.push({

x: Math.random() * wid,   y: Math.random() * hei,

r: Math.random() * 10 + 1   })

}

4、绘制雪花

上面我们已经将100个雪花半径、坐标(X、Y)生成,下面就是循环使用canvas画出雪花了(这里就是画圆),这里定义一个函数

JavaScript代码如下:

JavaScript Code复制内容到剪贴板

//画雪花   function DrawSnow() {

ctx.fillStyle="white";       ctx.beginPath();

for (var i = 0; i < snow; i++) {           var p = arr;

ctx.moveTo(p.x,p.y);           ctx.arc(p.x,p.y,p.r,0,2*Math.PI,false);

}       ctx.fill();

ctx.closePath();

然后调用 DrawSnow()函数,效果如下:

HTML5 canvas实现雪花飘落特效-4.jpg (8.18 KB, 下载次数: 0)

2020-7-7 19:03 上传

可以尝试多次刷新网页看是否会生成不同大小、位置的雪花(正常情况下是可以的),做到这里就已经接近最终效果了

注意:由于这里需要绘制100个圆,所以每当画一个圆时重新定义绘制开始坐标即:ctx.moveTo(p.x,p.y);否则会出现异样效果,不信可以试试呀

5、雪花飘动

上面我们已经画出100个雪花,可惜只能依靠刷新网页才能看到变化效果,但是我们需要实现的是雪花不停的移动位置。

首先我们需要借助setInterval函数不停的重画雪花,这里间隔时间为50毫秒:setInterval(DrawSnow,50);

同时每一朵雪花的坐标(X、Y)需要不停的改变(在一定幅度内),我们这里的雪花是从左上方飘落到右下方,所以每朵X、Y坐标值都在不停的增大,那我们用一个函数SnowFall()定义雪花飘过规则

该函数代码如下:

JavaScript Code复制内容到剪贴板

//雪花飘落   function SnowFall() {

for (var i = 0; i < snow; i++) {           var p = arr;

p.y += Math.random() * 2 + 1;           if (p.y > hei) {

p.y = 0;           }

p.x += Math.random() * 2 + 1;           if (p.x > wid) {

p.x = 0;           }

}   }

然后将该函数放入DrawSnow()执行,注意:我们每隔50毫毛重画雪花,必须擦除画布,所以DrawSnow()函数体内必须在前面执行clearRect()函数,即:ctx.clearRect(0, 0, wid, hei);

此时DrawSnow函数定义如下:

JavaScript Code复制内容到剪贴板

//画雪花   function DrawSnow() {

ctx.clearRect(0, 0, wid, hei);       ctx.fillStyle = "white";

ctx.beginPath();       for (var i = 0; i < snow; i++) {

var p = arr;           ctx.moveTo(p.x, p.y);

ctx.arc(p.x, p.y, p.r, 0, 2 * Math.PI, false);       }

ctx.fill();       SnowFall();

ctx.closePath();   }

最后执行setInterval(DrawSnow, 50);

OK,经过我们上述步骤,小伙伴们是否已经对整个过程及技术实现很清晰了。

完整代码如下(大家可以直接复制到自己项目中执行,测试下效果):

XML/HTML Code复制内容到剪贴板

* {                   margin: 0;

padding: 0;               }

#mycanvas {

background: black;               }

您的浏览器不支持canvas画布

//获取mycanvas画布               var can = document.getElementById("mycanvas");

var ctx = can.getContext("2d");               //画布宽度

var wid = window.innerWidth;               //画布高度

var hei = window.innerHeight;               can.width = wid;

can.height = hei;               //雪花数目

var snow = 100;               //雪花坐标、半径

var arr = []; //保存各圆坐标及半径               for (var i = 0; i < snow; i++) {

arr.push({                       x: Math.random() * wid,

y: Math.random() * hei,                       r: Math.random() * 10 + 1

})               }

//画雪花               function DrawSnow() {

ctx.clearRect(0, 0, wid, hei);                   ctx.fillStyle = "white";

ctx.beginPath();                   for (var i = 0; i < snow; i++) {

var p = arr;                       ctx.moveTo(p.x, p.y);

ctx.arc(p.x, p.y, p.r, 0, 2 * Math.PI, false);                   }

ctx.fill();                   SnowFall();

ctx.closePath();               }

//雪花飘落               function SnowFall() {

for (var i = 0; i < snow; i++) {                       var p = arr;

p.y += Math.random() * 2 + 1;                       if (p.y > hei) {

p.y = 0;                       }

p.x += Math.random() * 2 + 1;                       if (p.x > wid) {

p.x = 0;                       }

}               }

setInterval(DrawSnow, 50);

好了,今天分享就到这里,希望对大家的学习有所帮助。

原文:http://www.cnblogs.com/tangyifeng/p/5253629.html

html制作雪花飘落海报,HTML5 canvas实现雪花飘落特效相关推荐

  1. HTML5 canvas绘制雪花飘落动画(需求分析、知识点、程序编写分布详解)

    HTML5 canvas绘制雪花飘落动画(需求分析.知识点.程序编写分布详解) 原文:HTML5 canvas绘制雪花飘落动画(需求分析.知识点.程序编写分布详解) 看到网上很多展示html5雪花飞动 ...

  2. html画布敲碎的视频,html5 canvas碎纸屑空中飘落动画特效

    特效描述:html5 canvas碎纸屑 空中飘落动画特效.canvas绘制空中飘落的纸屑动画特效. 代码结构 1. HTML代码 "use strict"; var _creat ...

  3. 手机特效html,支持移动手机的HTML5 Canvas刮刮卡特效

    这是一款支持移动手机的HTML5 Canvas刮刮卡特效.该刮刮卡特效通过Canvas来前后两张图片的刮卡效果,支持桌面端和移动端. 使用方法 HTML结构 使用 元素来制作刮卡. ...... CS ...

  4. html 流动效果,html5 canvas流动的海浪特效

    特效描述:html5canvas 流动的海浪特效.html5 canvas流动的海浪特效 代码结构 1. 引入JS 2. HTML代码 'use strict'; var gui = new dat. ...

  5. html 画动画效果,html5 canvas绘制曲线动画特效

    特效描述:html5 canvas绘制 曲线动画特效. 代码结构 1. HTML代码 Balls Size Speed Delay Go! Presets: Atomic Flower Spiro Y ...

  6. html银河特效编码,html5 canvas银河星系动画特效

    特效描述:html5 canvas 银河星系动画特效.html5 canvas绘制闪闪发光移动的银河星系背景动画特效.(上传服务器正常演示,本地无法直接预览) 代码结构 1. 引入JS 2. HTML ...

  7. html5波浪效果,html5 canvas粒子波浪动画特效

    特效描述:html5 canvas 粒子波浪动画特效.html5基于canvas绘制波涛汹涌的粒子波浪动画. 代码结构 1. HTML代码 'use strict'; var FastRandom = ...

  8. html5 运动轨迹绘画,html5 canvas行星运动轨迹动画特效

    特效描述:html5 canvas 行星运动 轨迹动画特效.html5运动轨迹,行星动画特效 代码结构 1. 引入JS 2. HTML代码 Your browser doesn't support c ...

  9. html5给页面添加树叶特效,html5 canvas树叶光标动画特效

    特效描述:html5 canvas树叶 光标动画特效.html5 canvas虚幻的树叶光标动画. 代码结构 1. 引入JS 2. HTML代码 // Hold mouse down to enter ...

  10. HTML5 Canvas爱心表白动画特效

    代码自用自取,复制粘贴直接使用,喜欢的话可以查看博主其它文章,贡献一丢丢的浏览量,感激不尽. 先看一下效果 <!doctype html> <html> <head> ...

最新文章

  1. matlab 一个赋值变量赋值,MATLAB 基本语法----变量与赋值
  2. 用结点实现链表LinkedList,用数组和结点实现栈Stack,用数组和结点链表实现队列Queue
  3. 2021年5月信息系统项目管理师案例分析真题+视频讲解(3)
  4. 第十一篇:(顺序)容器的好伴侣 --- 容器适配器
  5. oracle导致的负载高,Oracle 11g 数据库服务器CPU、IO负载高的故障排除流程
  6. 计算机安全日志,如何回复被删除的电脑安全日志
  7. 【剑指 offer】(二十一)—— 包含 min 函数的栈
  8. vscode android调试,使用VsCode开发调试React Native笔记
  9. [转载]心灵丨愿你早一点发现,你才是自己最重要的粉丝
  10. access 数据库目录权限只读引起asp的访问错误
  11. 高校后勤管理系统java代码_java毕业设计_springboot框架的高校后勤信息管理系统...
  12. java 汉字处理_Java汉字处理
  13. 【记一下1】2022年6月29日 哥和弟 双重痛苦
  14. linux的ioctl函数实现
  15. Error:代理服务器拒绝链接
  16. 一师兄的面试经历:对于销售职位来…
  17. 电脑上怎么剪切、合并音乐
  18. 一线咨询师的絮絮叨叨
  19. 如何切换中英文输入法及全角/半角?(原创)
  20. 【数据构造】手机号码并发生成

热门文章

  1. OJ期末刷题 问题 B: 求三角形面积-gyy
  2. implode 与 explode 区别
  3. HTML学习的第三天
  4. 看完你就明白的锁系列之自旋锁
  5. Java接口测试工具rap_接口文档管理工具-Postman、Swagger、RAP(转载)
  6. 点击图标分享页面到QQ,微信,微博 等
  7. 【数据分析/挖掘】如何处理类别型特征?常用编码方式?Python实现?
  8. asp.net 下载文件几种方式
  9. 世界时、国际原子时、协调世界时到底有什么联系(最简单易懂版)
  10. mysql count判断_【MySQL】COUNT