Skip to content

GandharvMahajan/Unreal-Diffusion

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Unreal Diffusion : A Stable Diffusion Unreal Engine Implementation

unreal-diffusion

discord badge

This is a Unreal Engine 5 implementation of Stable Diffusion. It provides a streamlined GUI inside Unreal Engine to easily generate game-ready textures among other features. You can run Automatic1111 or InvokeAI as the backend server.

Quick links: [Discord Server]

Table of Contents

  1. Installation
  2. Features
  3. Latest Changes
  4. Troubleshooting
  5. Support

Installation

This plugin supports several SD backends. You can find individual installation instructions below. Install Automatic1111 Stable Diffusion and/or InvokeAI

  • [1a] Follow the install instructions at AUTOMATIC1111/stable-diffusion-webui and get that running normally

  • [1b] Follow the install instructions at invoke-ai/InvokeAI and get that running normally (WIP, use the legacy_InvokeAI in the meantime before I add support for their new API)

  • [2] Copy the Unreal/Unreal_Diffusion folder into your Unreal plugin folder either for the project or the engine install location

  • [3] Go to Plugins in unreal and then enable the "Unreal Diffusion" plugin and restart the engine

plugin

  • [4] Navigate to project settings then add the install location of Automatic1111 and/or InvokeAI in the settings

editor settings

  • [4.1] Also add /Lib/site-packages from your python 3 install location on your computer like in the image below

project logo

  • [5] (Optional) Go to Editor Preferences in Unreal and then "Loading & Saving"

  • [5.1] Add the "/outputs/img-samples/unreal-diffusion" to the Directories to monitor list to automatically import the generated images to unreal. You can map these to /Game/Unreal_Diffusion/Output as in the image below

project logo

Running the plugin

Launch the main UI from the playbar here: unreal start ui Main ui: unreal main ui

Choose backend server and automatically launch it from the "Start Server" button. Make sure the plugin settings have the correct path unreal settings ui

Features

Major Features

Unreal UI

  • Realtime - toggle that will generate the images without freezing unreal, but may generate slower. Off by default
  • Seamless - Forces SD to generate seamless images. Sometimes you could try to have this off and instead type seamless in the prompt

Extra Features

DeepBump Texture Generation

  • If DeepBump is installed (optional), you will get extra options. This allows right-click action on any texture in the content browser for Normal/Height/Curvature map generation. This will generate those textures based on the diffuse map and import them to the project. unreal image generation

Most docs here link to InvokeAI's as they are very detailed and show usecases and syntax

Latest Changes

  • v0.8.0 (03 April 2023)
    • Major rework
    • Added support for Automatic1111 backend server
    • Converted from content to C++ plugin
    • Moved config settings to plugin settings
    • Adding WIP ChatGPT prompting support
  • v0.6.0 (30 October 2022)
    • Added Img2Img support
    • Cleaned up UI.
    • Fixed reset button bugs.
    • Added export of texture if source file not found.
    • Added more sliders to UI
  • v0.5.0 (23 October 2022)
    • initial version with prompt/negative prompts, cfg, steps features

Troubleshooting

If the images won't generate due to VRAM, try lowering the resolution or temporarily load an empty level in unreal to generate images.

Contributing

Anyone who wishes to contribute to this project, whether documentation, features, bug fixes, code cleanup, testing, or code reviews, is very much encouraged to do so. If you are unfamiliar with how to contribute to GitHub projects, here is a Getting Started Guide.

A full set of contribution guidelines, along with templates, are in progress, but for now the most important thing is to make your pull request against the "development" branch, and not against "main". This will help keep public breakage to a minimum and will allow you to propose more radical changes.

Contributors

This fork is at the moment handled by me, with the main features/backend API coming from InvokeAI.

Support

For support, please use this repository's GitHub Issues tracking service. Feel free to send me an email if you use and like the plugin.

Original portions of the software are Copyright (c) 2023 Emil Eldstål

About

Stable Diffusion for Unreal Engine

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%