簡體   English   中英

垂直視差無法使用Parallax.js正常工作

[英]Vertical Parallax Isn't Working Using Parallax.js

因此,我嘗試使用插件parallax.js和兩個單獨的畫布元素(創建星星)來創建空間效果。 我已經按照插件的github的指示設置了HTML和JS,但是畫布元素都不垂直移動。

我制作了一個JS Fiddle來演示它。 代碼的第一部分是插件,底部是我的Canvas代碼。

這是我用於canvas元素的代碼。

var cvsSmall = document.getElementById("cvsSmall"),
  ctxSmall = cvsSmall.getContext("2d"),
  cvsBig = document.getElementById("cvsBig"),
  ctxBig = cvsBig.getContext("2d"),
  particlesSmall = [],
  particlesBig = [];

//main
fitCanvas();
var scene = document.getElementById('scene');
var parallax = new Parallax(scene);
makeParticles(20);
drawParticles();
ctxSmall.fillRect(0, window.innerWidth, 0, window.innerHeight);

//functions
function fitCanvas() {
  cvsSmall.width = window.innerWidth;
  cvsBig.width = window.innerWidth;
  cvsSmall.height = window.innerHeight;
  cvsBig.height = window.innerHeight;
}

function makeParticles(amount) {
  for (i = 0; i < amount; i++) {
    particle = {
      x: Math.random() * cvsSmall.width,
      y: Math.random() * cvsSmall.height,
      size: 1,
    }
    particlesSmall.push(particle);
  }
  for (i = 0; i < amount; i++) {
    particle = {
      x: Math.random() * cvsBig.width,
      y: Math.random() * cvsBig.height,
      size: 5,
    }
    particlesBig.push(particle);
  }
}

function drawParticles() {
  for (i = 0; i < particlesSmall.length; i++) {
    p = particlesSmall[i];
    ctxSmall.beginPath();
    ctxSmall.fillStyle = "#FFFFFF";
    ctxSmall.arc(p.x, p.y, p.size, 0, 2 * Math.PI);
    ctxSmall.closePath();
    ctxSmall.fill();
  }
  for (i = 0; i < particlesBig.length; i++) {
    p = particlesBig[i];
    ctxBig.beginPath();
    ctxBig.fillStyle = "#FFFFFF";
    ctxBig.arc(p.x, p.y, p.size, 0, 2 * Math.PI);
    ctxBig.closePath();
    ctxBig.fill();
  }
}

這是一個很特殊的問題,但事實證明我的<UL>的高度為0,並影響了垂直視差。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM