原生js canvas实现鼠标跟随效果


Posted in Javascript onAugust 02, 2020

本文实例为大家分享了canvas实现鼠标跟随效果的具体代码,供大家参考,具体内容如下

效果展示:

原生js canvas实现鼠标跟随效果

源码展示:

<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <title>canvas鼠标跟随效果(原生js实现)</title>
  <script src="http://libs.baidu.com/jquery/1.11.3/jquery.min.js"></script>
  <style>
    * {
      margin:0;
      padding:0;
    }
    body {
      overflow:hidden;
    }
    #myCanvas {
      background-color:#000;
    }
  </style>
</head>
<body>
<canvas id="myCanvas"></canvas>
 
<script>
  var myCanvas = document.getElementById('myCanvas');
  var ctx = myCanvas.getContext("2d");
  var starlist = [];
 
  function init() {
    // 设置canvas区域的范围为整个页面
    myCanvas.width = window.innerWidth;
    myCanvas.height = window.innerHeight;
  };
  init();
  // 监听屏幕大小改变 重新为canvas大小赋值
  window.onresize = init;
 
  // 当鼠标移动时 将鼠标坐标传入构造函数 同时创建一个对象
  myCanvas.addEventListener('mousemove', function(e) {
    // 将对象push到数组中,画出来的彩色小点可以看作每一个对象中记录着信息 然后存在数组中
    starlist.push(new Star(e.offsetX, e.offsetY));
  });
 
  // 随机数函数
  function random(min, max) {
    // 设置生成随机数公式
    return Math.floor((max - min) * Math.random() + min);
  };
 
 
  // 构造函数
  function Star(x, y) {
    // 将坐标存在每一个点的对象中
    this.x = x;
    this.y = y;
    // 设置随机偏移量
    this.vx = (Math.random() - 0.5) * 3;
    this.vy = (Math.random() - 0.5) * 3;
    this.color = 'rgb(' + random(0, 256) + ',' + random(0, 256) + ',' + random(0, 256) + ')';
    // 初始透明度
    this.a = 1;
    // 开始画
    this.draw();
  }
 
  // 再star对象原型上封装方法
  Star.prototype = {
    // canvas根据数组中存在的每一个对象的小点信息开始画
    draw: function() {
      ctx.beginPath();
      ctx.fillStyle = this.color;
      // 图像覆盖 显示方式 lighter 会将覆盖部分的颜色重叠显示出来
      ctx.globalCompositeOperation = 'lighter'
      ctx.globalAlpha = this.a;
      ctx.arc(this.x, this.y, 30, 0, Math.PI * 2, false);
      ctx.fill();
      this.updata();
    },
    updata: function() {
      // 根据偏移量更新每一个小点的位置
      this.x += this.vx;
      this.y += this.vy;
      // 透明度越来越小
      this.a *= 0.98;
    }
  }
  // 渲染
  function render() {
    // 每一次根据改变后数组中的元素进行画圆圈 把原来的内容区域清除掉
    ctx.clearRect(0, 0, myCanvas.width, myCanvas.height)
 
    // 根据存在数组中的每一位对象中的信息画圆
    starlist.forEach(function(ele, i) {
      ele.draw();
      // 如果数组中存在透明度小的对象 ,给他去掉 效果展示逐渐消失
      if (ele.a < 0.05) {
        starlist.splice(i, 1);
      }
    });
    requestAnimationFrame(render);
  }
  render();
</script>
<pre style="color:red">
 感: 最近贡献一下我在教学中的小案例可以能给你一些帮助 ,希望继续关注我的博客
                                        --王
