ComfyUI Extension: ComfyUI_tinyterraNodes

Authored by TinyTerra

Created

Updated

341 stars

A selection of nodes for Stable Diffusion ComfyUI

README

tinyterraNodes

A selection of custom nodes for ComfyUI.

Enjoy my nodes and would like to help keep me awake?

tinyterra_pipeSDXL tinyterra_trueHRFix tinyterra_trueHRFix

Installation

Navigate to the ComfyUI/custom_nodes directory with cmd, and run:

git clone https://github.com/TinyTerra/ComfyUI_tinyterraNodes.git

Special Features

Fullscreen Image Viewer

Enabled by default

  • <details><summary>Adds 'Fullscreen 🌏' to the node right-click context menu</summary> Opens a Fullscreen image viewer - containing all images generated by the selected node during the current comfy session.
  • <details><summary>Adds 'Set Default Fullscreen Node 🌏' to the node right-click context menu</summary> Sets the currently selected node as the default Fullscreen node
  • <details><summary>Adds 'Clear Default Fullscreen Node 🌏' to the node right-click context menu</summary> Clears the assigned default Fullscreen node
<break>
  • Slideshow Mode

    • Toggled On - Automatically jumps to New images as they are generated (Black Background) - the UI will auto hide after a set time.
    • Toggled Off - Holds to the current user selected image (Light Background)
  • Fullscreen Overlay

    • Toggles display of a navigable preview of all of the selected nodes images
    • Toggles display of the default comfy menu
  • Shortcuts

    • 'shift + F11' => Open ttN-Fullscreen using selected node OR default fullscreen node
    • 'shift + down arrow' (Node Selected) => Set selected node as default fullscreen node
    • 'shift + down arrow' (No Node Selected) => removes default fullscreen node to None
  • Shortcuts in Fullscreen

    • 'shift + F11' => Close ttN-Fullscreen
    • 'up arrow' => Toggle Fullscreen 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 Fullscreen Mode
    • Show UI with mouse hover in Slideshow mode

Advanced XYPlot

  • pipeKSampler/SDXL input to generate xy 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.

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='<lora:add_detail.safetensors:0.8>']
  • 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 deliminated 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

  • <details><summary>Adds 'Node Dimensions 🌏' to the node right-click context menu</summary> Allows setting specific node Width and Height values as long as they are above the minimum size for the given node.
  • <details><summary>Adds 'Default BG Color 🌏' to the node right-click context menu</summary> Allows setting specific default background color for every node added.
  • <details><summary>Adds support for 'ctrl + arrow key' Node movement</summary> 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.
  • <details><summary>Adds 'Reload Node 🌏' to the node right-click context menu</summary> 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 </details>
  • <details><summary>Adds 'Slot Type Color 🌏' to the Link right-click context menu</summary> Opens a color picker dialog menu to update the color of the selected link type. </details>
  • <details><summary>Adds 'Link Border 🌏' to the Link right-click context menu</summary> Toggles link line border. </details>
  • <details><summary>Adds 'Link Shadow 🌏' to the Link right-click context menu</summary> Toggles link line shadow. </details>
  • <details><summary>Adds 'Link Style 🌏' to the Link right-click context menu</summary> Sets the default link line type. </details>

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) <br> or %input_name>input_name>widget_name% (for inputting nodes) <br>

    <details><summary>Example: </summary>

    tinyterra_prefixParsing

    </details>

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)
<br> <details open> <summary>$\Large\color{white}{Nodes}$</summary>

ttN/base

<details> <summary>tinyLoader</summary> </details> <details> <summary>tinyConditioning</summary> </details> <details> <summary>tinyKSampler</summary> </details>

ttN/pipe

<details> <summary>pipeLoader v2</summary>

(Includes ADV_CLIP_emb)

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/deb74ef1-43a7-4fd5-9cdd-b4487eaee6f0" width="50%"> </details> <details> <summary>pipeKSampler v2</summary>

Embedded with Advanced CLIP Text Encode with an additional pipe output

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/0f33d9aa-65ea-4b4f-88fd-033e7c4f1e2a" width="50%">

Old node layout:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/32b189de-42e3-4464-b3b2-4e0e225e6abe" width="50%">

With pipeLoader and pipeKSampler:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/c806c2e3-2efb-44cb-bdf0-3fbc20251456" width="50%"> </details> <details> <summary>pipeKSamplerAdvanced v2</summary>

