鼠标点击特效666

鼠标点击网页任意地方,出文字符号表情的特效,颜色随机

// ==UserScript==
// @name         鼠标点击特效666
// @namespace    yeysou
// @license      MIT
// @version      0.1.1
// @description  鼠标点击网页任意地方,出文字符号表情的特效,颜色随机
// @author       yeysou
// @match        *://*/*
// @grant        none
// @icon         
// @require     https://code.jquery.com/jquery-3.6.0.min.js
// @require     https://code.jquery.com/ui/1.12.1/jquery-ui.min.js
// ==/UserScript==
/* global $ */
function getRandomInt(min, max) {
    // 确保参数为整数
    min = Math.ceil(min);
    max = Math.floor(max);
    // 生成 [min, max] 之间的随机整数
    return Math.floor(Math.random() * (max - min + 1)) + min;
}

(function() {
    'use strict';
    //缓慢消失
    $.fn.scaleFadeOut = function(options) {
        // 默认配置
        const settings = $.extend({
            scale: 2,// 放大倍数(2表示放大到原来的2倍)
            duration: 800,// 动画持续时间(毫秒)
            easing: 'swing' // 缓动函数
        }, options);

        const $element = $(this);
        // 记录原始样式(用于动画结束后恢复,可选)
        const originalTransform = $element.css('transform');
        const originalOpacity = $element.css('opacity');
        // 执行放大消失动画
        $element.animate({
            opacity: 0 // 透明度逐渐变为0
        }, {
            duration: settings.duration,
            easing: settings.easing,
            // 每帧更新缩放比例
            step: function(now, fx) {
                // 计算当前进度(0-1)
                const progress = now === 0 ? 1 : (1 - now);
                // 根据进度计算缩放比例(从1到设定的放大倍数)
                const scaleValue = 1 + (settings.scale - 1) * (1 - progress);
                // 应用缩放变换
                $(this).css('transform', `scale(${scaleValue})`);
            },
            // 动画结束回调
            complete: function() {
                // 恢复原始样式(如果需要)
                $(this).css({
                    transform: originalTransform,
                    opacity: originalOpacity
                });
                // 触发自定义回调
                if (settings.complete) {
                    settings.complete.call(this);
                }
            }
        });

        // 支持链式调用
        return this;
    };
    // 定义带弧度的跳跃效果jQuery方法
    $.fn.arcBounce = function(options) {
        // 默认配置
        const settings = $.extend({
            distance: 300, // 水平总距离
            height: 150, // 跳跃高度
            jumps: 3,// 跳跃次数
            duration: 1000,// 单次跳跃持续时间(ms)
            gravity: 0.8,// 重力系数(值越大下落越快)
            damping: 0.7// 阻尼系数(每次跳跃衰减比例)
        }, options);

        const $element = $(this);
        const originalPosition = $element.css('position');
        const startLeft = parseInt($element.css('left') || 0);
        const startTop = parseInt($element.css('top') || 0);

        // 确保元素可以被定位
        if (!['absolute', 'fixed', 'relative'].includes(originalPosition)) {
            $element.css('position', 'relative');
        }

        // 执行多段弧形跳跃
        let currentLeft = startLeft;
        let currentJump = 0;

        function performJump() {
            if (currentJump >= settings.jumps) {
                // 所有跳跃完成后的回调
                if (settings.complete) {
                    settings.complete.call($element);
                }
                return;
            }

            // 计算当前跳跃的参数(随次数衰减)
            const jumpDistance = settings.distance * Math.pow(settings.damping, currentJump);
            const jumpHeight = settings.height * Math.pow(settings.damping, currentJump);
            const jumpDuration = settings.duration * (1 - currentJump * 0.1); // 后续跳跃稍慢
            const targetLeft = currentLeft - jumpDistance;

            let startTime;
            let progress = 0;

            // 抛物线跳跃动画
            function animate(timestamp) {
                if (!startTime) startTime = timestamp;
                const elapsed = timestamp - startTime;
                progress = Math.min(elapsed / jumpDuration, 1);

                // 计算水平位置(线性移动)
                const newLeft = currentLeft - (jumpDistance * progress);

                // 计算垂直位置(抛物线轨迹: y = -4h(x² - x),形成弧形)
                // 加入重力效果,使下落更快
                const arcProgress = -4 * jumpHeight * (progress * progress - progress);
                const gravityEffect = Math.pow(progress - 0.5, 2) * settings.gravity * jumpHeight;
                const newTop = startTop - (arcProgress - gravityEffect);

                // 应用新位置
                $element.css({
                    left: newLeft + 'px',
                    top: newTop + 'px',
                    // transform: 'rotate('+progress*360+'deg)'
                });

                // 继续动画或结束当前跳跃
                if (progress < 1) {
                    requestAnimationFrame(animate);
                } else {
                    currentLeft = targetLeft;
                    currentJump++;
                    // 稍微延迟后开始下一次跳跃,增强节奏感
                    setTimeout(performJump, 0);
                }
            }

            requestAnimationFrame(animate);
        }

        // 开始第一段跳跃
        performJump();

        // 支持链式调用
        return this;
    };
    // 跳动效果函数
    function bounce($element) {
        const originalPosition = $element.css('position');
        const originalTop = $element.css('top');
        const originalLeft = $element.css('left');
        const bounceDamping = 0.8; // 弹跳阻尼(每次弹起高度衰减比例,0-1之间)

        // 确保元素可以被定位
        if (originalPosition !== 'absolute' && originalPosition !== 'fixed') {
            $element.css('position', 'relative');
        }

        // 记录初始位置(用于计算相对移动)
        const startTop = parseInt($element.css('top') || 0);
        const startLeft = parseInt($element.css('left') || 0);

        /*

            .animate({ top: startTop,left:startLeft-500*(1-bounceDamping)}, 200, 'swing')//落地
            .animate({ top: startTop - 150*bounceDamping**2,left:startLeft-500*(1-bounceDamping**2) }, 200, 'swing')//向上跳
            .animate({ top: startTop,left:startLeft-500*(1-bounceDamping**2)}, 200, 'swing')//落地
            .animate({ top: startTop - 150*bounceDamping**3,left:startLeft-500*(1-bounceDamping**3) }, 200, 'swing')//向上跳
            .animate({ top: startTop,left:startLeft-500*(1-bounceDamping**3)}, 200, 'swing')//落地
            .animate({ top: startTop - 150*bounceDamping**4,left:startLeft-500*(1-bounceDamping**4) }, 200, 'swing')//向上跳*/
        // 1. 跳动效果(向上再落下)
        // 2. 落地后旋转并向左移动
        $element.animate({
            //left: startLeft - 800,// 向左移动200px
            left:startLeft - 500,
            rotate: '-720deg'// 旋转360度
        }, {
            duration: 2000,
            easing: 'swing',
            step: function(now, fx) {
                // 处理旋转动画(jQuery本身不支持rotate,需要手动设置transform)
                if (fx.prop === 'rotate') {
                    var opa= $(this).css("opacity");
                    $(this).css('opacity', opa-0.005);
                    $(this).css('transform', `rotate(${now}deg)`);
                }
            },
            complete: () => {
                //$element.remove();
                $element.scaleFadeOut({
                    scale: 10,// 放大到3倍
                    duration: 500,// 1秒内完成动画
                    complete: function() {
                        // 动画结束后可以隐藏或移除元素
                        $(this).remove();
                        // 如需重复使用,可在适当时候显示
                        // setTimeout(() => $(this).show(), 1000);
                    }
                });
            }
        });
    }
    var a_idx = 0;
    const 前颜色码库 = new Array('00', '11', '22', '1', '44', '55', '66', '77', '88', '99',
                            'aa', 'bb', 'cc', 'dd', 'ee', 'ff');
    const 中颜色码库 = new Array('00', '11', '22', '33', '44', '55', '66', '77', '88', '99',
                            'aa', 'bb', 'cc', 'dd', 'ee', 'ff');
    const 后颜色码库 = new Array('00', '11', '22', '33', '44', '55', '66', '77', '88', '99',
                            'aa', 'bb', 'cc', 'dd', 'ee', 'ff');
    var 前颜色码 ;var 中颜色码;var 后颜色码;
    var timerrrr = setInterval(function(){

        前颜色码 = Math.floor(Math.random() * 前颜色码库.length);
        中颜色码 = Math.floor(Math.random() * 中颜色码库.length);
        后颜色码 = Math.floor(Math.random() * 后颜色码库.length);
    },150)
    $("body").click(function(e) {
        var a = new Array("我","超","牛","逼");
        var $i = $("<span/>").text(a[a_idx]);
        a_idx = (a_idx + 1) % a.length;
        var x = e.pageX,
            y = e.pageY;
        var size = getRandomInt(30,60);
        $i.css({
            "z-index": 99999999,
            "top": y-size-10,
            "left": x-size,
            "font-size":size,
            "position": "absolute",
            "font-weight": "bold",
            "color": "#" + 前颜色码库[前颜色码] + 中颜色码库[中颜色码] + 后颜色码库[后颜色码]
        });
        $("body").append($i);
        var rt = getRandomInt(2,5);
        var rl = getRandomInt(3,6);
        //bounce($i)
        // move($i)
        $i.arcBounce({
            distance: rl*50, // 水平距离
            height: 50*rt, // 跳跃高度
            jumps: 10,// 跳跃次数
            duration: 300,// 单次跳跃时间
            gravity: 1,// 重力系数
            damping: 0.6,// 阻尼系数
            complete: function() {
                // 跳跃完成后的回调函数
                bounce($i);
            }
        });
    });
})();