</pre> 
 
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 学习书 推荐
Jun 13 Javascript
javascript实现的在当前窗口中漂浮框的代码
Mar 15 Javascript
html向js方法传递参数具体实现
Aug 08 Javascript
js 用CreateElement动态创建标签示例
Nov 20 Javascript
通过pjax实现无刷新翻页(兼容新版jquery)
Jan 31 Javascript
可恶的ie8提示缺少id未定义
Mar 20 Javascript
js完美实现@提到好友特效(兼容各大浏览器)
Mar 16 Javascript
jQuery1.9+中删除了live以后的替代方法
Jun 17 Javascript
jQuery实现CheckBox全选、全不选功能
Jan 11 Javascript
利用adb shell和node.js实现抖音自动抢红包功能(推荐)
Feb 22 Javascript
vue+axios+mock.js环境搭建的方法步骤
Aug 28 Javascript
QT与javascript交互数据的实现
May 26 Javascript
原生js+canvas实现下雪效果
Aug 02 #Javascript
jQuery实现滑动开关效果
Aug 02 #jQuery
jQuery实现开关灯效果
Aug 02 #jQuery
JavaScript实现动态生成表格
Aug 02 #Javascript
javascript实现京东登录显示隐藏密码
Aug 02 #Javascript
Vue scoped及deep使用方法解析
Aug 01 #Javascript
Vue中computed及watch区别实例解析
Aug 01 #Javascript
You might like
PHP中的array数组类型分析说明
2010/07/27 PHP
PHP中子类重载父类的方法【parent::方法名】
2016/05/06 PHP
JavaScript 密码强度判断代码
2009/09/05 Javascript
再谈javascript图片预加载技术(详细演示)
2011/03/12 Javascript
JS图片预加载 JS实现图片预加载应用
2012/12/03 Javascript
alert中断settimeout计时功能
2013/07/26 Javascript
使用jquery获取网页中图片高度的两种方法
2013/09/26 Javascript
js动态创建上传表单通过iframe模拟Ajax实现无刷新
2014/02/20 Javascript
js 判断控件获得焦点的示例代码
2014/03/04 Javascript
浏览器中url存储的JavaScript实现
2015/07/07 Javascript
JavaScript利用正则表达式替换字符串中的内容
2016/12/12 Javascript
利用jQuery解析获取JSON数据
2017/04/08 jQuery
javascript深拷贝的原理与实现方法分析
2017/04/10 Javascript
从理论角度讨论JavaScript闭包
2019/04/03 Javascript
vue-cli3 项目优化之通过 node 自动生成组件模板 generate View、Component
2019/04/30 Javascript
Vue 列表上下过渡效果的实例代码
2019/06/25 Javascript
Vue3.x源码调试的实现方法
2019/10/13 Javascript
Jquery ajax书写方法代码实例解析
2020/06/12 jQuery
javascript实现扫雷简易版
2020/08/18 Javascript
Vue select 绑定动态变量的实例讲解
2020/10/22 Javascript
[00:39]DOTA2上海特级锦标赛 Liquid战队宣传片
2016/03/04 DOTA
python、java等哪一门编程语言适合人工智能?
2017/11/13 Python
Python实现的远程登录windows系统功能示例
2018/06/21 Python
Python 中的lambda函数介绍
2018/10/10 Python
Python字符串逆序输出的实例讲解
2019/02/16 Python
Python实现代码块儿折叠
2020/04/15 Python
css和css3弹性盒模型实现元素宽度(高度)自适应
2019/05/15 HTML / CSS
现代绅士日常奢侈品:Todd Snyder
2019/12/13 全球购物
什么造成了Java里面的异常
2016/04/24 面试题
大学生毕业自我鉴定
2013/11/06 职场文书
卖车协议书范例
2014/09/16 职场文书
2014年节能工作总结
2014/12/18 职场文书
《最后一头战象》读后感:动物也有感情
2020/01/02 职场文书
python如何在word中存储本地图片
2021/04/07 Python
Nginx 反向代理解决跨域问题多种情况分析
2022/01/18 Servers
如何打开Win11系统注册表编辑器?Win11注册表编辑器打开修复方法
2022/04/05 数码科技