Embedded with Advanced CLIP Text Encode with an additional pipe output

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/31dd3860-6cb0-417b-9912-f3f5a37df68b" width="50%"> </details> <details> <summary>pipeLoaderSDXL v2</summary>

SDXL Loader and Advanced CLIP Text Encode with an additional pipe output

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/cb6e43f8-a1c7-47f8-aab7-d403908bf83b" width="50%"> </details> <details> <summary>pipeKSamplerSDXL v2</summary>

SDXL Sampler (base and refiner in one) and Advanced CLIP Text Encode with an additional pipe output

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/cb6e43f8-a1c7-47f8-aab7-d403908bf83b" width="50%">

Old node layout:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/6fe28463-6ca4-4d45-818a-bbe91d84f3c4" width="50%">

With pipeLoaderSDXL and pipeKSamplerSDXL:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/faa5c807-c96c-4734-99cd-34e6024c32fb" width="50%"> </details> <details> <summary>pipeEDIT</summary>

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 </details>
<details> <summary>pipe > basic_pipe</summary>

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 </details>
<details> <summary>pipe > Detailer Pipe</summary>

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 </details>

ttN/xyPlot

<details> <summary>adv xyPlot</summary>

pipeKSampler input to generate xy plots using sampler and loader values. (Any values not set by xyPlot will be taken from the corresponding nodes)

adv_xyPlot

</details> <details> <summary>advPlot range</summary>

adv_xyPlot input to generate plot syntax across a range of values.

</details> <details> <summary>advPlot string</summary>

adv_xyPlot input to generate plot syntax for strings via a delimiter.

</details> <details> <summary>advPlot combo</summary>

adv_xyPlot input to generate plot syntax for combos with various modes.

</details>

ttN/image

<details> <summary>imageOutput</summary>

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
</details> <details> <summary>imageRemBG</summary>

(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: photobash

</details> <details> <summary>hiresFix</summary>

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 </details>

ttN/text

<details> <summary>text</summary>

Basic TextBox Loader.

  • Outputs - text (STRING) </details>
<details> <summary>textDebug</summary>

Text input, to display text inside the node, with optional print to console.

  • inputs - text, print_to_console
  • Outputs - text (STRING) </details>
<details> <summary>textConcat</summary>

3 TextBOX inputs with a single concatenated output.

  • inputs - text1, text2, text3 (STRING's), delimiter
  • Outputs - text (STRING) </details>
<details> <summary>7x TXT Loader Concat</summary>

7 TextBOX inputs concatenated with spaces into a single output, AND seperate text outputs.

  • inputs - text1, text2, text3, text4, text5, text6, text7 (STRING's), delimiter
  • Outputs - text1, text2, text3, text4, text5, text6, text7, concat (STRING's) </details>
<details> <summary>3x TXT Loader MultiConcat</summary>

3 TextBOX inputs with seperate 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) </details>

ttN/util

<details> <summary>seed</summary>

Basic Seed Loader.

  • Outputs - seed (INT) </details>
<details> <summary>float</summary>

float loader and converter

  • inputs - float (FLOAT)
  • Outputs - float, int, text (FLOAT, INT, STRING) </details>
<details> <summary>int</summary>

int loader and converter

  • inputs - int (INT)
  • Outputs - int, float, text (INT, FLOAT, STRING) </details>
</details>

ttN/legacy

<details> <summary>pipeLoader v1</summary>

(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 </details>
<details> <summary>pipeKSampler v1</summary>

(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:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/32b189de-42e3-4464-b3b2-4e0e225e6abe" width="50%">

With pipeLoader and pipeKSampler:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/c806c2e3-2efb-44cb-bdf0-3fbc20251456" width="50%"> </details> <details> <summary>pipeKSamplerAdvanced v1</summary>

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

    </details> <details> <summary>pipeLoaderSDXL v1</summary>

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 </details>
<details> <summary>pipeKSamplerSDXL v1</summary>

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:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/6fe28463-6ca4-4d45-818a-bbe91d84f3c4" width="50%">

With pipeLoaderSDXL and pipeKSamplerSDXL:

<img src="https://github.com/TinyTerra/ComfyUI_tinyterraNodes/assets/115619949/faa5c807-c96c-4734-99cd-34e6024c32fb" width="50%"> </details> <details> <summary>pipeIN</summary>

Encode up to 8 frequently used inputs into a single Pipe line.

  • Inputs - model, conditioning, conditioning, samples, vae, clip, image, seed
  • Outputs - pipe </details>
<details> <summary>pipeOUT</summary>

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 </details>
<details> <summary>pipe > xyPlot</summary>

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 </details>