Create a new environment with python 3.10 via conda or venv and then use pip to install the dependencies.
$ pip install -r requirements.txt
$ python ./webui.py
You can then reach the web ui via http://127.0.0.1:8050/. Be prepared that the first time, any new functionality is used, the corresponding models need to be downloaded first. This can take a few minutes based on your connection speed. If you want to prefetch the default models, you can start the application with
$ python ./webui.py --prefetch-models=default
Note
If you want to make changes to the styles, you need to set up node
and run npm run build
to rebuild the tailwind css file. This requires installing tailwindcss
via npm install -D tailwindcss
.
Important
To use Stable Diffusion 3 Medium, you will need to install the current versio of diffusers from github.
Provides a workflow for turning images into 2.5D animation like the one seen above.
- Segmentation of images
- Using depth models like Midas or ZeoDepth
- Using instance segmentatio via Segment Anything with multiple positive and negative point selection
- Adding and removing of cards, direct manipulation of depth values
- Inpainting
- Inpainting of masks that can be padded and blurred
- Replacing the masked regions with new images via image generation models like Stable Diffusion 1.0 XL, Stable Diffusion 3 Medium, Automatic1111 or ComyfUI endpoints as well as the StabilityAI API.
- 3D Export
- Generation of glTF scenes that can be imported into Blender or Unreal Engine
- Support for depth displacement of cards to generate more realistic 3D geometry
- In browser 3D preview of the generated glTF scene.
Using an input image, the tool runs a depth model like Midas or ZoeDepth to generate a depth map
and then creates cards that can be used for 2.5 parallax animation.
This animation was created using the following command:
ffmpeg -framerate 24 -i rendered_image_%03d.png -filter_complex "fps=5,scale=480:-1:flags=lanczos,split[s0][s1];[s0]palettegen=max_colors=32[p];[s1][p]paletteuse=dither=bayer" output.gif
The tool also supports generating a glTF2.0 scene file that an be easily imported into 3D apps like Blender or Unreal Engine.
Tip
To utilize depth of field camera effects for the Blender scene, the material needs to be changed to ALPHA HASHED.
Tip
To utilize depth of field camera effects for Unreal Engine, the material needs to be changed to Translucent Masked.
A Dash based Web UI provides a browser assisted workflow to generated slices from images, inpaint the slices and then export them as a glTF scene to Blender or Unreal Engine. The resulting glTF scene can also be visualized within the app or manipulated via a command line tool and the state file saved by the app.
The Docker image is available for both ARM64 (Apple Silicon) and AMD64 (Intel/AMD) architectures.
# Pull and run the container
docker pull nielsprovos/parallax-maker:v1.0.1
docker run -it -p 8050:8050 \
-v $(pwd)/.cache:/root/.cache/ \
-v $(pwd)/workdir:/app/workdir \
nielsprovos/parallax-maker:v1.0.1
Parallax Maker also supports the Automatic1111 and ComfyUI API endpoints. This allows the tool to utilize GPUs remotely and potentially achieve much higher performance compared to the local GPU. It also means that it's possible to use more specialzied inpainting models and workflows. Here is an example ComfyUI inpainting workflow that makes use the offset lora published by Stability AI.