JavaScript canvas实现跟随鼠标事件
2020-02-13 11:31
603 查看
本文实例为大家分享了用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实现文字跟随鼠标特效
- 完整的html+css+javascript实现跟随鼠标移动显示选中效果
- javascript文字跟随鼠标移动简易实现方法
- javascript滚动栏响应鼠标滑轮的实现上下滚动事件
- javascript实现禁止鼠标滚轮事件
- 5分钟实现Canvas鼠标跟随动画背景
- JavaScript中通过鼠标事件实现模拟拖放效果
- 使用javaScript实现鼠标拖拽事件
- javascript 鼠标单击和双击事件并存的实现方法
- JavaScript实现的鼠标跟随特效示例【2则实例】
- canvas实现跟随鼠标旋转的箭头
- javascript实现在某个元素上阻止鼠标右键事件的方法和实例
- javascript某标签的鼠标滚动事件取消效果或实现其他自定义效果
- 4000 前端成长之路—canvas实现跟随鼠标和跟随手指粒子特效
- JavaScript实现文字跟随鼠标特效
- javascript实现图片跟随鼠标移动效果的方法
- JavaScript原生代码实现鼠标跟随案例(附注释)
- javascript实现页面右侧在线客服始终跟随鼠标滚动而上下滚动且始终位于屏幕中间
- 【前端】javascript实现鼠标跟随特效
- JavaScript实现跟随鼠标移动而移动的文字