ComfyUI Extension: Comfyui-Resolution-Master
Precise resolution and aspect ratio control for ComfyUI
Custom Nodes (0)
README
<h1 align="center">ResolutionMaster – Precise resolution and aspect ratio control for ComfyUI</h1>
<p align="center"><i>ResolutionMaster A powerful and feature-rich ComfyUI custom node for precise resolution and aspect ratio control in AI image generation workflows. This node provides an intuitive interface with advanced scaling options, preset management, and model-specific optimizations.</i></p>
<p align="center">
<a href="https://registry.comfy.org/publishers/azornes/nodes/resolutionmaster" style="display:inline-flex; align-items:center; gap:6px;">
<img alt="ComfyUI" src="https://img.shields.io/badge/ComfyUI-1a1a1a?style=for-the-badge&logo=" />
<img alt="Downloads" src="https://img.shields.io/badge/dynamic/json?color=%230D2A4A&label=&query=downloads&url=https://gist.githubusercontent.com/Azornes/685c440e952c0eadfefc2ca10fc347dd/raw/top_resolutionmaster.json&style=for-the-badge" />
</a>
<a href='https://github.com/Azornes/Comfyui-Resolution-Master'>
<img alt='GitHub Clones' src='https://img.shields.io/badge/dynamic/json?color=2F80ED&label=Clone&query=count&url=https://gist.githubusercontent.com/Azornes/dc1baa944bb2145d066bdf4e3f490cfc/raw/clone.json&logo=github&style=for-the-badge'>
</a>
<a href="https://visitorbadge.io/status?path=https%3A%2F%2Fgithub.com%2FAzornes%2FComfyui-Resolution-Master">
<img src="https://api.visitorbadge.io/api/combined?path=https%3A%2F%2Fgithub.com%2FAzornes%2FComfyui-Resolution-Master&countColor=%2337d67a&style=for-the-badge&labelStyle=none" />
</a>
<img alt="Python 3.10+" src="https://img.shields.io/badge/-Python_3.10+-4B8BBE?logo=python&logoColor=FFFFFF&style=for-the-badge&logoWidth=20">
<img alt="JavaScript" src="https://img.shields.io/badge/-JavaScript-000000?logo=javascript&logoColor=F7DF1E&style=for-the-badge&logoWidth=20">
</p>
Features
🎯 Core Functionality
- Interactive 2D Canvas Control: Visually select resolution with real-time preview
- Smart Rescaling: Automatic calculation of rescale factors for upscaling workflows
- Snap to Grid: Align dimensions to customizable grid increments (16px to 256px)
- Real-time Info Display: Shows current resolution, megapixels, p-value and aspect ratio
- Visual Output Values: Color-coded values at output slots (blue/pink/green)
📐 Advanced Scaling Options
- Manual Scale: Direct multiplier control (ex. 2.0x)
- Resolution Targeting: Scale to standard resolutions (ex. 480p, 720p, 1080p, 2160p)
- Megapixel Targeting: Scale to specific megapixel counts (ex. 5 MP)
- Live Preview: See resulting dimensions before applying changes
🎨 Preset Categories
Extensive preset library organized by use case:
- Standard: Common aspect ratios (1:1, 4:3, 16:9, 21:9, etc.)
- SDXL: Optimized resolutions for Stable Diffusion XL
- Flux: Flux model optimized presets with smart constraints
- WAN: Video model presets with resolution recommendations
- Social Media: Instagram, Twitter, Facebook, YouTube optimized sizes
- Print: Standard print formats (A4, Letter, photo sizes)
- Cinema: Professional film aspect ratios (2.39:1, 1.85:1, etc.)
🤖 Model-Specific Optimizations
SDXL Mode
- Enforces officially supported resolutions
- Fixed dimensions for optimal generation quality
Flux Mode
- 32px increment enforcement
- Resolution range: 320px to 2560px
- Maximum 4.0 megapixels constraint
- Sweet spot recommendation: 1920×1080
WAN Mode
- Flexible 320p to 820p range
- 16px increments for video encoding compatibility
- Automatic model recommendation (480p vs 720p)
- Maintains proper aspect ratios for video generation
🚀 Installation
Install via ComfyUI-Manager
- Search
Comfyui-LayerForge
in ComfyUI-Manager and clickInstall
button.
Manual Install
- Install ComfyUi.
- Clone this repo into
custom_modules
:cd ComfyUI/custom_nodes/ git clone https://github.com/Azornes/Comfyui-Resolution-Master.git
- Start up ComfyUI.
- Restart ComfyUI or reload custom nodes
Usage
Basic Operation
- Add the "Resolution Master" node to your workflow
- Connect the outputs to your image generation nodes:
width
: Current width valueheight
: Current height valuerescale_factor
: Calculated scale factor for upscaling
Working with Presets
- Select a Category: Choose from the dropdown (e.g., "SDXL", "Social Media")
- Choose a Preset: Select specific aspect ratio or resolution
- Enable Custom Calc (optional): Checkbox appears next to preset dropdown
- Activates model-specific constraints
- Automatically adjusts dimensions to model requirements
- Apply: Dimensions are automatically updated
Scaling Workflow
The node provides three scaling methods that work together:
- Set Base Resolution: Use presets or manual input
- Choose Scaling Method:
- Manual: Direct multiplier
- Resolution: Target specific output resolution
- Megapixels: Target specific pixel count
- Apply Scale: Updates dimensions while maintaining aspect ratio
- Use Rescale Factor: Connect to upscaling nodes in your workflow
Snap Functionality
- Snap Button: Rounds dimensions to nearest grid value
- Adjustable Grid: 16px to 256px increments (adjustable via slider)
- Smart Snapping: Respects model constraints when Custom Calc is enabled
- Shift Key Override: Hold Shift while dragging on canvas to temporarily toggle snap on/off
Auto-Detect & Auto-Fit
- Auto-Detect Toggle: Automatically detects dimensions from connected images
- Monitors input connection every second
- Updates dimensions when new image is detected
- Shows detected resolution in green text
- Auto-Fit Button: Intelligently matches detected dimensions to closest preset
- Analyzes both aspect ratio and total pixels
- Checks both normal and flipped orientations
- Applies category-specific scaling when Custom Calc is enabled
- Auto Checkbox: Enable automatic fitting when dimensions change
- Located next to Auto-Fit button
- Only active when category is selected and image detected
Output Values
- width (INT): Selected width in pixels (displayed in blue #89F)
- height (INT): Selected height in pixels (displayed in pink #F89)
- rescale_factor (FLOAT): Calculated scaling factor for achieving target resolution (displayed in green #9F8)
Values are shown directly at output slots for quick reference.
Rescale Factor Modes
The rescale factor adapts based on your selection (choose via radio buttons):
- Manual Mode: Uses the manual scale slider value (adjustable 0.1x to 4.0x)
- Resolution Mode: Calculates factor to reach target resolution (p-value based)
- Megapixels Mode: Calculates factor to reach target pixel count (0.5 to 6.0 MP)
Each scaling row shows:
- Control button for immediate application (⬆, 📺, 📷)
- Adjustment method (slider/dropdown)
- Calculated scale factor
- Preview of resulting dimensions
- Radio button to set as active rescale mode
Examples
Example 1: SDXL Portrait Generation
- Select "SDXL" category
- Choose "3:4 Portrait (768×1024)"
- Enable "Custom Calc" for SDXL optimization
- Connect to your SDXL workflow
Example 2: Social Media Content
- Select "Social Media" category
- Choose "Instagram Square (1080×1080)"
- Use resolution scaling to target 2160p for high quality
- Apply rescale factor in upscaling node
Example 3: Flux Model Generation
- Select "Flux" category
- Enable "Custom Calc" for automatic constraints
- Choose any preset - dimensions auto-adjust to Flux requirements
- Node enforces 32px increments and 4MP limit
Tips & Best Practices
- Start with Presets: Use category presets as starting points, then fine-tune
- Enable Custom Calc: For SDXL, Flux, and WAN models to ensure compatibility
- Use Snap for Clean Values: Helps avoid odd dimensions that may cause issues
- Monitor Info Messages: Pay attention to mode-specific recommendations
- Leverage Rescale Factor: Connect to upscaling nodes for resolution-independent workflows
Internal Properties
- Min/Max ranges for X and Y axes
- Step values for grid snapping
- Decimal precision settings
- Visual options (dots, frame, snap)
Contributing
Contributions are welcome! Please feel free to submit issues and pull requests.
Support
For issues, questions, or suggestions, please open an issue on GitHub or contact through the ComfyUI community forums.