canvas实现爱心和彩虹雨效果

发布时间 - 2026-01-11 00:05:08    点击率:

效果图:

代码如下:

<!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 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  如何用IIS7快速搭建并优化网站站点?  如何快速搭建安全的FTP站点?  Android GridView 滑动条设置一直显示状态(推荐)  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何快速上传建站程序避免常见错误?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  如何在万网主机上快速搭建网站?  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel如何使用模型观察者?(Observer代码示例)  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  如何快速建站并高效导出源代码?  JavaScript常见的五种数组去重的方式  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  香港服务器选型指南:免备案配置与高效建站方案解析  如何挑选优质建站一级代理提升网站排名?  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  如何在宝塔面板中修改默认建站目录?  如何在搬瓦工VPS快速搭建网站?  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  ,交易猫的商品怎么发布到网站上去?  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  如何利用DOS批处理实现定时关机操作详解  油猴 教程,油猴搜脚本为什么会网页无法显示?  Android Socket接口实现即时通讯实例代码  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Laravel怎么判断请求类型_Laravel Request isMethod用法  如何破解联通资金短缺导致的基站建设难题?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  个人网站制作流程图片大全,个人网站如何注销?  黑客如何通过漏洞一步步攻陷网站服务器?  JavaScript如何实现音频处理_Web Audio API如何工作?  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  如何快速打造个性化非模板自助建站?  如何在橙子建站上传落地页?操作指南详解  如何构建满足综合性能需求的优质建站方案?  EditPlus中的正则表达式实战(5)  如何做网站制作流程,*游戏网站怎么搭建?  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  如何为不同团队 ID 动态生成多个非值班状态按钮  如何在沈阳梯子盘古建站优化SEO排名与功能模块?