• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > html5使用canvas实现跟随光标跳动的火焰效果_html5教程技巧

html5使用canvas实现跟随光标跳动的火焰效果_html5教程技巧

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含canvas,跟随光标等相关知识,匿名希望在学习及工作中可以帮助到您
本效果的完整代码如下,把代码保存到HTML文件中打开也能查看效果,火焰会跟随光标:

var particles = [];
var mouse = {};

//Lets create some particles now
var particle_count = 100;
for(var i = 0; i < particle_count; i++)
{
particles.push(new particle());
}
keleyi_canvas.addEventListener('mousemove', track_mouse, false);

function track_mouse(e)
{
mouse.x = e.pageX;
mouse.y = e.pageY;
}

function particle()
{
this.speed = {x: -2.5+Math.random()*5, y: -15+Math.random()*10};
//location = mouse coordinates
//Now the flame follows the mouse coordinates
if(mouse.x && mouse.y)
{
this.location = {x: mouse.x, y: mouse.y};
}
else
{
this.location = {x: W/2, y: H/2};
}
//radius range = 10-30
this.radius = 10+Math.random()*20;
//life range = 20-30
this.life = 20+Math.random()*10;
this.remaining_life = this.life;
//colors
this.r = Math.round(Math.random()*255);
this.g = Math.round(Math.random()*255);
this.b = Math.round(Math.random()*255);
}

function draw()
{
ctx.globalCompositeOperation = "source-over";
ctx.fillStyle = "black";
ctx.fillRect(0, 0, W, H);
ctx.globalCompositeOperation = "lighter";

for(var i = 0; i < particles.length; i++)
{
var p = particles[i];
ctx.beginPath();
p.opacity = Math.round(p.remaining_life/p.life*100)/100
var gradient = ctx.createRadialGradient(p.location.x, p.location.y, 0, p.location.x, p.location.y, p.radius);
gradient.addColorStop(0, "rgba("+p.r+", "+p.g+", "+p.b+", "+p.opacity+")");
gradient.addColorStop(0.5, "rgba("+p.r+", "+p.g+", "+p.b+", "+p.opacity+")");
gradient.addColorStop(1, "rgba("+p.r+", "+p.g+", "+p.b+", 0)");
ctx.fillStyle = gradient;
ctx.arc(p.location.x, p.location.y, p.radius, Math.PI*2, false);
ctx.fill();


p.remaining_life--;
p.radius--;
p.location.x += p.speed.x;
p.location.y += p.speed.y;

if(p.remaining_life < 0 || p.radius < 0)
{
particles[i] = new particle();
}
}
}

setInterval(draw, 86);
}



您可能想查找下面的文章:

  • canvas与html5实现视频截图功能示例
  • 详解html5 canvas常用api总结(二)--绘图API
  • HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
  • 详解使用HTML5 Canvas创建动态粒子网格动画
  • 解决canvas转base64/jpeg时透明区域变成黑色背景的方法
  • 用html5的canvas和JavaScript创建一个绘图程序的简单实例
  • HTML5 canvas基本绘图之图形组合
  • HTML5 canvas基本绘图之文字渲染
  • HTML5 canvas基本绘图之绘制曲线
  • HTML5 canvas基本绘图之图形变换

相关文章

  • 2018-12-03HTML4,HTML5,XHTML 之间有什么区别?
  • 2018-12-03HTML5 figure标签是什么意思?HTML5 figure标签的使用方法详解
  • 2017-08-06用canvas实现图片滤镜效果附演示
  • 2018-12-03HTML5 创建canvas元素示例代码_html5教程技巧
  • 2017-08-06HTML5所有标签汇总及标签意义解释
  • 2018-12-03HTML5中Canvas与SVG的画图原理比较_html5教程技巧
  • 2018-12-03HTML5Web 存储实例详解
  • 2018-12-03HTML5 canvas实现瀑布流文字效果代码
  • 2018-12-03 html5的setCustomValidity的详细介绍
  • 2018-12-03详解使用HTML5 Canvas创建动态粒子网格动画的示例代码分享

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 关于H5调用相机拍照并压缩图片的代码
    • 浅析border-radius如何兼容IE
    • H5 语义化标签介绍
    • 详解HTML5中rel属性的prefetch预加载功能使用_html5教程技巧
    • HTML5各引擎显示效率比较
    • 秀野堂html5入门视频教程的资源推荐
    • canvas可以替代html与css了吗?
    • 为什么英特尔要力推HTML5?
    • HTML5 script元素async、defer异步加载使用介绍_html5教程技巧
    • 比较总结mui页面跳转方式之间的差异

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有