简介

在codepen上看到一个Canvas做的下雨效果动画,感觉蛮有意思的。就研究了下,这里来分享下,实现技巧。

效果截图:

Canvas动画基础

大家都知道,Canvas其实只是一个画板。我们可以应用canvas的api在上面绘制各种图形。

那么Canvas绘制动画的步骤就是:

绘制第一帧图形(利用API绘图)

清空画板(应用clearRect()或fillRect())

绘制下一帧动画

用什么来控制动画每一帧的绘制时间呢?大家很容易想到 window.setInterval()和window.setTimeout()。没错用这两个也可以。除此之外,后来又出现一个新的方法:window.requestAnimationFrame(callback)。

requestAnimationFrame会告诉浏览器你要绘制一个动画。让浏览器要重绘时调用你指定的方法(callback)来绘制你的动画。

使用方法如下:

function anim() {

ctx.fillStyle = clearColor;

ctx.fillRect(0,0,w,h);

for(var i in drops){

drops[i].draw();

}

requestAnimationFrame(anim);

html怎么做下雨效果,Canvas制作的下雨动画的示例相关推荐

  1. Canvas制作的下雨动画

    简介 在codepen上看到一个Canvas做的下雨效果动画,感觉蛮有意思的.就研究了下,这里来分享下,实现技巧.效果可以见下面的链接. 霓虹雨: http://codepen.io/natewile ...

  2. php下雨效果源码,ps下雨效果制作步骤

    ps下雨效果制作步骤:首先打开ps软件,并导入一张图片素材:然后新建一个透明图层,并选择填充工具,将填充图层为白色:接着点击菜单栏的滤镜选项,并在弹出的列表选择像素化:最后在点状化的设置窗口中调整参数 ...

  3. php打字文本,怎么做打字效果视频 制作文字像打字那样出现并且有打字声音的视频 画面文字一个一个出...

    看电影或是电视剧的时候,会出现这样的一个字幕效果,就是在视频画面上字幕文字像打字那样画面文字一个一个出现并且有打字声音,有没有人跟我一样好奇的这样的字幕是怎么制作出来的,呵呵呵,我们一定要对身边的所有 ...

  4. 如何用html5 canvas制作子画面动画,如何用HTML5 Canvas制作子画面动画

    用户提问 为了用DOM做2D游戏,你基本上要动态地调整元素风格,以便在页面上移动它.虽然有些时候DOM修改是很好的,但这一次我将重点介绍使用HTML5 Canvas来制作图像,因为对于现代浏览器,它是 ...

  5. 带你使用canvas制作马赛克canvas飞鸟动画小球动画

    文章目录 canvas制作马赛克&飞鸟动画&小球拖拽动画 一.了解单像素操作 1.在canvas中的像素操作 2.得到场景像素数据 3.ImageData对象 4.在场景中写入像素数据 ...

  6. 从手机端 H5 制作来看 WEB 动画的术与道

    我们在微信朋友圈里经常看到很多人分享 H5 的链接,有的科技感十足,有的展示炫目,有的非常有创意,各大公司也把H5作为他们品牌传播,活动预热的很好方式.企业商户对于这种方式也很有好感,从而导致了 H5 ...

  7. Unity3d中使用自带动画系统制作下雨效果(一)

    之前看了以前版本的unity3d demo AngryBots ,觉得里面的下雨效果不错,刚好前段时间学习了,写出来跟大家分享下,直接开始. 使用自带动画系统制作下雨效果. 先制作下雨的雨滴涟漪. 步 ...

  8. php 3d animation,如何用HTML5的Canvas制作3D动画效果

    HTML5的诞生给web前端界带来了不小轰动,像什么动画旋转.图片滑块.图片轮播等等这些3D特效,也引发了不少朋友想要学习HTML5的好奇心.最近我一直在做canvas动画效果,发现canvas这个东 ...

  9. js制作的模拟超逼真下雨效果

    一层秋雨一层凉. 小楼一夜听春雨. 虞美人·听雨 少年听雨歌楼上.红烛昏罗帐.壮年听雨客舟中.江阔云低.断雁叫西风. 而今听雨僧庐下.鬓已星星也.悲欢离合总无情.一任阶前.点滴到天明. 我是那迷恋微雨 ...

最新文章

  1. RabbitMQ单机多实例配置
  2. python导入excel模块_Excel到python第一章python利用pandas和numpy模块导入数据
  3. ViewPager异常,对ViewPager源码分析
  4. Mac翻译软件Mate Translate
  5. java top tree 数据结构_Java中如何实现Tree的数据结构算法
  6. 沉没的王国---揭秘滇东自杞国(1)
  7. PEANUT-WF模块开发-HslCommunicationEx
  8. Linux基础知识小结(一)
  9. JavaScript 每日一题 #10
  10. html表格标题居于标题左侧,css如何设置表格标题(caption标签)的位置
  11. 自研数据分析工具——yandas系列一:分析泰坦尼克号沉船事件中的乘客信息表
  12. 思科9124光纤交换机配置管理使用手册
  13. 图片加水印怎么加,快速图片加水印?
  14. 每周一计-自己动手做的电源
  15. 关闭ssh隧道的几种“优雅”方式
  16. Numpy提取多维数组的某行/列
  17. 李笑来 css,CSS
  18. 今天是微信7周年 7年之痒 一切都已被改变
  19. 《Web安全之机器学习入门》笔记:第七章 7.6朴素贝叶斯检测DGA域名
  20. c#中文字符串与byte数组互相转化

热门文章

  1. 【卡尔曼滤波介绍与原理解析】
  2. 解决MobaXtem中使用vim不能复制到Windows
  3. perl 产生随机数
  4. git 命令带用户名密码
  5. 在 iOS13 及以前,App 请求用户定位授权时为如下形态
  6. 爬取房天下新房、二手房房源数据(scrapy-redis分布式爬虫)
  7. 美食自媒体好不好做?如何做好美食类账号
  8. Python GDAL矢量转栅格详解
  9. 自学编程,痛并快乐着
  10. Java Vs. C♯