The Fast and Simple Face Swap Extension Node for ComfyUI, based on ReActor SD-WebUI Face Swap Extension
This Node goes without NSFW filter (uncensored, use it on your own responsibility)
Support This Project |
ReActor Node is an extension for ComfyUI that allows a very easy and accurate face-replacement (face swap) in images |
Donate to This Project |
SD WebUI: AUTOMATIC1111 or SD.Next
- Close (stop) your SD-WebUI/Comfy Server if it's running
- (For Windows Users):
- Install Visual Studio 2022 (Community version - you need this step to build Insightface)
- OR only VS C++ Build Tools and select "Desktop Development with C++" under "Workloads -> Desktop & Mobile"
- OR if you don't want to install VS or VS C++ BT - follow this steps (sec. I)
- Go to the
extensions\sd-webui-comfyui\ComfyUI\custom_nodes
- Open Console or Terminal and run
git clone https://github.com/Gourieff/comfyui-reactor-node
- Go to the SD WebUI root folder, open Console or Terminal and run (Windows users)
.\venv\Scripts\activate
or (Linux/MacOS)venv/bin/activate
python -m pip install -U pip
cd extensions\sd-webui-comfyui\ComfyUI\custom_nodes\comfyui-reactor-node
python install.py
- Please, wait until the installation process will be finished
- (From the version 0.3.0) Download facerestorers models from the links below and put them into the
extensions\sd-webui-comfyui\ComfyUI\custom_nodes\comfyui-reactor-node\models\facerestore_models
directory: - Run SD WebUI and check console for the message that ReActor Node is running:
- Go to the ComfyUI tab and find there ReActor Node inside the menu
image/postprocessing
or by using a search:
Standalone (Portable) ComfyUI for Windows
- Do the following:
- Install Visual Studio 2022 (Community version - you need this step to build Insightface)
- OR only VS C++ Build Tools and select "Desktop Development with C++" under "Workloads -> Desktop & Mobile"
- OR if you don't want to install VS or VS C++ BT - follow this steps (sec. I)
- Go to the
ComfyUI\custom_nodes
directory - Open Console and run
git clone https://github.com/Gourieff/comfyui-reactor-node
- Run
install.bat
- (From the version 0.3.0) Download facerestorers models from the links below and put them into the
ComfyUI\models\facerestore_models
directory: - Run ComfyUI and find there ReActor Node inside the menu
image/postprocessing
or by using a search
Just connect all required nodes and run the query.
From the version 0.3.0 ReActor Node has a buil-in face restoration.
Just download the models you want (see Installation instruction) and select one of them to restore the resulting face(s) during the faceswap. It will enhance face details and make your result more accurate.
ReActor detects faces in images in the following order:
left->right, top->bottom
And if you need to specify faces, you can set indexes for source and input images.
Index of the first detected face is 0.
You can set indexes in the order you need.
E.g.: 0,1,2 (for Source); 1,0,2 (for Input).
This means: the second Input face (index = 1) will be swapped by the first Source face (index = 0) and so on.
You can specify the gender to detect in images.
ReActor will swap a face only if it meets the given condition.
I. (For Windows users) If you still cannot build Insightface for some reasons or just don't want to install Visual Studio or VS C++ Build Tools - do the following:
- (ComfyUI Portable) From the root folder check the version of Python:
run CMD and typepython_embeded\python.exe -V
- Download prebuilt Insightface package for Python 3.10 or for Python 3.11 (if in the previous step you see 3.11) and put into the stable-diffusion-webui (A1111 or SD.Next) root folder (where you have "webui-user.bat" file) or into ComfyUI root folder if you use ComfyUI Portable
- From the root folder run:
- (SD WebUI) CMD and
.\venv\Scripts\activate
- (ComfyUI Portable) run CMD
- (SD WebUI) CMD and
- Then update your PIP:
- (SD WebUI)
python -m pip install -U pip
- (ComfyUI Portable)
python_embeded\python.exe -m pip install -U pip
- (SD WebUI)
- Then install Insightface:
- (SD WebUI)
pip install insightface-0.7.3-cp310-cp310-win_amd64.whl
- (ComfyUI Portable)
python_embeded\python.exe -m pip install insightface-0.7.3-cp310-cp310-win_amd64.whl
- (SD WebUI)
- Enjoy!
This error may occur if there's smth wrong with the model file inswapper_128.onnx
Try to download it manually from here
and put it to the ComfyUI\models\insightface
replacing existing one
This means that input points have been changed with the latest update
Remove the current ReActor Node from your workflow and add it again
- Close ComfyUI if it runs
- Go to the ComfyUI root folder, open CMD there and run:
python_embeded\python.exe -m pip uninstall -y opencv-python opencv-contrib-python opencv-python-headless
python_embeded\python.exe -m pip install opencv-python==4.7.0.72
- That's it!
Just put .bat or .sh script from this Repo to the ComfyUI\custom_nodes
directory and run it when you need to check for updates
This software is meant to be a productive contribution to the rapidly growing AI-generated media industry. It will help artists with tasks such as animating a custom character or using the character as a model for clothing etc.
The developers of this software are aware of its possible unethical applicaitons and are committed to take preventative measures against them. We will continue to develop this project in the positive direction while adhering to law and ethics.
Users of this software are expected to use this software responsibly while abiding the local law. If face of a real person is being used, users are suggested to get consent from the concerned person and clearly mention that it is a deepfake when posting content online. Developers and Contributors of this software are not responsible for actions of end-users.
By using this extension you are agree not to create any content that:
- violates any laws;
- causes any harm to a person or persons;
- propogates (spreads) any information (both public or personal) or images (both public or personal) which could be meant for harm;
- spreads misinformation;
- targets vulnerable groups of people.
If you encounter any errors when you use ReActor Node - don't rush to open an issue, first try to remove current ReActor node in your workflow and add it again
ReActor Node gets updates from time to time, new functions appears and old node can work with errors or not work at all