A Pen by Jordan Overbye on CodePen.
Created
May 20, 2020 23:07
-
-
Save bozzin/3dc42c80158f70bf9e9646672cb9d308 to your computer and use it in GitHub Desktop.
PIXI experiment (based off persona.co)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<div id="root"></div> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
let ww = window.innerWidth; | |
let wh = window.innerHeight; | |
const options = { | |
bg: { | |
src: "https://res.cloudinary.com/dheeu8pj9/image/upload/v1540179278/HvSDhSJ.jpg", | |
// src: "https://res.cloudinary.com/dheeu8pj9/image/upload/v1540179383/frida.jpg", | |
ratio: 1080 / 1661 | |
}, | |
displacementMap: { | |
intensity: 40, | |
mouseDelay: 0.05, | |
speed: 1, | |
size: { | |
height: 300, | |
width: 300, | |
}, | |
src: "https://res.cloudinary.com/dheeu8pj9/image/upload/v1540179223/filter_NRM.jpg", | |
wrapMode: PIXI.WRAP_MODES.REPEAT | |
} | |
}; | |
const renderer = new PIXI.autoDetectRenderer({ | |
width: window.innerWidth, | |
height: window.innerHeight | |
}); | |
document.querySelector("#root").appendChild(renderer.view); | |
const stage = new PIXI.Container(); | |
let bgResource = null; | |
let displacementMapResource = null; | |
const pixiLoader = new PIXI.loaders.Loader(); | |
pixiLoader.add("bg", options.bg.src); | |
pixiLoader.add("displacementMap", options.displacementMap.src); | |
pixiLoader.load((loader, { bg, displacementMap }) => { | |
displacementMapResource = new PIXI.Sprite(displacementMap.texture); | |
displacementMapResource.width = options.displacementMap.size.width; | |
displacementMapResource.height = options.displacementMap.size.height; | |
displacementMapResource.texture.baseTexture.wrapMode = | |
options.displacementMap.wrapMode; | |
bgResource = new PIXI.Sprite(bg.texture); | |
bgResource.anchor.x = 0.5; | |
bgResource.anchor.y = 0.5; | |
bgResource.x = (ww - 50) / 2 | |
bgResource.y = (wh - 50) / 2; | |
bgResource.width = ww + 100; | |
bgResource.height = bgResource.width * options.bg.ratio; | |
bgResource.interactive = true; | |
bgResource.filters = [ | |
new PIXI.filters.DisplacementFilter( | |
displacementMapResource, | |
options.displacementMap.intensity | |
) | |
]; | |
stage.addChild(bgResource, displacementMapResource); | |
}); | |
let oldX = 0; | |
let oldY = 0; | |
let currentY = 0; | |
let currentX = 0; | |
window.addEventListener("mousemove", e => { | |
currentY = e.pageX; | |
currentX = e.pageY; | |
}); | |
const ticker = new PIXI.ticker.Ticker(); | |
ticker.stop(); | |
ticker.add(deltaTime => { | |
const diffX = currentY - oldX; | |
const diffY = currentX - oldY; | |
if (displacementMapResource) { | |
displacementMapResource.x = | |
displacementMapResource.x + | |
options.displacementMap.speed - | |
diffX * options.displacementMap.mouseDelay; | |
displacementMapResource.y = | |
displacementMapResource.y - | |
options.displacementMap.speed + | |
diffY * options.displacementMap.mouseDelay; | |
} | |
oldX = oldX + diffX * options.displacementMap.mouseDelay; | |
oldY = oldY + diffY * options.displacementMap.mouseDelay; | |
renderer.render(stage); | |
}); | |
ticker.start(); | |
window.addEventListener("resize", e => { | |
ww = window.innerWidth; | |
wh = window.innerHeight; | |
bgResource.width = ww + 100; | |
bgResource.height = bgResource.width * options.bg.ratio; | |
bgResource.x = (ww - 50) / 2 | |
bgResource.y = (wh - 50) / 2; | |
renderer.resize(ww, wh); | |
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.8.2/pixi.min.js"></script> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
html, | |
body { | |
margin: 0; | |
padding: 0; | |
height: 100vh; | |
width: 100vw; | |
overflow: hidden; | |
} | |
#root { | |
height: 100%; | |
width: 100%; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment