tinyterraNodes
*A selection of custom nodes for ComfyUI.*
Enjoy my nodes and would like to help keep me awake?
Installation
Navigate to the _ComfyUI/custom_nodes_ directory with cmd, and run:
git clone https://github.com/TinyTerra/ComfyUI_tinyterraNodes.git
Special Features
ttN Image Viewer
*Enabled by default*
Adds ‘🌏 Fullscreen Image Viewer’ to the node right-click context menu
Opens a Fullscreen image viewer – containing all images generated by the selected node during the current comfy session.
Adds ‘🌏 Popout Image Viewer’ to the node right-click context menu
Opens a Popout image viewer – containing all images generated by the selected node during the current comfy session.
Adds ‘🌏 Set Default Fullscreen Node’ to the node right-click context menu
Sets the currently selected node as the default Fullscreen node
Adds ‘🌏 Clear Default Fullscreen Node’ to the node right-click context menu
Clears the assigned default Fullscreen node
Slideshow Mode
Toggled On – Automatically jumps to New images as they are generated if the last image is selected (Black Background) – the UI will auto hide after a set time.
Toggled Off – Holds to the current user selected image (Light Background)
UI Overlay
Toggles display of a navigable preview of all of the selected nodes images
Toggles display of the Image Viewer Settings button
*Shortcuts*
‘shift + F11’ => _Open ttN-Fullscreen Image Viewer using selected node OR default fullscreen node_
‘shift + F10’ => _Open ttN-Popout Image Viewer using selected node OR default fullscreen node_
*Shortcuts in Image Viewer*
‘up arrow’ => _Toggle UI Overlay_
‘down arrow’ => _Toggle Slideshow Mode_
‘left arrow’ => _Select Image to the left_
‘shift + left arrow’ => _Select Image 5 to the left_
‘ctrl + left arrow’ => _Select the first Image_
‘right arrow’ => _Select Image to the right_
‘shift + right arrow’ => _Select Image 5 to the right_
‘ctrl + right arrow’ => _Select last Image_
‘mouse scroll’ => _Zoom the current image in and out_
‘ctrl + mouse scroll’ => _Select image to Left/Right_
‘left click + drag’ => _Update the current image’s position_
‘double click’ => _Reset position of current image_
‘esc’ => _Close Image Viewer_
‘F’ => _Fit image to Viewer window_
Show UI with mouse hover in Slideshow mode
Advanced XY(Z)Plot
pipeKSampler/SDXL input to generate xyz plots using any previous input nodes.
_(Any values not set by xyPlot will be taken from the corresponding nodes)_
Advanced xyPlot can take multiple variables for each axis somewhat programmatically.
Any image input – Use the ‘advPlot images’ node to create an xyplot from any image input.
Syntax:
<axis number1:label1>
[node_ID:widget_Name='value']
<axis number2:label2>
[node_ID:widget_Name='value2']
[node_ID:widget2_Name='value']
[node_ID2:widget_Name='value']
For Example:
<1:v_label>
[2:ckpt_name='model.safetensors']
<2:custom label>
[2:ckpt_name='checkpoint.xyz']
[2:vae_name='someVae.xyz']
[4:text='Summer sunset']
labels:
Any custom string for a custom axis label
v_label – for a concatenation of the values being set. In the example above if both were set to v_label:
model.safetensors
checkpoint.xyz, someVae.xyz, Summer sunset
tv_label – for the option title and value concatenated. In the example above if both were set to tv_label:
ckpt_name: model.safetensors
ckpt_name: checkpoint.xyz, vae_name: someVae.xyz, text: Summer sunset
itv_label – for the node ID, option title and value concatenated. In the example above if both were set to itv_label:
[2] ckpt_name: model.safetensors
[2] ckpt_name: checkpoint.xyz, [2] vae_name: someVae.xyz, [4] text: Summer sunset
Node ID’s:
Suggested to use ‘Badge: ID + nickname’ in ComfyUI Manager settings to be able to view node IDs.
Autocomplete:
ttN Autocomplete will activate when the advanced xyPlot node is connected to a sampler, and will show all the nodes and options available, as well as an ‘add axis’ option to auto add the code for a new axis number and label.
Search and Replace:
if you include %search;replace% as the value it will use the current nodes value and do a search and replace using these values.
you can include more than one to replace different strings
Append to original value
if you include .append to the widget name it will append the xyPlot value to the original instead of overwriting it.
For example: [1:loras.append=’\‘]
Z-Axis support for multi plotting
Creates extra xyPlots with the z-axis value changes as a base
Node based plotting to avoid requiring manually writing syntax
advPlot range for easily created int/float ranges
advPlot string for delimited string ‘ranges’
Auto Complete
*Enabled by default*
displays a popup to autocomplete embedding filenames in text widgets – to use, start typing embedding and select an option from the list.
displays a popup to autocomplete noodlesoup categories – to use, start typing __ and select an option from the list.
displays a popup in ttN ‘loras’ input to autocomplete loras from a list.
Option to disable ([ttNodes] enable_embed_autocomplete = True | False)
Dynamic Widgets
*Enabled by default*
Automatically hides and shows widgets depending on their relevancy
Option to disable ([ttNodes] enable_dynamic_widgets = True | False)
ttNinterface
*Enabled by default*
Adds ‘Node Dimensions 🌏’ to the node right-click context menu
Allows setting specific node Width and Height values as long as they are above the minimum size for the given node.
Adds ‘Default BG Color 🌏’ to the node right-click context menu
Allows setting specific default background color for every node added.
Adds support for ‘ctrl + arrow key’ Node movement
This aligns the node(s) to the set ComfyUI grid spacing size and move the node in the direction of the arrow key by the grid spacing value. Holding shift in addition will move the node by the grid spacing size * 10.
Adds ‘Reload Node 🌏’ to the node right-click context menu
Creates a new instance of the node with the same position, size, color and title . It attempts to retain set widget values which is useful for replacing nodes when a node/widget update occurs
Adds ‘Slot Type Color 🌏’ to the Link right-click context menu
Opens a color picker dialog menu to update the color of the selected link type.
Adds ‘Link Border 🌏’ to the Link right-click context menu
Toggles link line border.
Adds ‘Link Shadow 🌏’ to the Link right-click context menu
Toggles link line shadow.
Adds ‘Link Style 🌏’ to the Link right-click context menu
Sets the default link line type.
Save image prefix parsing
Add date/time info to filenames or output folder by using: %date:yyyy-MM-dd-hh-mm-ss%
Parse any upstream setting into filenames or output folder by using %[widget_name]% (for the current node)
or %input_name>input_name>widget_name% (for inputting nodes)
Example:
Node Versioning
All tinyterraNodes now have a version property so that if any future changes are made to widgets that would break workflows the nodes will be highlighted on load
Will only work with workflows created/saved after the v1.0.0 release
AutoUpdate
*Disabled by default*
Option to auto-update the node pack ([ttNodes] auto_update = False | True)
$\Large\color{white}{Nodes}$
ttN/base
tinyLoader
tinyConditioning
tinyKSampler
ttN/pipe
pipeLoader v2
(Includes ADV_CLIP_emb)
pipeKSampler v2
Embedded with Advanced CLIP Text Encode with an additional pipe output
Old node layout:
With pipeLoader and pipeKSampler:
pipeKSamplerAdvanced v2
Embedded with Advanced CLIP Text Encode with an additional pipe output
pipeLoaderSDXL v2
SDXL Loader and Advanced CLIP Text Encode with an additional pipe output
pipeKSamplerSDXL v2
SDXL Sampler (base and refiner in one) and Advanced CLIP Text Encode with an additional pipe output
Old node layout:
With pipeLoaderSDXL and pipeKSamplerSDXL:
pipeEDIT
Update/Overwrite any of the 8 original inputs in a Pipe line with new information.
_Inputs – pipe, model, conditioning, conditioning, samples, vae, clip, image, seed_
_Outputs – pipe_
pipe > basic_pipe
Convert ttN pipe line to basic pipe (to be compatible with ImpactPack), WITH original pipe throughput
_Inputs – pipe[model, conditioning, conditioning, samples, vae, clip, image, seed]_
_Outputs – basic_pipe[model, clip, vae, conditioning, conditioning], pipe_
pipe > Detailer Pipe
Convert ttN pipe line to detailer pipe (to be compatible with ImpactPack), WITH original pipe throughput
_Inputs – pipe[model, conditioning, conditioning, samples, vae, clip, image, seed], bbox_detector, sam_model_opt_
_Outputs – detailer_pipe[model, vae, conditioning, conditioning, bbox_detector, sam_model_opt], pipe_
ttN/xyPlot
adv xyPlot
pipeKSampler input to generate xy plots using sampler and loader values. (Any values not set by xyPlot will be taken from the corresponding nodes)
advPlot images
Node to generate xyz plots from any image inputs.
advPlot range
adv_xyPlot input to generate plot syntax across a range of values.
advPlot string
adv_xyPlot input to generate plot syntax for strings via a delimiter.
advPlot combo
adv_xyPlot input to generate plot syntax for combos with various modes.
ttN/image
imageOutput
Preview or Save an image with one node, with image throughput.
_Inputs – image, image output[Hide, Preview, Save, Hide/Save], output path, save prefix, number padding[None, 2-9], file type[PNG, JPG, JPEG, BMP, TIFF, TIF] overwrite existing[True, False], embed workflow[True, False]_
_Outputs – image_
imageRemBG
(Using RemBG)
Background Removal node with optional image preview & save.
_Inputs – image, image output[Disabled, Preview, Save], save prefix_
_Outputs – image, mask_
Example of a photobashing workflow using pipeNodes, imageRemBG, imageOutput and nodes from ADV_CLIP_emb and ImpactPack:
hiresFix
Upscale image by model, optional rescale of result image.
_Inputs – image, vae, upscale_model, rescale_after_model[true, false], rescale[by_percentage, to Width/Height], rescale method[nearest-exact, bilinear, area], factor, width, height, crop, image_output[Hide, Preview, Save], save prefix, output_latent[true, false]_
_Outputs – image, latent_
ttN/text
text
Basic TextBox Loader.
_Outputs – text (STRING)_
textDebug
Text input, to display text inside the node, with optional print to console.
_inputs – text, print_to_console_
_Outputs – text (STRING)_
textConcat
3 TextBOX inputs with a single concatenated output.
_inputs – text1, text2, text3 (STRING’s), delimiter_
_Outputs – text (STRING)_
7x TXT Loader Concat
7 TextBOX inputs concatenated with spaces into a single output, AND separate text outputs.
_inputs – text1, text2, text3, text4, text5, text6, text7 (STRING’s), delimiter_
_Outputs – text1, text2, text3, text4, text5, text6, text7, concat (STRING’s)_
3x TXT Loader MultiConcat
3 TextBOX inputs with separate text outputs AND multiple concatenation variations (concatenated with spaces).
_inputs – text1, text2, text3 (STRING’s), delimiter_
_Outputs – text1, text2, text3, 1 & 2, 1 & 3, 2 & 3, concat (STRING’s)_
ttN/util
seed
Basic Seed Loader.
_Outputs – seed (INT)_
float
float loader and converter
_inputs – float (FLOAT)_
_Outputs – float, int, text (FLOAT, INT, STRING)_
int
int loader and converter
_inputs – int (INT)_
_Outputs – int, float, text (INT, FLOAT, STRING)_
ttN/legacy
pipeLoader v1
(Modified from Efficiency Nodes and ADV_CLIP_emb)
Combination of Efficiency Loader and Advanced CLIP Text Encode with an additional pipe output
_Inputs – model, vae, clip skip, (lora1, modelstrength clipstrength), (Lora2, modelstrength clipstrength), (Lora3, modelstrength clipstrength), (positive prompt, token normalization, weight interpretation), (negative prompt, token normalization, weight interpretation), (latent width, height), batch size, seed_
_Outputs – pipe, model, conditioning, conditioning, samples, vae, clip, seed_
pipeKSampler v1
(Modified from Efficiency Nodes and QOLS_Omar92)
Combination of Efficiency Loader and Advanced CLIP Text Encode with an additional pipe output
_Inputs – pipe, (optional pipe overrides), xyplot, (Lora, model strength, clip strength), (upscale method, factor, crop), sampler state, steps, cfg, sampler name, scheduler, denoise, (image output [None, Preview, Save]), Save_Prefix, seed_
_Outputs – pipe, model, conditioning, conditioning, samples, vae, clip, image, seed_
Old node layout:
With pipeLoader and pipeKSampler:
pipeKSamplerAdvanced v1
Combination of Efficiency Loader and Advanced CLIP Text Encode with an additional pipe output
_Inputs – pipe, (optional pipe overrides), xyplot, (Lora, model strength, clip strength), (upscale method, factor, crop), sampler state, steps, cfg, sampler name, scheduler, starts_at_step, return_with_leftover_noise, (image output [None, Preview, Save]), Save_Prefix_
_Outputs – pipe, model, conditioning, conditioning, samples, vae, clip, image, seed_
pipeLoaderSDXL v1
SDXL Loader and Advanced CLIP Text Encode with an additional pipe output
_Inputs – model, vae, clip skip, (lora1, modelstrength clipstrength), (Lora2, modelstrength clipstrength), model, vae, clip skip, (lora1, modelstrength clipstrength), (Lora2, modelstrength clipstrength), (positive prompt, token normalization, weight interpretation), (negative prompt, token normalization, weight interpretation), (latent width, height), batch size, seed_
_Outputs – sdxlpipe, model, conditioning, conditioning, vae, model, conditioning, conditioning, vae, samples, clip, seed_
pipeKSamplerSDXL v1
SDXL Sampler (base and refiner in one) and Advanced CLIP Text Encode with an additional pipe output
_Inputs – sdxlpipe, (optional pipe overrides), (upscale method, factor, crop), sampler state, base_steps, refiner_steps cfg, sampler name, scheduler, (image output [None, Preview, Save]), Save_Prefix, seed_
_Outputs – pipe, model, conditioning, conditioning, vae, model, conditioning, conditioning, vae, samples, clip, image, seed_
Old node layout:
With pipeLoaderSDXL and pipeKSamplerSDXL:
pipeIN
Encode up to 8 frequently used inputs into a single Pipe line.
_Inputs – model, conditioning, conditioning, samples, vae, clip, image, seed_
_Outputs – pipe_
pipeOUT
Decode single Pipe line into the 8 original outputs, AND a Pipe throughput.
_Inputs – pipe_
_Outputs – model, conditioning, conditioning, samples, vae, clip, image, seed, pipe_
pipe > xyPlot
pipeKSampler input to generate xy plots using sampler and loader values. (Any values not set by xyPlot will be taken from the corresponding pipeKSampler or pipeLoader)
_Inputs – grid_spacing, latent_id, flip_xy, x_axis, x_values, y_axis, y_values_
_Outputs – xyPlot_