全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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>

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


# canvas绘制爱心  # canvas画彩虹  # canvas+gif.js打造自己的数字雨头像的示例代码  # canvas实现流星雨的背景效果  # JS+Canvas 实现下雨下雪效果  # JavaScript canvas实现雨滴特效  # raindrops  # minSize  # bg  # maxSpeed  # maxSize  # minSpeed  # canvasWHalf  # canvasHHalf  # height  # innerHeight  # yoff  # xoff  # return  # Math  # arguments  # length  # hex  # opacity  # floor  # hexToRGB 


相关文章: 清除minerd进程的简单方法  如何快速搭建安全的FTP站点?  中山网站制作网页,中山新生登记系统登记流程?  javascript中的try catch异常捕获机制用法分析  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何快速完成中国万网建站详细流程?  如何选择服务器才能高效搭建专属网站?  常州自助建站工具推荐:低成本搭建与模板选择技巧  开源网站制作软件,开源网站什么意思?  香港服务器选型指南:免备案配置与高效建站方案解析  如何批量查询域名的建站时间记录?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  一键网站制作软件,义乌购一件代发流程?  如何获取开源自助建站系统免费下载链接?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  网站制作的步骤包括,正确网址格式怎么写?  h5网站制作工具有哪些,h5页面制作工具有哪些?  如何在景安云服务器上绑定域名并配置虚拟主机?  相册网站制作软件,图片上的网址怎么复制?  北京专业网站制作设计师招聘,北京白云观官方网站?  郑州企业网站制作公司,郑州招聘网站有哪些?  ,如何利用word制作宣传手册?  如何在阿里云ECS服务器部署织梦CMS网站?  如何快速搭建高效香港服务器网站?  建站之星如何通过成品分离优化网站效率?  家具网站制作软件,家具厂怎么跑业务?  香港服务器租用费用高吗?如何避免常见误区?  建站之星后台管理系统如何操作?  jQuery 常见小例汇总  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  公司门户网站制作流程,华为官网怎么做?  如何选择高效便捷的WAP商城建站系统?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何在万网ECS上快速搭建专属网站?  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  如何解决VPS建站LNMP环境配置常见问题?  ,网站推广常用方法?  建站VPS配置与SEO优化指南:关键词排名提升策略  b2c电商网站制作流程,b2c水平综合的电商平台?  盘锦网站制作公司,盘锦大洼有多少5G网站?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  历史网站制作软件,华为如何找回被删除的网站?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  云南网站制作公司有哪些,云南最好的招聘网站是哪个?  网站制作模板下载什么软件,ppt模板免费下载网站?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何选择域名并搭建高效网站?  兔展官网 在线制作,怎样制作微信请帖?  建站之星安装需要哪些步骤及注意事项?  建站之星后台密码遗忘或太弱?如何重置与强化? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。