let5sne 0363f84028 🐳 更新 Docker 配置到最新项目状态
- 更新 build_docker.sh 到新仓库地址
  - 仓库: Sanster/lama-cleaner → let5sne/IOPaint
  - 镜像标签: cwq1913/lama-cleaner → let5sne/iopaint
  - 项目名称: lama-cleaner → IOPaint

- 重构 Dockerfile (CPU & GPU)
  - 从源码构建替代 PyPI 安装
  - 更新基础镜像到最新版本
  - CPU: python:3.11-slim-bookworm
  - GPU: nvidia/cuda:12.1.0-runtime-ubuntu22.04
  - 使用最新的 PyTorch 和依赖版本
  - 添加自动启动命令

- 更新 scripts/pack.sh
  - 构建目录: lama-cleaner → iopaint
  - 修复拼写错误 (Ensuer → Ensure)

- 新增 docker/README.md
  - 完整的 Docker 部署指南
  - 包含 CPU 和 GPU 两种模式
  - Docker Compose 配置示例
  - 故障排查和安全建议

主要改进:
-  与当前项目完全同步
- 📦 支持从源码构建
- 🔧 更灵活的运行配置
- 📝 完整的使用文档
- 🚀 更新的依赖版本

🤖 Generated with Claude Code
2025-11-28 17:34:53 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00
2025-11-28 17:10:24 +00:00

IOPaint

A free and open-source inpainting & outpainting tool powered by SOTA AI model.

total download version python version HuggingFace Spaces Open in Colab

Erase(LaMa) Replace Object(PowerPaint)
Draw Text(AnyText) Out-painting(PowerPaint)

Features

Quick Start

Start webui

IOPaint provides a convenient webui for using the latest AI models to edit your images. You can install and start IOPaint easily by running following command:

# In order to use GPU, install cuda version of pytorch first.
# pip3 install torch==2.1.2 torchvision==0.16.2 --index-url https://download.pytorch.org/whl/cu118
# AMD GPU users, please utilize the following command, only works on linux, as pytorch is not yet supported on Windows with ROCm.
# pip3 install torch==2.1.2 torchvision==0.16.2 --index-url https://download.pytorch.org/whl/rocm5.6

pip3 install iopaint
iopaint start --model=lama --device=cpu --port=8080

That's it, you can start using IOPaint by visiting http://localhost:8080 in your web browser.

All models will be downloaded automatically at startup. If you want to change the download directory, you can add --model-dir. More documentation can be found here

You can see other supported models at here and how to use local sd ckpt/safetensors file at here.

Plugins

You can specify which plugins to use when starting the service, and you can view the commands to enable plugins by using iopaint start --help.

More demonstrations of the Plugin can be seen here

iopaint start --enable-interactive-seg --interactive-seg-device=cuda

Batch processing

You can also use IOPaint in the command line to batch process images:

iopaint run --model=lama --device=cpu \
--image=/path/to/image_folder \
--mask=/path/to/mask_folder \
--output=output_dir

--image is the folder containing input images, --mask is the folder containing corresponding mask images. When --mask is a path to a mask file, all images will be processed using this mask.

You can see more information about the available models and plugins supported by IOPaint below.

Model Recommendations

Choosing the right model depends on your use case and hardware. Here's our recommended model strategy:

🚀 Quick Start - For Daily Use

LaMa (Recommended for beginners)

iopaint start --model lama --device cuda --port 8080
  • Fastest - Near real-time processing
  • 💾 Low VRAM - Uses ~1GB GPU memory
  • 🎯 Best for: Removing watermarks, people, objects from images
  • Most stable and reliable

🎨 Creative Editing - With Prompt Control

Stable Diffusion Inpainting

iopaint start --model runwayml/stable-diffusion-inpainting --device cuda --port 8080
  • 🎨 Smart content generation - Not just removal, but intelligent filling
  • 📝 Text prompts - Control what gets generated
  • 🖼️ Creative flexibility - Replace objects with AI-generated content
  • Official model - Well-maintained and stable

💎 Professional - High Quality Results

SDXL Inpainting (For high-resolution work)

iopaint start --model diffusers/stable-diffusion-xl-1.0-inpainting-0.1 --device cuda --low-mem --port 8080
  • 🖼️ High resolution - Supports up to 1024x1024
  • 🎨 Better details - Superior quality output
  • 💎 Professional use - Best for photography and commercial work
  • ⚠️ Requires more VRAM - Use --low-mem flag for optimization

📊 Model Comparison

Model Speed Quality VRAM Use Case Recommended
LaMa ~1GB Quick erase
SD Inpainting ~4GB Creative edit
SDXL Inpainting ~8GB Professional
PowerPaint V2 ~5GB Multi-task

🔧 GPU Optimization Tips

For NVIDIA GPUs with limited VRAM:

# Enable low memory mode
iopaint start --model <model_name> --device cuda --low-mem --port 8080

# Enable CPU offload for very large models
iopaint start --model <model_name> --device cuda --cpu-offload --port 8080

For CPU-only systems:

# LaMa works well on CPU
iopaint start --model lama --device cpu --port 8080

📦 Installation Note

Updated Dependencies (2025-11-28)

This project now uses the latest stable versions of all dependencies. Install with:

# Recommended: Use mirror for faster installation (China users)
pip3 install -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com

# Or use official PyPI
pip3 install -r requirements.txt

See UPGRADE_NOTES.md for detailed information about package updates.

Development

Install nodejs, then install the frontend dependencies.

git clone https://github.com/Sanster/IOPaint.git
cd IOPaint/web_app
npm install
npm run build
cp -r dist/ ../iopaint/web_app

Create a .env.local file in web_app and fill in the backend IP and port.

VITE_BACKEND=http://127.0.0.1:8080

Start front-end development environment

npm run dev

Install back-end requirements and start backend service

pip install -r requirements.txt
python3 main.py start --model lama --port 8080

Then you can visit http://localhost:5173/ for development. The frontend code will automatically update after being modified, but the backend needs to restart the service after modifying the python code.

Description
Image inpainting tool powered by SOTA AI Model. Remove any unwanted object, defect, people from your pictures or erase and replace(powered by stable diffusion) any thing on your pictures.
Readme Apache-2.0 24 MiB
Languages
Python 87.7%
TypeScript 11.9%