h5 + js 炫酷相册

172 阅读1分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

昨晚看抖音,看别别人用h5和js简简单单就做好了一个很炫酷的页面,照片旋转起来,看起来很酷,我今天没有什么事,就简单的查找了一下资料,最后的成果展示一下:

20200429091942802.png

我觉得还是很帅的,我喜欢科比布莱恩特,所以就搞了很多张科比的高清图片来旋转。

嗯。。。看起来还是那么帅!

学习完了,不忘把成果分享一下,这个页面不知道拿来撩做前端的小姐姐会不会有效果。。。

后来,我发现这个其实可以加点音乐也可以加点特效等浪漫元素。

于是,我又添加了下面一段代码:

        <source src="img/bg.mp3" type="audio/mpeg">
    </audio>
 
    <canvas></canvas>
    <div id="container" class="container"></div>
 
    <script src="https://code.jquery.com/jquery-3.2.1.min.js" charset="utf-8"></script>
    <script type="text/javascript">
      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);
        // ctx.globalAlpha = 1;
        // ctx.fillStyle = "rgba(255,255,255,0.3)";
        // ctx.fillRect(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;
      })
 
    </script>

body中间添加这段,你会发现界面多了音乐还有爱心:

20200429091942802.png

是不是感觉更那个啥了。。。。。。

源代码下载地址://download.csdn.net/download/pyf_914406232/12005597