ComfyUI Extension: ComfyUI Web Viewer

Authored by VrchStudio

Created

Updated

83 stars

The ComfyUI Web Viewer by a/vrch.ai is a custom node collection offering a real-time AI-generated interactive art framework. This utility integrates realtime streaming into ComfyUI workflows, supporting keyboard control nodes, OSC control nodes, sound input nodes, and more. Accessible from any device with a web browser, it enables real time interaction with AI-generated content, making it ideal for interactive visual projects and enhancing ComfyUI workflows with efficient content management and display.

Custom Nodes (0)

    README

    ComfyUI Web Viewer

    The ComfyUI Web Viewer by vrch.ai is a custom node collection offering a real-time AI-generated interactive art framework. This utility integrates realtime streaming into ComfyUI workflows, supporting keyboard control nodes, OSC control nodes, sound input nodes, and more. Accessible from any device with a web browser, it enables real time interaction with AI-generated content, making it ideal for interactive visual projects and enhancing ComfyUI workflows with efficient content management and display.

    Features:

    • Real-time interaction and AI generation
    • Keyboard control nodes, OSC control nodes, and sound input nodes
    • Web accessibility from any device
    <video src="https://github.com/user-attachments/assets/cdac0293-64ce-4b74-95a8-d4dcce2300d2" controls="controls" style="max-width: 100%;"> </video>

    Changelog

    see CHANGELOG

    Installation

    Method 1: Auto Installation (Recommended)

    Simply search for ComfyUI Web Viewer in ComfyUI Manager and install it directly.

    Method 2: Manual Installation

    1. Clone this repo into the custom_nodes directory of ComfyUI
    2. Install dependencies:
      pip install -r requirements.txt
      
      or if you use the windows portable install, run this in ComfyUI_windows_portable folder:
      python_embeded\python.exe -m pip install -r ComfyUI\custom_nodes\comfyui-web-viewer\requirements.txt
      
    3. Restart ComfyUI

    How to Use

    Web Viewer Nodes

    OSC Control Nodes

    Key Control Nodes

    Audio Nodes

    Image Nodes

    Other Example Workflows

    Troubleshootings

    Image Not Displayed in Popped-Up Image Viewer Window

    For Chrome, you may need to add the ComfyUI server's IP address manually in chrome://flags/#unsafely-treat-insecure-origin-as-secure to enable access to the content. For other browsers, an http-to-http setup should allow for seamless access without additional configuration.


    How can I resolve the CORS policy error when trying to display images?

    If you’re encountering a CORS policy error with a message like this:

    "origin 'https://vrch.ai' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource"

    you can resolve this by launching the ComfyUI service with the --enable-cors-header flag. For example:

    python main.py --enable-cors-header
    

    For additional details, refer to this discussion on GitHub.


    Why can’t the ComfyUI service run at HTTPS/TLS/SSL on port 8189?

    ComfyUI Web Viewer provides a build-in, self-signed certificate (intended for development only, not production use). To launch the ComfyUI service with HTTPS enabled on port 8189, use the following command:

    # Start ComfyUI with HTTPS using the built-in certificate and key
    python main.py --tls-keyfile ./custom_nodes/comfyui-web-viewer/https/key.pem --tls-certfile ./custom_nodes/comfyui-web-viewer/https/cert.pem --port 8189 --listen
    

    For more details, refer to the ComfyUI official instructions.

    Version Update

    This project uses bump2version for version management. To update the version:

    1. Ensure you have bump2version installed:
      pip install bump2version
      
    2. To update the version, run:
      python update_version.py [major|minor|patch]
      
      Replace [major|minor|patch] with the part of the version you want to increment.
    3. This will automatically:
      • Update the version number in __init__.py
      • Update the CHANGELOG.md file
      • Create a new git commit and tag (if you're using git)
    4. After running the script, review and update the CHANGELOG.md file with details about the new version's changes.
      • Note: make sure you've put changes in Unreleased section manually

    Contributing

    Created and maintained by the vrch.io team.

    Contributions are welcome! Please feel free to submit a Pull Request.

    Contact Us

    For any inquiries, you can contact us at [email protected].

    License

    MIT License