canvas实现爱心和彩虹雨效果


Posted in Javascript onMarch 09, 2017

效果图:

canvas实现爱心和彩虹雨效果

代码如下:

<!doctype html>
 <html>
 <head>
 <meta charset="utf-8">
 <title></title>
 </head>
 <body>
 <canvas id="canvas"></canvas>
 <script>
 var canvas = document.getElementById('canvas'),
 ctx = canvas.getContext('2d'),
 canvasW = canvas.width = window.innerWidth,
 canvasH = canvas.height = window.innerHeight,
 canvasWHalf = canvasW / 2,
 canvasHHalf = canvasH / 2,
 xoff = canvasWHalf - 306,
 yoff = 50,
 bg = '00061a',
 id = 0,
 raindrops = [],
 minSize = 1,
 maxSize = 4,
 minSpeed = 5,
 maxSpeed = 20,
 minHue = 0,
 maxHue = 360,
 maxAmount = 50;
 function random(min, max) {
 if (arguments.length < 2) {
  max = min;
  min = 0;
 }
 return Math.floor(Math.random() * (max - min) + min);
 }
 function hexToRGB(hex, opacity) {
 var rgb = '';
 hex.match(/.{2}/g).forEach(function(n) {
  rgb += (parseInt(n, 16)) + ',';
 });
 return 'rgba(' + rgb + opacity + ')';
 }
 function draw() {
 // Heart
 ctx.fillStyle = hexToRGB(bg, '0.1');
 ctx.beginPath();
 // Left half
 ctx.moveTo(0, 0);
 ctx.lineTo(canvasWHalf, 0);
 ctx.lineTo(304 + xoff, 97 + yoff);
 ctx.bezierCurveTo(282 + xoff, -5 + yoff, 80 + xoff, -6 + yoff, 76 + xoff, 165 + yoff);
 ctx.bezierCurveTo(74 + xoff, 251 + yoff, 184 + xoff, 300 + yoff, 304 + xoff, 447 + yoff);
 ctx.lineTo(canvasWHalf, canvasH);
 ctx.lineTo(0, canvasH);
 // Right half
 ctx.moveTo(canvasW, 0);
 ctx.lineTo(canvasWHalf, 0);
 ctx.lineTo(304 + xoff, 97 + yoff);
 ctx.bezierCurveTo(326 + xoff, 5 + yoff, 528 + xoff, 6 + yoff, 532 + xoff, 165 + yoff);
 ctx.bezierCurveTo(534 + xoff, 251 + yoff, 424 + xoff, 300 + yoff, 304 + xoff, 447 + yoff);
 ctx.lineTo(canvasWHalf, canvasH);
 ctx.lineTo(canvasW, canvasH);
 ctx.closePath();
 ctx.fill();
 // Raindrops
 for (var i = 1; i < id; i++) {
  raindrops[i].fall();
 };
 }
 var Raindrop = function() {
 id++;
 this.y = random(-canvasH);
 this.x = random(canvasW);
 this.size = random(minSize, maxSize);
 this.speed = random(minSpeed, maxSpeed);
 this.color = 'hsl(' + random(minHue, maxHue) + ',100%,55%)';
 this.origColor = this.color;
 this.id = id;
 raindrops[id] = this;
 };
 Raindrop.prototype.fall = function() {
 this.y += this.speed;
 if (this.y >= canvasH) {
  this.y = random(-canvasH);
  this.x = random(canvasW);
 }
 ctx.save();
 ctx.beginPath();
 var gradient = ctx.createRadialGradient(this.x, this.y, 0, this.x, this.y, this.size);
 gradient.addColorStop(0, '#fff');
 gradient.addColorStop(0.5, this.color);
 gradient.addColorStop(1, hexToRGB(bg, 0));
 ctx.rect(this.x, this.y, this.size, maxSpeed);
 ctx.fillStyle = gradient;
 ctx.fill();
 ctx.closePath();
 ctx.restore();
 };
 (function init() {
 ctx.fillStyle = '#' + bg;
 ctx.fillRect(0, 0, canvasW, canvasH);
 for (var i = 0; i < maxAmount; i++) {
  new Raindrop();
 }
 }());
 function animate() {
 draw();
 window.requestAnimationFrame(animate);
 }
 window.requestAnimationFrame(animate);
 function mouseTrail(x, y) {
 ctx.save();
 ctx.globalCompositeOperation = 'overlay';
 ctx.fillStyle = 'rgba(255,255,255,0.1)';
 ctx.arc(x, y, 50, 0, Math.PI * 2);
 ctx.fill();
 ctx.restore();
 }
 window.addEventListener('mousemove', function(cursor) {
 mouseTrail(cursor.x, cursor.y);
 });
 </script>
 </body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
