• stackoverflow愚人节彩蛋效果


    效果如图所示:

    index.js

    /*!
     * Fairy Dust Cursor.js
     * - 90's cursors collection
     * -- https://github.com/tholman/90s-cursor-effects
     * -- https://codepen.io/tholman/full/jWmZxZ/
     */
    
    (function fairyDustCursor() {
    
      var possibleColors = ["#D61C59", "#E7D84B", "#1B8798"]
      var width = window.innerWidth;
      var height = window.innerHeight;
      var cursor = {x: width/2, y: width/2};
      var particles = [];
    
      function init() {
        bindEvents();
        loop();
      }
    
      // Bind events that are needed
      function bindEvents() {
        document.addEventListener('mousemove', onMouseMove);
        document.addEventListener('touchmove', onTouchMove);
        document.addEventListener('touchstart', onTouchMove);
    
        window.addEventListener('resize', onWindowResize);
      }
    
      function onWindowResize(e) {
        width = window.innerWidth;
        height = window.innerHeight;
      }
    
      function onTouchMove(e) {
        if( e.touches.length > 0 ) {
          for( var i = 0; i < e.touches.length; i++ ) {
            addParticle( e.touches[i].clientX, e.touches[i].clientY, possibleColors[Math.floor(Math.random()*possibleColors.length)]);
          }
        }
      }
    
      function onMouseMove(e) {
        cursor.x = e.clientX;
        cursor.y = e.clientY;
    
        addParticle( cursor.x, cursor.y, possibleColors[Math.floor(Math.random()*possibleColors.length)]);
      }
    
      function addParticle(x, y, color) {
        var particle = new Particle();
        particle.init(x, y, color);
        particles.push(particle);
      }
    
      function updateParticles() {
    
        // Updated
        for( var i = 0; i < particles.length; i++ ) {
          particles[i].update();
        }
    
        // Remove dead particles
        for( var i = particles.length -1; i >= 0; i-- ) {
          if( particles[i].lifeSpan < 0 ) {
            particles[i].die();
            particles.splice(i, 1);
          }
        }
    
      }
    
      function loop() {
        requestAnimationFrame(loop);
        updateParticles();
      }
    
      /**
       * Particles
       */
    
      function Particle() {
    
        this.character = "*";
        this.lifeSpan = 120; //ms
        this.initialStyles ={
          "position": "absolute",
          "display": "block",
          "pointerEvents": "none",
          "z-index": "10000000",
          "fontSize": "16px",
          "will-change": "transform"
        };
    
        // Init, and set properties
        this.init = function(x, y, color) {
    
          this.velocity = {
            x:  (Math.random() < 0.5 ? -1 : 1) * (Math.random() / 2),
            y: 1
          };
    
          this.position = {x: x - 10, y: y - 20};
          this.initialStyles.color = color;
    
          this.element = document.createElement('span');
          this.element.innerHTML = this.character;
          applyProperties(this.element, this.initialStyles);
          this.update();
    
          document.querySelector('body').appendChild(this.element);
        };
    
        this.update = function() {
          this.position.x += this.velocity.x;
          this.position.y += this.velocity.y;
          this.lifeSpan--;
    
          this.element.style.transform = "translate3d(" + this.position.x + "px," + this.position.y + "px, 0) scale(" + (this.lifeSpan / 120) + ")";
        }
    
        this.die = function() {
          this.element.parentNode.removeChild(this.element);
        }
    
      }
    
      /**
       * Utils
       */
    
      // Applies css properties to an element.
      function applyProperties( target, properties ) {
        for( var key in properties ) {
          target.style[ key ] = properties[ key ];
        }
      }
    
      init();
    })();
  • 相关阅读:
    洛谷P2740 草地排水
    BZOJ 4326 运输计划
    BZOJ 1036 树的统计
    BZOJ 1003 物流运输
    BZOJ 1251 序列终结者
    HDU4864 Task(算竞进阶习题)
    洛谷P4281 紧急集合 / 聚会
    CH0802 占卜DIY
    node.js(二)各种模块
    node.js对象数据类型
  • 原文地址:https://www.cnblogs.com/CyLee/p/10636120.html
Copyright © 2020-2023  润新知