What’s on our mind?

Collection of articles, design, site, and resources made by designers and publisher @Menu View

**
	var canvas = document.querySelector("canvas");
    var ctx = canvas.getContext("2d");
    var ww = window.innerWidth;
    var wh = window.innerHeight;        
    var hearts = [];

    function init(){
        requestAnimationFrame(render);

        canvas.width = ww;
        canvas.height = wh;

        for(var i=0; i<100; i++){
            hearts.push(new Heart());
        }
    }

    function Heart(){
        this.x = Math.random() * ww;
        this.y = Math.random() * wh;
        this.opacity = (Math.random() * 0.5) + 0.5;
        this.vel = {
            x:(Math.random() - 0.5) * 4,
            y:(Math.random() - 0.5) * 4
        };
        this.targetScale = (Math.random() * 0.15) + 0.02;
        this.scale = this.targetScale * Math.random();
    }

    Heart.prototype.update = function(){
        this.x += this.vel.x;
        this.y += this.vel.y;

        this.scale += (this.targetScale -this.scale) * 0.01;
        if(this.x - this.width > ww || this.x + this.width < 0){
            this.scale = 0;
            this.x = Math.random() * ww;
        }
        if(this.y - this.height > wh || this.y+this.height < 0){
            this.scale = 0;
            this.y = Math.random() * wh;
        }
        this.width  =473.8 * this.scale;
        this.height  =408.6 * this.scale;
    }
    
    Heart.prototype.draw = function(){
        ctx.globalAlpha = this.opacity;
        ctx.drawImage(heartImage, this.x-this.width * 0.5, this.y-this.height * 0.5, this.width, this.height);
    }

    function render(){
        ctx.clearRect(0, 0, ww, wh);
        for(var i=0; i<100; i++){
            hearts[i].update();
            hearts[i].draw();
        }
        requestAnimationFrame(render);
    }

    var heartImage = new Image();
    heartImage.onload = init;
    heartImage.src = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0NzMuOHB4IiBoZWlnaHQ9IjQwOC42cHgiIHZpZXdCb3g9IjAgMCA0NzMuOCA0MDguNiI+PHBhdGggZmlsbD0iI2QzMjkzMiIgZD0iTTQwNC42LDE2LjZDMzg1LjQsNi4xLDM2My41LDAsMzQwLDBjLTQxLjUsMC03OC41LDE4LjktMTAzLDQ4LjVDMjEyLjMsMTguOSwxNzUuMywwLDEzMy44LDAgYy0yMy4zLDAtNDUuMyw2LjEtNjQuNSwxNi42QzI3LjksMzkuNSwwLDgzLjQsMCwxMzMuOWMwLDE0LjQsMi40LDI4LjMsNi42LDQxLjJDMjkuNiwyNzguNCwyMzcsNDA4LjYsMjM3LDQwOC42IHMyMDcuMi0xMzAuMiwyMzAuMi0yMzMuNWM0LjMtMTIuOSw2LjYtMjYuOCw2LjYtNDEuMkM0NzMuOCw4My40LDQ0NS45LDM5LjYsNDA0LjYsMTYuNnoiLz48L3N2Zz4=";

    window.addEventListener("resize", function(){
        ww =  window.innerWidth;
        wh =  window.innerHeight;
    })