Skip to content

Vintage visual effects tools from the 90s along with their re-engineered life as a Paint.NET plugin

License

Notifications You must be signed in to change notification settings

philstopford/GenesisVFX

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vfx

Contents

This repository contains both an archive of all recovered, original Genesis VFX content as well as a from-scratch rewrite of the Genesis rendering engine based on the recovered Photoshop source code - a project called regenesis.




The Original

Released in 1997, Genesis VFX was a flexible, multi-purpose visual effects tool written by Andrew "Deadline" Cross and published by Future Fantastic and Positron. It offered a vibrant GUI for creating layered, highly-configurable effects out of procedural, geometric elements, each one with its own unique blending and distortion properties. Presets could be stored in .GFX files and shared with others.

You can still check out the original Genesis website via archive.org

photoshop UI from version 1

The simplest use would appear be to creating lens flares - and the 90s loved lens flares.

Dig a bit deeper though and there was a wild world of cool and unusual results possible. The software offered some unique and powerful features not found in anything else at the time; most notable the ability to "wrap" any effect around any number of arbitrary shapes via a masking system, helping to cater to another 90s favourite : extremely funky text.

example of effect wrapping

Various versions shipped, integrating into Photoshop, 3D Studio MAX and Lightwave 3D. Various snaphots and collected builds are available in the Original directory.

Later, a Genesis VFX 2.0 PRO version shipped with a less Kai's Power Tools-inspired UI (boo! more colourful weird GUIs!) plus a small selection of improved features, faster rendering and a more refined preset management system.

photoshop UI from version 2

My interest in Genesis stems from my involvement in its early testing and development. Andrew and I crossed paths in the burgeoning 3dsmax plugin development scene and he ended up a source of encouragement and inspiration when it came to my own attempts at visual effects development.

I ended up creating a number of popular preset packs for the product launch as well as offering guidance for the 3dsmax version. In the last decade my personal site has held a small shrine to Genesis, housing any old builds I could find and a short history of the project. I consider all the work on this repo to be (probably) the final form of my obsession with it!




The Present - regenesis

pdn ui 1

Several years ago I became suddenly re-interested in how Genesis had functioned - specifically the 'wrap' functionality. I reached out to Andrew to see if he could provide any hints but the intervening years had blurred any memories of the original design (and the code was lost to time).

A lucky break came in late 2017 when I was able to recover the original Photoshop source code - and with Andrew's blessing, began a project to untangle the code and rebuild the engine from scratch for sake of longer-term preservation.

The regenesis core now also powers a modern reimagining as a fully-featured plugin for Paint.NET using my bespoke Win Forms UI framework, asphalt. It loads all original .GFX preset files and exposes some new quirks and tweaks for further experimenting with Genesis' capabilities.

pdn ui 1

Optimised, multi-threaded and comprehensively commented, regenesis seeks to keep this wonderful bit of vfx arcana alive and kicking!

Currently a build is available in releases, however it is a manual install process (not difficult, but still). An installer will be created in the future to ease setup.

regenesis is built with premake5 and should run on Windows and Linux. A command-line demo is provided to demonstrate standalone rendering.




The Guts

Ok, so how does the wrap function work?

While porting and refactoring the original core, I added some debug buffer output to help me understand what was going on as the algorithm progressed. The following sequence walks through what goes on in the "Deep Mask" processing path - generating various buffers that finally drive the wrapped-effect rendering.

Initial Setup

We're going to take the Noisy Green Mess preset and render it using a mask. By default, it looks a bit like this.

gfx input

The mask is a couple of simple shapes - separated to show how the alogrithm deals with multiple competing surfaces:

mask input

The end result will look like this:

result output

... So what's happening to get there?

Stage 1 - Mask Extraction

First, the mask image is analysed in a multi-pass process to extract a list of how many separate mask elements exist and which pixels belong to each element. While this is happening, a centroid is computed for each element as an average of the contributing pixel positions.

This sequence shows each pass across the image as it discovers and then flood-fills the larger star shape element. The arrows show the progression of the computed centroid as the balance of pixels changes.

The fill phase finds the first unaccounted-for pixel in the mask and then expands out in a diagonal direction (flipping diagonal direction on each pass) in multiple passes until it has accounted for all connected pixels in the shape.

mask builder

Stage 2 - Unsigned Distance Field (UDF)

Once the mask elements are built, the next step is to compute how far each pixel in the image is away from the nearest element edge.

To do this, Genesis first seeds a buffer with two values - if a pixel is inside the mask element, it gets a large value, otherwise 0.

Then, we sweep multiple times across this buffer in different directions, 'smearing' outwards from the masked areas, only updating a pixel if the distance value increases.

udf 1 udf 2

To soften the hard edges, the distance field is then smoothed using a separable Gaussian blur with a configurable radius.

udf blur

Stage 3 - Distance Gradient Field

Next, we compute the gradient of the distance field. This is a vector field that points in the direction of the nearest element edge. This is achieved using a Sobel operator on the UDF to estimate the direction from local distance changes. This is then integrated with the original distance value.

sgf 1 sgf 1

This buffer is a little harder to visualise. The first image shows a representation of 2D direction in the R/B colour channels. The second image shows the magnitude of the gradient using a Viridis gradient palette.

Stage 4 - Final Rendering

Finally, the rendering loop shifts in presence of the mask buffer data. Instead of a flare being rendered around a single central point on the image, each pixel recomputes the internal rendering structures to place the center of the flare at the nearest element edge.

The distance gradient field is used to offset the current pixel towards the nearest edge; the flare renderer is effectively "reset" to consider this the new center and rendering proceeds. This results in the flare being effectively warped to fit the distance field.

result output






Photoshop is a registered trademark of Adobe

3D Studio MAX and 3ds Max are registered trademarks of Autodesk, Inc.

Lightwave 3D is a registered trademark of NewTek, Inc.

About

Vintage visual effects tools from the 90s along with their re-engineered life as a Paint.NET plugin

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 45.1%
  • C 28.6%
  • C# 23.3%
  • Makefile 1.1%
  • Clarion 0.9%
  • Rez 0.7%
  • Other 0.3%