🌀 ComfyUI Wrapper for Hunyuan3D-2.1
ComfyUI integration for Tencent's powerful Hunyuan3D-2.1 model. Supports textured 3D generation with optional high-quality UV mapping.
- GitHub: Tencent-Hunyuan/Hunyuan3D-2.1
- Model Weights (HuggingFace): 👉 Main page
Place the following checkpoints into the corresponding folders under your ComfyUI
directory:
ComfyUI/
├── models/
│ ├── diffusion_models/
│ │ └── hunyuan3d-dit-v2-1.ckpt
│ ├── vae/
│ │ └── hunyuan3d-vae-v2-1.ckpt
Tested on Windows 11 with Python 3.12 and Torch >= 2.6.0 + cu126. Compatible with the latest ComfyUI Portable release.
For a standard Python environment:
python -m pip install -r ComfyUI/custom_nodes/ComfyUI-Hunyuan3DWrapper/requirements.txt
For ComfyUI Portable:
python_embeded\python.exe -m pip install -r ComfyUI\custom_nodes\ComfyUI-Hunyuan3d-2-1\requirements.txt
Two critical C++ extensions need to be installed: the custom rasterizer and the differentiable renderer.
You will find precompiled wheels in hy3dpain\custom_rasterizer\dist
folder
For standard Python:
Example, if you are on Python 3.12:
pip install custom_rasterizer-0.1-cp312-cp312-win_amd64.whl
For ComfyUI Portable:
python_embeded\python.exe -m pip install ComfyUI\custom_nodes\ComfyUI-Hunyuan3d-2-1\hy3dpaint\custom_rasterizer\dist\custom_rasterizer-0.1-cp312-cp312-win_amd64.whl
You will find precompiled wheels in hy3dpaint\DifferentiableRenderer\dist
folder
For standard Python:
Example, if you are on Python 3.12:
pip install mesh_inpaint_processor-0.0.0-cp312-cp312-win_amd64.whl.whl
For ComfyUI Portable:
python_embeded\python.exe -m pip install ComfyUI\custom_nodes\ComfyUI-Hunyuan3d-2-1\hy3dpaint\DifferentiableRenderer\dist\mesh_inpaint_processor-0.0.0-cp312-cp312-win_amd64.whl.whl
# Compile custom rasterizer
cd ComfyUI/custom_nodes/ComfyUI-Hunyuan3d-2-1/hy3dpaint/custom_rasterizer
python setup.py install
# Compile differentiable renderer
cd ../DifferentiableRenderer
python setup.py install
This upgrade improves UV unwrapping stability for complex meshes.
# Step 1: Uninstall existing xatlas
python_embeded\python.exe -m pip uninstall xatlas
# Step 2: Clone updated xatlas-python wrapper
cd ComfyUI_windows_portable
git clone --recursive https://github.com/mworchel/xatlas-python.git
# Step 3: Replace internal xatlas source
cd xatlas-python\extern
del /s /q xatlas
git clone --recursive https://github.com/jpcy/xatlas
# Step 4: Patch source file
# In xatlas-python/extern/xatlas/source/xatlas/xatlas.cpp:
Line 6774: change `#if 0` → `//#if 0`
Line 6778: change `#endif` → `//#endif`
# Step 5: Install patched xatlas wrapper
cd ../../..
python_embeded\python.exe -m pip install .\xatlas-python\
python_embeded\python.exe -m pip uninstall -y xatlas; `
cd ComfyUI_windows_portable; `
if (Test-Path xatlas-python) { Remove-Item xatlas-python -Recurse -Force }; `
git clone --recursive https://github.com/mworchel/xatlas-python.git; `
cd xatlas-python\extern; `
if (Test-Path xatlas) { Remove-Item xatlas -Recurse -Force }; `
git clone --recursive https://github.com/jpcy/xatlas; `
(Get-Content .\xatlas\source\xatlas\xatlas.cpp) -replace '#if 0', '//#if 0' -replace '#endif', '//#endif' | Set-Content .\xatlas\source\xatlas\xatlas.cpp; `
cd ..\..\..; `
python_embeded\python.exe -m pip install .\xatlas-python\
ComfyUI/
├── custom_nodes/
│ └── ComfyUI-Hunyuan3d-2-1/
│ ├── hy3dpaint/
│ │ ├── custom_rasterizer/ # Custom rasterizer module
│ │ │ ├── setup.py
│ │ │ └── dist/ # Precompiled wheels
│ │ ├── DifferentiableRenderer/ # Differentiable renderer
│ │ │ ├── setup.py
│ │ │ └── dist/ # Precompiled wheels
├── models/
│ ├── diffusion_models/
│ │ └── [hunyuan3d-dit-v2-1.ckpt](https://huggingface.co/tencent/Hunyuan3D-2.1/tree/main/hunyuan3d-dit-v2-1)
│ └── vae/
│ └── [hunyuan3d-vae-v2-1.ckpt](https://huggingface.co/tencent/Hunyuan3D-2.1/tree/main/hunyuan3d-vae-v2-1)
├── xatlas-python/ # Patched UV unwrapper (optional)
│ └── extern/
│ └── xatlas/
- kijai — Original wrapper developer for Hunyuan3D v2.0
- TrueMike, Agee, Palindar, and the vibrant Discord community
- Tencent team for the incredible Hunyuan3D-2.1 model