/display3d

A command line interface for rendering and animating 3D objects

Primary LanguageRust

display3d

Crates.io Version
display3d.webm

display3d is a command line interface for rendering and animating 3D objects using ANSI escape codes, written using gemini-engine in the Rust programming language.

For a basic guide on how to use the tool, run display3d --help

Supported formats

  • .obj (combined with .mtl for colours). If you're exporting from Blender, set the forward axis to +Z and the up axis to +Y
  • .stl

Please note that this form of rendering requires the terminal to support ANSI escape codes, support for which tends to be unreliable on Windows from installation to installation. If you are having issues getting an image on Linux or MacOS, please submit an issue request

Installing

Make sure you have rust and cargo installed before proceeding with either of these methods

Install with cargo (recommended)

Run cargo install display3d. This will download, compile and install the latest stable release of display3d. You can then simply run display3d to access it

Compile from source

Clone this repository with git clone https://github.com/redpenguinyt/display3d.git or download and extract this repository.

Build the project with cargo build --release. The binary will be saved to <project-repo>/target/release/display3d

Example

To run the example spinning shark, run display3d blahaj.obj -t 0,0,5.5. You can get the blahaj.obj and blahaj.mtl (for colours, should be stored together with blahaj.obj) files in the resource folder of this repository.