pixi-react-parallax v1.0.15
Pixi React Parallax
Demo
Head over to the Etherion Lab for a demonstration of the parallax effect. The laboratory will be undergoing active development, but I'll commit to making sure a parallax demo is available at Experiment 1.
Installation
This library requires React, @pixi/react, and Pixijs installed as Peer Dependencies.
NPM:
npm install --save pixi-react-parallax react @pixi/react pixi.jsYarn:
yarn add pixi-react-parallax react @pixi/react pixi.jsUsage
Stack ParallaxLayers in a declarative style. They must fall within the context of a ParallaxCameraProvider. Set the ParallaxLayer's zIndex prop to the distance from the camera. Arrange a scene within each ParallaxLayer. Scale the contents if you want.
Pay special attention to the use of useParallaxCameraRef(). This hook returns the camera's current target, and a function to set the target. Pass that setter function into the ref prop of a DisplayObject to "tag" it. The camera will now follow that target around!
Note that the camera target needs to move around to see the parallax effect.
Basic example with 3 parallax layers:
import {
  ParallaxCameraProvider,
  ParallaxLayer,
  useParallaxCameraRef,
} from "pixi-react-parallax";
function MyComponent() {
  const [, setCameraTargetRef] = useParallaxCameraRef()
  return (
    <ParallaxCameraProvider>
      <ParallaxLayer zIndex={-400}>
        <Text
          text="-400"
          x={200}
          y={200}
          scale={2}
        />
      </ParallaxLayer>
      <ParallaxLayer zIndex={0}>
        <Text
          text="0"
          x={200}
          y={200}
          scale={2}
          ref={setCameraTargetRef} // Tag the camera target like this.
          // Now when this DisplayObject moves, the camera will track it.
        />
      </ParallaxLayer>
      <ParallaxLayer zIndex={100}>
        <Text
          text="100"
          x={200}
          y={200}
          scale={2}
        />
      </ParallaxLayer>
    </ParallaxCameraProvider>
  );
}The camera currently only supports tracking one target. The target must be a child of a ParallaxLayer, but that layer doesn't need to have a zIndex of 0.
Working example: Here's the source for the Parallax Demo
API
<ParallaxCameraProvider>
All ParallaxLayers must be children of a ParallaxCameraProvider.
Props:
- movementDamping: number: Greater values result in a camera that tracks more sluggishly. A value of 0 means tracking is instantaneous. Default: 10.
- focalLength: number: The- zIndexof the camera itself. All ParallaxLayers must be positioned in front of the camera, having 'zIndex' values less than the- focalLength. Default: 300.
<ParallaxLayer>
A container for the DisplayObjects that are positioned a given distance from the camera.
Props:
- zIndex: number: How far away the layer is. Lower values result in a layer that is farther away. Values must be less than the camera's- focalLength. The contents of a ParallaxLayer are automatically scaled to give the illusion of distance. ParallaxLayers with a- zIndexof 0 aren't scaled; negative- zIndexis scaled down; positive scaled up. Objects very far away might be scaled to microscopic sizes, relatively speaking, so you might consider scaling up the contents to counter the scaling effect. The side-to-side parallax motion is unaffected by the scaling factor.
useParallaxCameraRef
Hook that returns the camera target, and a setter that can be passed into a DisplayObject's ref prop to "tag" it to be tracked by the camera.
import { useParallaxCameraRef } from 'pixi-react-parallax'
function MyComponent() {
  const [cameraTargetRef, setCameraTargetRef] = useParallaxCameraRef()
  // ...
}ParallaxCameraContext
The React context that contains the camera.
The camera currently supports a shaking effect with camera.shake(strength: number, duration?: number).
  import { useContext } from 'react'
  import { ParallaxCameraContext } from 'pixi-react-parallax'
  const camera = useContext(ParallaxCameraContext);
  camera.shake(15, 0.2)Building
Install dependencies.
yarn installCompile.
yarn buildBuild the package locally (optional).
yarn packThen add the local dependency to your package.json.
// package.json
{
  ...
  "dependencies": {
    "pixi-react-parallax": "file:/path/to/your/pixi-react-parallax/pixi-react-parallax-v1.0.10.tgz"
  }
}