Nodes Browser
ComfyDeploy: How Jovimetrix works in ComfyUI?
What is Jovimetrix?
Webcam, MIDI, Spout, and GLSL support with animation via tick. Features wave-based parameter modulation, math operations, universal value conversion, shape masking, image channel ops, batch processing, dynamic bus routing, GIPHY and SPOUT integration. Load images/videos from URLs, save output anywhere, and apply transformations like flattening, cropping, and color adjustments. Includes tools for color blindness simulation, stereograms, and stereoscopic imagingβplus much more!
How to install it in ComfyDeploy?
Head over to the machine page
- Click on the "Create a new machine" button
- Select the
Edit
build steps - Add a new step -> Custom Node
- Search for
Jovimetrix
and select it - Close the build step dialig and then click on the "Save" button to rebuild the machine
SPONSORSHIP
Please consider sponsoring me if you enjoy the results of my work, code or documentation or otherwise. A good way to keep code development open and free is through sponsorship.
<div align="center"> </div>HIGHLIGHTS
- 30 function
BLEND
node -- subtract, multiply and overlay like the best - Vector support for 2, 3, 4 size tuples of integer or float type
- Specific RGB/RGBA color vector support that provides a color picker
- All Image inputs support RGBA, RGB or pure MASK input
- Full Text generation support using installed system fonts
- Basic parametric shape (Circle, Square, Polygon) generator~~
COLOR BLIND
check supportCOLOR MATCH
against existing images or create a custom LUT- Generate
COLOR THEORY
spreads from an existing image COLOR MEANS
to generate palettes for existing images to keep other images in the same tonal rangesPIXEL SPLIT
separate the channels of an image to manipulate andPIXEL MERGE
them back togetherSTACK
a series of images into a new single image vertically, horizontally or in a grid- Or
FLATTEN
a batch of images into a single image with each image subsequently added on top (slap comp) VALUE
Node has conversion support for all ComfyUI types and some 3rd party types (2DCoords, Mixlab Layers)LERP
node to linear interpolate all ComfyUI and Jovimetrix value types- Automatic conversion of Mixlab Layer types into Image types
- Generic
ARRAY
that can Merge, Split, Select, Slice or Randomize a list of ANY type STRINGER
node to perform specific string manipulation operations: Split, Join, Replace, Slice.- A
QUEUE
Node that supports recursing directories, filtering multiple file types and batch loading - Use the
OP UNARY
andOP BINARY
nodes to perform single and double type functions across all ComfyUI and Jovimetrix value types - Manipulate vectors with the
SWIZZLE
node to swap their XYZW positions DELAY
execution at certain parts in a workflow, with or without a timeout- Generate curve data with the
TICK
andWAVE GEN
nodes
Migrated to Jovi_GLSL
~~* GLSL shader support~~
~~* * GLSL Node
provides raw access to Vertex and Fragment shaders~~
~~* * Dynamic GLSL
dynamically convert existing GLSL scripts file into ComfyUI nodes at runtime~~
~~* * Over 20+ Hand written GLSL nodes to speed up specific tasks better done on the GPU (10x speedup in most cases)~~
Migrated to Jovi_Capture
~~* STREAM READER
node to capture monitor, webcam or url media~~
~~* STREAM WRITER
node to export media to a HTTP/HTTPS server for OBS or other 3rd party streaming software~~
Migrated to Jovi_Spout
~~* SPOUT
streaming support WINDOWS ONLY~~
Migrated to Jovi_MIDI
~~* MIDI READER
Captures MIDI messages from an external MIDI device or controller~~
~~* MIDI MESSAGE
Processes MIDI messages received from an external MIDI controller or device~~
~~* MIDI FILTER
(advanced filter) to select messages from MIDI streams and devices~~
~~* MIDI FILTER EZ
simpler interface to filter single messages from MIDI streams and devices~~
Migrated to Jovi_Help
~~* Help System for ALL NODES that will auto-parse unknown knows for their type data and descriptions~~
Migrated to Jovi_Colorizer
~~* Colorization for ALL NODES using their own node settings, their node group or via regex pattern matching~~
UPDATES
<h2>DO NOT UPDATE JOVIMETRIX PAST VERSION 1.7.48 IF YOU DONT WANT TO LOSE A BUNCH OF NODES</h2>Nodes that have been removed are in various other packages now. You can install those specific packages to get the functionality back, but I have no way to migrate the actual connections -- you will need to do that manually. **
Nodes that have been migrated:
- ALL MIDI NODES:
-
- MIDIMessageNode
-
- MIDIReaderNode
-
- MIDIFilterNode
-
- MIDIFilterEZNode
- ALL STREAMING NODES:
-
- StreamReaderNode
-
- StreamWriterNode
-
- SpoutWriterNode
- ALL GLSL NODES:
-
- GLSL
-
- GLSL BLEND LINEAR
-
- GLSL COLOR CONVERSION
-
- GLSL COLOR PALETTE
-
- GLSL CONICAL GRADIENT
-
- GLSL DIRECTIONAL WARP
-
- GLSL FILTER RANGE
-
- GLSL GRAYSCALE
-
- GLSL HSV ADJUST
-
- GLSL INVERT
-
- GLSL NORMAL
-
- GLSL NORMAL BLEND
-
- GLSL POSTERIZE
-
- GLSL TRANSFORM
2025/04/19 @2.0.7:
- all JS messages fixed
2025/04/19 @2.0.6:
- fixed reset message from JS
2025/04/19 @2.0.5:
- patched new frontend input mechanism for dynamic inputs
- reduced requirements
- removed old vector conversions waiting for new frontend mechanism
2025/04/17 @2.0.4:
- fixed bug in resize_matte
MODE
that would fail when the matte was smaller than the input image - migrated to image_crop functions to cozy_comfyui
2025/04/15 @2.0.3:
- migrated to image_stack in cozy_comfyui
2025/04/14 @2.0.2:
- migrated out old routes to cozy_comfyui
2025/04/14 @2.0.1:
- numpy version set for < 2.0.0
- core supports switched to cozy_comfyui
2025/04/12 @2.0.0:
-
REMOVED ALL STREAMING, MIDI and GLSL nodes for new packages, HELP System and Node Colorization system:
Jovi_Capture - Web camera, Monitor Capture, Window Capture
Jovi_MIDI - MIDI capture and MIDI message parsing
Jovi_Spout - SPOUT Streaming support
-
all nodes will accept
LIST
orBATCH
and process as if all elements are in a list. -
patched constant node to work with
MATTE_RESIZE
-
patched import loader to work with old/new comfyui
-
missing array web node partial
-
removed array and no one even noticed.
-
all inputs should be treated as a list even single elements []
2025/03/28 @1.7.46:
- ~~updated requirements for numpy to only be >=1.26.4~~
- removed to keep numba working with numpy < 2.0
2025/03/25 @1.7.45:
- no work around comfyui not doing type conversion past version 1.10.14
2025/03/18 @1.7.42:
- updated numby jit to ignore python objects
- aligned float("NaN") constructs
2025/03/18 @1.7.40:
- allow vectors to be inline inputs + widget cause waiting for ComfyUI team is painful
- changed precision default to 3
- merged new action trigger from ComfyUI team
2025/03/06 @1.7.34:
- prep for Purz stream
- removed security scanner failures for in-line http links
- auto-size masks during mask add
- fix some limits on transform node
- better constraints for UNARY and BINARY OP nodes
- fix inversion in pixel merge
- defaults for regex colorizer entries
- fall through for constant node input
INSTALLATION
Please see the wiki for advanced use of the environment variables used during startup
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 <code>virtual environment</code> (<code><i>venv</i></code>), make sure it is activated before installation. Then install the requirements with the command:
pip install -r requirements.txt