/mojovimetrix

Primary LanguagePythonOtherNOASSERTION

THIS ENTIRE PROJECT IS DONATIONWARE.
PLEASE FEEL FREE TO CONTRIBUTE IN ANYWAY YOU THINK YOU CAN

ComfyUI Nodes for procedural masking, live composition and video manipulation

COMFYUI Nodes for procedural masking, live composition and video manipulation

WHY BUILD THESE NODES?

There are many ways to do composition and it is apparent that is a large portion of what Computer Vision - aka contemporaneous "A.I" - is invented to resolve.

While diffusers and latent hallucinations can make many amazing things at the moment, there is still a need to resolve final "frames" in something else, like one of the many free tools:

The main goal of Jovimetrix is to supplement those external workflows before the need to use them.

TARGETS

  • animation / motion graphics
  • traditional image blending
  • support masks as an image channel
  • improved UX ** custom node colorization ** node favorites

COMMUNITY

Everything here is made because I wanted to make it. Everything you are looking for here that you cant find doesnt exsit because I didnt make it. If you feel like helping with text or code contributions, please pull and send me any PRs.

CONTRIBUTIONS

Feel free to contribute to this project by reporting issues or suggesting improvements. Open an issue or submit a pull request on the GitHub repository.

DONATIONS

If you feel like donating money resource instead, you can always use my ko-fi ❤️

DISCORD

There are a few places you can chat about Jovimetrix nodes.

Directly on the #jovimetrix channel at the Banodoco discord:

On Purz discord (Creative Exploration):

INSTALLATION

COMFYUI MANAGER

If you have ComfyUI Manager installed, simply search for Jovimetrix and install from the manager's database.

MANUAL INSTALL

Clone the repository into your ComfyUI custom_nodes directory. You can clone the repository with the command:

git clone https://github.com/Amorano/Jovimetrix.git

You can then install the requirements by using the command:

.\python_embed\python.exe -s -m pip install -r requirements.txt

If you are using a virtual environment (venv), make sure it is activated before installation. Then install the requirements with the command:

pip install -r requirements.txt

ENVIRONMENT VARIABLES

LOGGER

The logger can be controlled via the JOV_LOG_LEVEL variable. It can be set to one of the following, by name or value:

  • TRACE (5)
  • DEBUG (10)
  • INFO (20)
  • SUCCESS (25)
  • WARNING (30)
  • ERROR (40)
  • CRITICAL (50)

The default is WARNING (30); i.e. SET JOV_LOG_LEVEL=WARNING

SYSTEM DEVICE SCAN

Allows the system to auto-scan for any devices, so that it can populate the device list in the Stream Reader Node.

The STREAM READER📺 is able to load media from local media, web media dna also system devices such as (virtual) web cameras and monitors. By default, the scan for web cameras is off.

If you wish to engage the auto-scan on ComfyUI statrt-up, set the JOV_SCAN_DEVICES variable to 1 or True.

JOV_SCAN_DEVICES=1

GIFSKI SUPPORT

If you have GIFSKI installed you can enable the option for the Export Node to use GIFSKI when outputting frames.

You will need to add an environment var so it knows you have it installed and where:

set JOV_GIFSKI=[path to gifski]

Once set the GIFSKI option should appear in the Export Node drop down list of output target formats.

PYAUDIO

By default, pyaudio is installed for all platforms; however, it may be nessicary to run a specific platform package manager to obtain all the correct platform dependencies. You can refer to the non-complicated specific platform instructions for help..

In short:

  • For MacOS you need the extra brew package of portaudio. (brew install portaudio)
  • For Linux you need the extra apt package of python3-pyaudio. (sudo apt-get install python3-pyaudio)

SPOUT (WINDOWS ONLY)

If you are on Linux or Mac, Spout will not be installed from the requirements.txt.

By default, Spout, a system for GPU accelerated sharing of graphics between applications, is on for all platforms.

If you are on Mac or Linux, this will only amount to a message at startup about Spout not being used. When Spout is not found, the SpoutWriter node will not showup. In addition, the StreamReader node will not have Spout as an option from which to read stream data.

If you want to fully turn off the initial startup attempt to import Spout, you can use the environment variable:

JOV_SPOUT=0

FFMEPG

The audio nodes require FFMPEG. You can find the official FFMPEG here. Follow it's installation instructions for your specific operating system.

