data:image/s3,"s3://crabby-images/efc0c/efc0c2f576a053b18bddfebe7c6ad8d7e16f3e7e" alt="Painting Coder Utilities Logo"
ComfyUI Painting Coder Utilities Nodes
A practical collection of nodes designed for ComfyUI that streamlines image and text processing workflows. Features include optimized resolution adjustment, text cleaning tools, dynamic image/text combination, and mask preview utilities. Created by a programmer who enjoys painting, this collection is perfect for artists and developers looking to enhance their AI art creation pipeline.
English | 简体中文
⚠️ Important Update Notice
Version 0.3.0 Breaking Changes:
- The namespace has been modified to improve compatibility
- This update will cause older workflows to stop working
- To fix your existing workflows, please use our workflow fixer tool:
data:image/s3,"s3://crabby-images/6cf8b/6cf8b7cd29f3497b8c594d5f05b5b536ff0bf5e7" alt="Workflow Fixer Tool"
Open the page Workflow Fixer Tool Or go to the directory ComfyUI_PaintingCoderUtils/docs/fix/ to find workflow_fixer.html and open the page
- Added new feature: Path separator conversion between Windows and Unix-style (Linux/Mac) formats
- The fixer tool now supports both namespace updates and path format conversion
🎯 Nodes
📐Image Resolution Adjuster
A utility node for adjusting image resolutions according to SDXL optimal aspect ratios.
data:image/s3,"s3://crabby-images/60560/6056064d1447b49c84037cb702e3a0d99f6c4239" alt="Image Resolution Adjuster Settings"
Image resolution adjustment with customizable background color fill
data:image/s3,"s3://crabby-images/4f0d8/4f0d83fd3d79ad1b947aa5d2aa99a4eee01dd474" alt="Image Resolution Adjuster Settings"
Batch image redrawing with aspect ratio preservation
data:image/s3,"s3://crabby-images/c9786/c9786b374d3e95710b495c64272a54567502152a" alt="Batch Image Redrawing"
Flux Image Resolution Adjuster Batch Workflow Download
<a href="https://raw.githubusercontent.com/jammyfu/ComfyUI_PaintingCoderUtils/refs/heads/main/workflow/Flux_Image_Resolution_Adjuster_scale_up_batch_workflow.json" download="Flux_Image_Resolution_Adjuster_batch_workflow.json">⬇️ Download Workflow JSON (Right Click Save As)</a>
Features:
- Supports all SDXL optimal resolutions:
- 1:1 (1024x1024)
- 9:7 (1152x896)
- 7:9 (896x1152)
- 3:2 (1216x832)
- 2:3 (832x1216)
- 7:4 (1344x768)
- 4:7 (768x1344)
- 12:5 (1536x640)
- 5:12 (640x1536)
- Multiple extend modes:
- contain: Scale proportionally to fit within target size
- cover: Scale proportionally to cover target size
- fill: Stretch to fill target size
- inside: Like contain, but only downscale
- outside: Like cover, but only upscale
- top/bottom/left/right/center: Position image within target size
- Adjustable scaling factor
- Configurable maximum and minimum resolution limits
- Background color picker
- Maintains aspect ratio during adjustment
Usage:
- Add the node to your workflow
- Select target resolution from SDXL presets
- Choose extend mode as needed
- Use color picker to set background color
- Adjust scaling factor and resolution limits as needed
🌐Web Image Loader
A node for loading images from the web.
data:image/s3,"s3://crabby-images/765d6/765d6e1fb23ff7dbdb0369bce79737dee54bcfbd" alt="Web Image Loader Example"
Features:
- Supports loading images from URLs and Base64 format
- Automatically handles image formats
- Supports batch image loading
- Error handling:
- Returns a placeholder image for invalid URLs
- Gracefully handles exceptions, automatically removing erroneous images
Usage:
- Add the node to your workflow
- Input the image URL
- The node will automatically load and process the image
- The output image can be connected to other nodes requiring image input
Use Cases:
- Loading images from online resources
- Dynamic image processing workflows
- Batch image downloading and processing
🖼️Image to Base64 Encoder
A node for converting images to Base64 encoding.
data:image/s3,"s3://crabby-images/a7a9f/a7a9f3ddba023cb4a37ced73a0394d8eef8e003f" alt="Image to Base64 Encoder Example"
Features:
- Supports various image formats (JPEG, PNG, BMP, etc.)
- Automatically handles image size and format
- Supports batch image encoding
- Error handling:
- Returns error information for invalid images
- Gracefully handles exceptions, ensuring workflow continuity
Usage:
- Add the node to your workflow
- Input the image file or image path
- The node will automatically convert the image to Base64 encoding
- The output Base64 string can be connected to other nodes requiring Base64 input
Use Cases:
- Image data transmission
- Embedding images in HTML or JSON
- Dynamic image processing workflows
- Batch image encoding and processing
🔀 Switch Node (Image Switch, Text Switch)
Switch nodes are used to dynamically switch between different input or output paths in a workflow.
data:image/s3,"s3://crabby-images/559ca/559ca35cfdd84f6c55f155706240f5e6040c0c40" alt="Switch Node"
Features:
- Supports multiple input and output types
- Configurable switching conditions
- Automatically handles input and output connections
Usage:
- Add the Switch node to your workflow
- Configure switching conditions (e.g., boolean values, numerical ranges, etc.)
- Connect different input and output paths
- Automatically switch paths based on conditions
Use Cases:
- Dynamically adjusting workflows
- Conditional branch processing
- Multi-path selection
🖼️Image Size Creator
A node for creating image dimensions.
data:image/s3,"s3://crabby-images/f8a7f/f8a7f43a515dc88deb8d013fea21b105371ec196" alt="Image Size Creator"
Features:
- Supports all SDXL optimal resolutions:
- 1:1 (1024x1024)
- 9:7 (1152x896)
- 7:9 (896x1152)
- 3:2 (1216x832)
- 2:3 (832x1216)
- 7:4 (1344x768)
- 4:7 (768x1344)
- 12:5 (1536x640)
- 5:12 (640x1536)
- Adjustable scale factor
- Supports landscape, portrait and square modes
- Automatic calculation of optimal resolution
Usage:
- Add the node to your workflow
- Select image mode (landscape/portrait/square)
- Choose target resolution
- Adjust scale factor (optional)
Use Cases:
- Creating images with specific dimensions
- SDXL image generation optimization
- Batch image processing workflows
✨Image Size Creator Plus
data:image/s3,"s3://crabby-images/ab783/ab783ecc5bbd82042a31248170cdfc8f041cae9f" alt="Image Size Creator Plus"
An enhanced version of the image size creator that supports both SDXL and Midjourney standard resolutions. Key features:
- Supports switching between SDXL and Midjourney styles
- Includes all SDXL standard resolutions
- Includes all Midjourney standard resolutions
- Three modes: landscape, portrait, and square
- Adjustable scale factor
🖼️Image Latent Creator
A node for creating empty image latent spaces.
Features:
- Inherits all functionality from Image Size Creator
- Supports batch size settings
- Automatically creates optimized latent space dimensions
- Supports additional PNG information
Usage:
- Add the node to your workflow
- Set desired image dimension parameters
- Set batch size
- Connect to nodes requiring latent space input
Use Cases:
- Creating empty latent spaces
- SDXL workflow initialization
- Batch image generation
- Custom latent space processing
✨Image Latent Creator Plus
An enhanced version of the latent creator that inherits all functionality from Image Size Creator Plus and supports batch latent space creation.
data:image/s3,"s3://crabby-images/de121/de12137db535f554ed1dab98a7082ccf82764e5a" alt="Image Latent Creator Plus"
✂️Remove Empty Lines And Leading Spaces
A text processing node that cleans up text by removing empty lines and leading/trailing spaces.
data:image/s3,"s3://crabby-images/54c98/54c98aa234c5178ca672a0fb9c9d40f9d55d595c" alt="Remove Empty Lines And Leading Spaces"
Features:
- Removes empty lines from text
- Removes leading and trailing spaces
- Option to keep single empty line between paragraphs
- Option to preserve indentation
- Supports batch text processing
Usage Example:
Input text:
Hello World
This is a test
Multiple empty lines above
Output text (with default settings):
Hello World
This is a test
Multiple empty lines above
Parameters:
output type
: Output type (text, list)
remove empty line option
: Remove empty lines
remove loading space option
: Remove spaces
Use Cases:
- Cleaning up prompt text
- Formatting text for LoRA training
- Preparing text for text-to-image generation
- Standardizing text input format
Remove extra empty lines and spaces to generate text:
data:image/s3,"s3://crabby-images/c1f03/c1f036478e5ad727ca1e9f56d51a1c9705f05214" alt="Remove extra empty lines and spaces to generate text"
Remove empty lines while keeping spaces to generate text:
data:image/s3,"s3://crabby-images/daecb/daecbf5fd865a06a24024985de227f4f36e8ae35" alt="Remove empty lines while keeping spaces to generate text"
Remove spaces while keeping empty lines to generate text:
data:image/s3,"s3://crabby-images/88232/8823200b3c9fb83d37c32f8a7f5dd02cdf10ab5c" alt="Remove spaces while keeping empty lines to generate text"
Remove empty lines and spaces to generate list:
data:image/s3,"s3://crabby-images/e43ce/e43ceb6ec2a6c03bb0cae17108d11e5c0498c4d6" alt="Remove empty lines and spaces to generate list"
🔗Text Combiner✨
Added Text Combiner node for combining multiple text inputs into a single output.
data:image/s3,"s3://crabby-images/69294/692940976b3a87605b160dbb4a8dd359a8a58964" alt="Added Text Combiner node for combining multiple text inputs into a single output."
Features:
- Dynamic inputs: automatically adds new input points when connected
- Flexible separators:
- Supports regular expressions
- Supports escape characters (e.g., \n, \r)
- Uses space when left empty
- Smart line breaks: automatically splits output by line when separator includes newline
- Auto filtering: removes empty lines while preserving pure space content
Usage Examples:
-
Basic Usage:
- Using comma separator:
,
- Output: text1, text2, text3
-
Line Break Separator:
- Using newline:
\n
- Output:
text1
text2
text3
-
Mixed Separator:
- Using comma or newline:
,|\n
- Supports both separator types
-
Empty Separator:
- Leave empty
- Directly joins text with spaces
🖼️Dynamic Image Input
A node for dynamically combining multiple image inputs.
Features:
- Dynamic input ports: automatically adds new image input points when connected
- Smart image processing:
- Automatically filters empty inputs
- Maintains image format and quality
- Supports batch image processing
- Error handling:
- Returns blank image when no valid inputs
- Gracefully handles exceptions
- Output format: returns image list for further processing
Usage:
- Add the node to your workflow
- Connect image inputs (new input ports will be created automatically)
- Node will automatically combine all non-empty image inputs
- Output can be connected to other nodes that require image lists
Use Cases:
- Batch image processing
- Image collection management
- Dynamic workflow building
- Image list generation
📝 Text Display Enhancer (Show Text Plus)
An enhanced text display node that provides more text formatting and display options.
data:image/s3,"s3://crabby-images/bcb82/bcb82e33b913c66f1037c10c62f7ca46d4e7c099" alt="Text Display Enhancer Example"
Features:
- Display Mode Options:
- Normal Mode: Displays text directly
- Text Statistics Functionality:
- Character Count
- Word Count
- Line Count
- Supports automatic line wrapping for long texts
- Supports multilingual text
Usage Instructions:
- Add the node to your workflow
- Connect the text input
- Select the display mode
📝 Multiline Text Input (Multiline Text)
A node that supports multiline text input, making it easy to input and edit long text content.
data:image/s3,"s3://crabby-images/bcb82/bcb82e33b913c66f1037c10c62f7ca46d4e7c099" alt="Multiline Text Input Example"
Features:
- Supports multiline text input and editing
- Retains text formatting and line breaks
- Compatible with both Chinese and English input
- User-friendly text editing interface
- Supports copy and paste operations
Usage Instructions:
- Add the node to your workflow
- Double-click the text box to edit
- Supports direct pasting of multiline text
- Click outside the area to save after editing
Usage Scenarios:
- Inputting long prompt phrases
- Editing multiline descriptive texts
- Batch text processing
- Preparing texts for LoRA training
🎭Mask Preview
A utility node for previewing and inspecting image masks.
data:image/s3,"s3://crabby-images/70d82/70d8236ef92a5a7d206aa0bf42e6ba31712e9924" alt="Mask Preview Example"
Features:
- Intuitive mask area visualization
- Multiple preview modes:
- Original mask
- Outline highlight
- Support for batch mask preview
- Real-time preview updates
Usage:
- Add the node to your workflow
- Connect mask input
- Select preview mode
- Adjust display parameters
📦 Installation
- Navigate to ComfyUI's
custom_nodes
directory
- Clone the repository:
cd custom_nodes
git clone https://github.com/jammyfu/ComfyUI_PaintingCoderUtils.git
- Restart ComfyUI
📝 License
MIT License
🤝 Updates
v0.3.5 Update (2025-01-25)
- New Features:
- Added Image Size Creator Plus node, supporting SDXL and Midjourney dimensions
- Added Image Latent Creator Plus node, inheriting all Plus node functionalities
- Optimized Plus node user interface and interaction experience
- Added more resolution preset options
- Improved node performance and stability
v0.3.4 Update (2025-01-24)
- Updates:
- Modified the ComfyUI workflow fixer tool page to enhance user experience
- Added more error messages to help users locate issues faster
- Optimized file upload and download functionality to support more file processing
- Improved path separator conversion functionality to enhance cross-platform compatibility
- Enhanced interface response speed to reduce loading time
v0.3.3 (2025-01-23)
- Improvements:
- Bug fixes, added workflow fixer tool to repair old version workflow JSON files
- Added path separator conversion functionality to switch between Windows and Unix formats
- Added file upload functionality to upload JSON files for repair
- Added file download functionality to download repaired JSON files or ZIP files
v0.3.2 (2025-01-22)
- Improvements:
- Enhanced the workflow fixer tool with more error handling and informative messages
- Optimized the user interface for more intuitive operation
- Added support for more node types
- Improved the stability of the path separator conversion functionality
- Fixed issues where JSON files could not be loaded correctly in certain cases
v0.3.1 (2025-01-22)
- Bug Fixes:
- Fixed crash issue in Text Combiner when handling special characters
- Fixed issue with Dynamic Image Input node not handling inputs correctly in certain cases
- Fixed display error in Mask Previewer during batch preview
- Fixed compatibility issues with path separator conversion functionality on some systems
- Fixed processing errors in Image Resolution Adjuster at specific resolutions
v0.3.0 (2025-01-21)
- Breaking Changes:
- Modified namespace structure for better compatibility
- Added workflow fixer tool for migration
- Added path separator conversion functionality
- Enhanced error handling and user feedback
- Improved cross-platform compatibility
v0.2.2 (2024-01-09)
- Added Mask Switch node
- Support switching between two masks based on conditions
- Provides default blank mask handling
- Optimized exception handling mechanism
- Maintains mask format and quality
v0.2.1 (2024-01-07)
- Added Web Image Loader node
- Support loading images from URLs and Base64
- Automatic image format handling
- Support batch image loading
- Error handling: returns placeholder image for invalid URLs, graceful exception handling
- Cache support for improved loading efficiency
- Preview feature: generates and saves preview images
v0.2.0 (2024-01-06)
-
Added Image Switch node
- Support switching between two images based on conditions
- Provides default blank image handling
- Optimized exception handling mechanism
- Maintains image format and quality
-
Added Text Switch node
- Support switching between two texts based on conditions
- Provides default blank text handling
- Optimized exception handling mechanism
v0.1.9 (2024-01-05)
- Enhanced Image Resolution Adjuster
- Added mask feathering functionality
- Improved mask edge processing algorithm
- Enhanced mask processing performance
- Optimized edge smoothing effects
v0.1.8 (2024-01-04)
- Optimized Text Combiner
- Improved text concatenation logic
- Enhanced performance for large text processing
- Fixed special character handling issues
- Optimized memory usage
v0.1.7 (2024-01-03)
- Enhanced Image Resolution Adjuster
- Improved extend mode algorithms
- Enhanced image processing performance
- Fixed edge handling issues
- Optimized memory usage
v0.1.6 (2024-01-02)
- Added Multiline Text Input node
- Support for multiline text input and editing
- Preserves text formatting and line breaks
- Compatible with both Chinese and English input
- User-friendly text editing interface
- Supports copy and paste operations
v0.1.5 (2024-12-28)
- Added Mask Preview node
- Added real-time preview update
- Added batch mask preview
v0.1.4 (2024-12-27)
- Added Show Text Plus node
- Added multiple display modes
- Implemented text statistics functionality
- Added support for custom display options
- Optimized long text display
v0.1.3 (2024-12-26)
- Added Dynamic Image Input Combiner
- Implemented dynamic input ports
- Added smart image processing
- Optimized error handling mechanism
- Added support for image list output
v0.1.2 (2024-12-25)
- Added image outline feature
- Added text combiner node
v0.1.1 (2024-12-25)
- Added TextCombiner node
- Implemented dynamic input connections
- Added support for regex separators
- Added support for newlines and escape characters
- Added empty separator handling
- Optimized text joining logic
v0.1.0 (2024-12-23)
- Initial release
- Added Image Resolution Adjuster:
- Support for SDXL optimal resolutions
- Multiple extend modes
- Color picker for background
- Scale factor adjustment
- Resolution limits
- Added Remove Empty Lines And Leading Spaces:
- Text cleaning functionality
- Configurable preservation options
- Batch processing support
Planned Features
- Dynamic image input combination
- Text template system
- More image processing utilities
🤝 Contributions
Issues and Pull Requests are welcome!
🙏 Acknowledgements
- ComfyUI Team
- Impact-Pack Project