鼠标跟随特效

简单鼠标跟随特效,无广告和受益

目前為 2023-05-12 提交的版本,檢視 最新版本

// ==UserScript==
// @name         鼠标跟随特效
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  简单鼠标跟随特效,无广告和受益
// @author       asdiver
// @match        *://*/*
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Your code here...
        // 复用池
    class Pool{
      constructor(creatItem){
        this.creatItem = creatItem
      }
      creatItem = null
      total = 0
      save = []
      // 有剩余 则返回 ,没剩余 新增 并返回
      get(){
        //有剩余
        if(this.save.length){
          return this.save.shift()
        }else{
          this.total++
          return this.creatItem()
        }
      }
      recovery(item){
        this.save.push(item)
      }
    }

    // 随机数
    function getRandomIntInclusive(min, max) {
      min = Math.ceil(min);
      max = Math.floor(max);
      return Math.floor(Math.random() * (max - min + 1)) + min; //含最大值,含最小值
    }

    // 事件侦听函数复用
    let last = null
    function tranEnd(){
      if(last === this){
        return
      }
      last = this
      document.body.removeChild(this)
      pool.recovery(this)
    }

    //生成一个小圆球
    const offsetX = 35
    const offsetY = 35
    const diameter = [10,30]
    const spendTime = [0.2, 0.5]
    function createRotundity(){
      const rotundity = document.createElement("div")

      rotundity.style.borderRadius = "100px";
      rotundity.style.position = "fixed";
        rotundity.style.zIndex = "9999";
        rotundity.style.pointerEvents = " none";
      // 随机大小
      rotundity.style.height = rotundity.style.width = getRandomIntInclusive(diameter[0],diameter[1]) + "px"
      // 随机颜色
      rotundity.style.backgroundColor = `rgb(${getRandomIntInclusive(0,255)},${getRandomIntInclusive(0,255)},${getRandomIntInclusive(0,255)})`
      // 随机速度
      rotundity.style.transition = `all ${getRandomIntInclusive(spendTime[0], spendTime[1])}s`
      // 添加侦听器
      rotundity.addEventListener("transitionend", tranEnd)

      return rotundity
    }

    const pool = new Pool(createRotundity)

    // 事件监听
    let data = Date.now()
    const interval = 25
    let run = true;
    document.addEventListener("mousemove",function(e){
      if(!run){
        return
      }
      const now = Date.now()
      if(now - data > interval){
        const dom = pool.get()
        const startX = e.clientX
        const startY = e.clientY
        // 初始
        dom.style.opacity = 1
        dom.style.left = startX+"px"
        dom.style.top = startY+"px"

        document.body.appendChild(dom)
        requestAnimationFrame(()=>{
          // 结束
          dom.style.opacity = 0
          dom.style.left = (getRandomIntInclusive(offsetX,-offsetX)+startX)+"px"
          dom.style.top = (getRandomIntInclusive(offsetY,-offsetY)+startY)+"px"

        })

        data = now
      }
    })
        document.addEventListener("mousedown",function(){
      run = false
    })
    document.addEventListener("mouseup",function(){
      run = true
    })
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址