CREATE  
CONSTANT 🟪 Create a single RGBA block of color. Useful for masks, overlays and general filtering.
SHAPE GENERATOR ✨ Generate polyhedra for masking or texture work.
TEXT GENERATOR 📝 Uses any system font with auto-fit or manual placement.
STEREOGRAM 📻 Make a magic eye stereograms.
GLSL 🍩 GLSL Shader support
ADJUST  
ADJUST 🕸️ Blur, Sharpen, Emboss, Levels, HSV, Edge detection.
COLOR MATCH 💞 Project the colors of one image onto another or use a pre-defined color target.
THRESHOLD 📉 Clip an input based on a mid point value.
COMPOSE  
TRANSFORM 🏝️ Translate, Rotate, Scale, Tile, Mirror, Re-project and invert an input.
BLEND ⚗️ Applies selected operation to 2 inputs with optional mask using a linear blend (alpha).
PIXEL SPLIT 💔 Splits images into constituent R, G and B and A channels.
PIXEL MERGE 🫂 Combine 3 or 4 inputs into a single image
STACK ➕ Union multiple latents horizontal, vertical or in a grid.
CROP ✂️ Clip away sections of an image and backfill with optional color matte.
COLOR THEORY 🛞 Generate Complimentary, Triadic and Tetradic color sets.
CALC  
VALUE #️⃣ Create a value for most types; also universal constants.
CONVERT🧬 Convert INT, FLOAT, VEC*, STRING and BOOL.
CALC OP UNARY 🎲 Perform a Unary Operation on an input.
CALC OP BINARY 🌟 Perform a Binary Operation on two inputs.
LERP 🔰 Interpolate between two values with or without a smoothing.
ANIMATE  
TICK ⏱ Periodic pulse exporting normalized, delta since last pulse and count.
WAVE GENERATOR 🌊 Periodic and Non-Periodic Sinosodials.
FLOW  
COMPARISON 🕵🏽 Compare two inputs: A=B, A!=B, A>B, A>=B, A<B, A<=B
DELAY ✋🏽 Delay traffic. Electrons on the data bus go round.
HOLD VALUE 🫴🏽 When engaged will send the last value it had even with new values arriving.
DEVICE  
MIDI READER🎹 Capture MIDI devices and pass the data into Comfy.
MIDI MESSAGE🎛️ Expands a MIDI message into its values.
MIDI FILTER ✳️ Filter MIDI messages by channel, message type or value.
MIDI FILTER EZ ❇️ Filter MIDI messages by channel, message type or value.
STREAM READER📺 Connect system media devices and remote streams into ComfyUI workflows.
STREAM WRITER🎞️ Broadcast ComfyUI Node outputs to custom webserver endpoint.
AUDIO  
GRAPH WAVE▶ ılıılı Import and display audio linear waveform data.
UTILITY  
VALUE GRAPH📈 Graphs historical execution run values
AKASHIC📓 Display the top level attributes of an output
QUEUE🗃 Cycle lists of images files or strings for node inputs.
SELECT🤏🏽 Select an item from a user explicit list of inputs.
ROUTE🚌 Pass all data because the default is broken on connection
EXPORT 📽 Take your frames out static or animated (GIF)
IMAGE DIFF 📏 Explicitly show the differences between two images via self-similarity index
GLSL  
GLSL - GRAYSCALE Converts input to grayscale.
GLSL - NOISE Various noise functions
GLSL - PATTERN Pattern factory wip.
GLSL - POLYGON Make convex polygons
GLSL - MAP Re-project an image
GLSL - SELECT RANGE Select a value range from an image for masking.
GLSL - MIRROR Mirror an input with an optional custom pivot.
GLSL - ROTATE Rotate an input.
GLSL - TILER A tiling utility wip.
GLSL - VFX Various Video Effects.

ACKNOWLEDGEMENTS

Everyone mentioned here has been tireless in helping me, at some point, construct all the material in Jovimetrix.

   
Stable Diffusion without this, we would all still only be using pixel pushing tools
ComfyUI Thank You! for existing

COMFY DEVELOPERS & NODE MAKERS & COMMUNITY BUILDERS

     
comfy Chris Goringe Purz
pythongosssss melmass Fizzledorf
Dr. Lt. Data Trung0246 Fannovel16
Kijai WASasquatch MatisseTec
rgthree Suzue1

LICENSE

This project is licensed under the MIT License. See the LICENSE file for details.