JavaScript canvas实现跟随鼠标事件
更新时间:2020年02月10日 13:47:06 作者:哪天才能学到vue
这篇文章主要为大家详细介绍了JavaScript canvas实现跟随鼠标事件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了用canvas实现跟随鼠标事件的具体代码,供大家参考,具体内容如下
//鼠标移动 展现光片

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style>
body {
margin: 0;
overflow: hidden;
}
#canvas {
background: #000;
}
</style>
</head>
<body>
<canvas id="canvas"></canvas>
<script>
var canvas = document.getElementById('canvas');
var context = canvas.getContext('2d');
var circleList = [];
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
canvas.addEventListener('mousemove', function (e) {
// 将对象push到数组中,画出来的彩色小点可以看作每一个对象中记录着信息 然后存在数组中
circleList.push(new Circle(e.clientX, e.clientY));
})
//取x到y之间随机数:Math.round(Math.random()*(y-x)+x) 包括y
function random(min, max) {
return Math.round(Math.random() * (max - min) + min);
}
function Circle(x, y) {
this.x = x;
this.y = y;
this.vx = (Math.random() - 0.5) * 3; //随机出来一个正数,或者负数。乘3是为了让速度变得大一点
this.vy = (Math.random() - 0.5) * 3;
this.color = 'rgb(' + random(0, 255) + ',' + random(0, 255) + ',' + random(0, 255) + ')';
this.a = 1; // 初始透明度
this.draw();
}
Circle.prototype = {
draw() {
context.beginPath();
context.fillStyle = this.color;
context.globalCompositeOperation = 'lighter';
context.globalAlpha = this.a; //全局透明度
context.arc(this.x, this.y, 30, 0, Math.PI * 2, false);
context.fill();
this.update();
},
update() {
// 根据速度更新每一个小圆的位置
this.x += this.vx;
this.y += this.vy;
this.a *= 0.98;
}
}
function render() {
//把原来的内容区域清除掉
context.clearRect(0, 0, canvas.width, canvas.height);
circleList.forEach(function (ele, i) {
ele.draw();
if (ele.a < 0.05) {
circleList.splice(i, 1);
}
});
requestAnimationFrame(render); //动画,会根据浏览器的刷新频率更新动画
}
render();
</script>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
JavaScript的Object.defineProperty详解
本篇文章给大家详细讲述了JavaScript的Object.defineProperty的相关知识点内容,有兴趣的朋友参考学习下。2018-07-07
JavaScript 防抖debounce与节流thorttle
这篇文章主要介绍了JavaScript 防抖debounce与节流thorttle,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-05-05
JavaScript使用docx-preview和mammoth预览Docx
这篇文章主要为大家详细介绍了两个库,即docx-preview和mammoth,利用它们,你就能在浏览器中完美预览 Word 文档,甚至连表格样式,页眉页脚都原汁原味地呈现出来,下面我们来看看具体使用步骤吧2025-04-04
JavaScript+Canvas实现彩色图片转换成黑白图片的方法分析
这篇文章主要介绍了JavaScript+Canvas实现彩色图片转换成黑白图片的方法,结合实例形式分析了javascript结合HTML5相关函数修改页面图片元素显示效果相关操作技巧,需要的朋友可以参考下2018-07-07
javascript学习随笔(使用window和frame)的技巧
javascript学习随笔(使用window和frame)的技巧...2007-03-03
JavaScript实现Tab标签页切换的最简便方式(4种)
这篇文章主要介绍了JavaScript实现Tab标签页切换的最简便方式(4种),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06


最新评论