[原创]网络复制内容时常用的正则+editplus
Nov 30 Javascript
javascript下操作css的float属性的特殊写法
Aug 22 Javascript
如何确保JavaScript的执行顺序 之jQuery.html并非万能钥匙
Mar 03 Javascript
jsp+javascript打造级连菜单的实例代码
Jun 14 Javascript
jQuery-ui引入后Vs2008的无智能提示问题解决方法
Feb 10 Javascript
jQuery表单验证插件解析(推荐)
Jul 21 Javascript
JSONP基础知识详解
Mar 19 Javascript
vue实现图片加载完成前的loading组件方法
Feb 05 Javascript
基于Angular中ng-controller父子级嵌套的相关属性详解
Oct 08 Javascript
jQuery实现简单评论功能
Aug 19 jQuery
vue组件中实现嵌套子组件案例
Aug 31 Javascript
vue-router定义元信息meta操作
Dec 07 Vue.js
vue如何实现observer和watcher源码解析
Mar 09 #Javascript
详解VueJs异步动态加载块
Mar 09 #Javascript
微信小程序 设置启动页面的两种方法
Mar 09 #Javascript
js实现登录框鼠标拖拽效果
Mar 09 #Javascript
解决Node.js使用MySQL出现connect ECONNREFUSED 127.0.0.1:3306的问题
Mar 09 #Javascript
基于vue实现分页/翻页组件paginator示例
Mar 09 #Javascript
vue.js利用Object.defineProperty实现双向绑定
Mar 09 #Javascript
You might like
PHP Oauth授权和本地加密实现方法
2016/08/12 PHP
PHP实现APP微信支付的实例讲解
2018/02/10 PHP
禁止直接访问php文件代码分享
2020/05/05 PHP
判断多个元素(RADIO,CHECKBOX等)是否被选择的原理说明
2009/02/18 Javascript
JS文本框不能输入空格验证方法
2013/03/19 Javascript
js Array对象的扩展函数代码
2013/04/24 Javascript
使用JavaScript 实现各种跨域的方法
2013/05/08 Javascript
jquery操作HTML5 的data-*的用法实例分享
2014/08/17 Javascript
js调试工具Console命令详解
2014/10/21 Javascript
nodejs实现获取当前url地址及url各种参数值
2015/06/25 NodeJs
Bootstrap下拉菜单效果实例代码分享
2016/06/30 Javascript
Bootstrap的fileinput插件实现多文件上传的方法
2016/09/05 Javascript
JavaScript实现瀑布流以及加载效果
2017/02/11 Javascript
Vue常用指令V-model用法
2017/03/08 Javascript
浅谈Node模块系统及其模式
2017/11/17 Javascript
element-ui 表格数据时间格式化的方法
2018/08/24 Javascript
解决Vue 刷新页面导航显示高亮位置不对问题
2019/12/25 Javascript
JQuery获得内容和属性方法解析
2020/05/30 jQuery
在Django的模型中执行原始SQL查询的方法
2015/07/21 Python
zookeeper python接口实例详解
2018/01/18 Python
Python读取图片为16进制表示简单代码
2018/01/19 Python
解决Shell执行python文件,传参空格引起的问题
2018/10/30 Python
python 弹窗提示警告框MessageBox的实例
2019/06/18 Python
python之pexpect实现自动交互的例子
2019/07/25 Python
解决PyCharm无法使用lxml库的问题(图解)
2020/12/22 Python
如何用python实现一个HTTP连接池
2021/01/14 Python
html5 CSS过度-webkit-transition使用介绍
2013/07/02 HTML / CSS
HTML5实现无刷新修改URL的方法
2019/11/14 HTML / CSS
阿玛尼意大利官网:Armani意大利
2018/10/30 全球购物
岗位竞聘书范文
2014/03/31 职场文书
寒山寺导游词
2015/02/03 职场文书
酒店员工管理制度
2015/08/05 职场文书
选对餐饮营销策略,营业额才会上涨
2019/08/27 职场文书
CSS 还能这样玩?奇思妙想渐变的艺术
2021/04/27 HTML / CSS
python实现调用摄像头并拍照发邮箱
2021/04/27 Python
threejs太阳光与阴影效果实例代码
2022/04/05 Javascript