/install gemini-watermark
Gemini Watermark Remover
Remove the visible Gemini AI watermark (star/sparkle logo) from generated images using mathematically accurate reverse alpha blending.
Fully offline — pure Python, no external binary downloads, no network access.
When to Use
- Remove the Gemini watermark from AI-generated images
- Batch process a directory of Gemini-generated images
- Clean images before publishing or sharing
- Automate watermark removal in pipelines
Quick Start
Install Dependencies (one-time)
pip install Pillow numpy
# Recommended: use uv for faster, isolated installs
uv pip install Pillow numpy
Requires: Python ≥ 3.9. No Rust toolchain, no compiled binaries, no downloads.
Basic Usage
# Single image (auto-detect watermark, save as photo_cleaned.jpg)
python3 scripts/remove_watermark.py photo.jpg
# Specify output path
python3 scripts/remove_watermark.py photo.jpg -o clean_photo.jpg
# Batch process directory
python3 scripts/remove_watermark.py ./input_dir -o ./output_dir
# Force removal without detection
python3 scripts/remove_watermark.py photo.jpg -o clean.jpg --force
How It Works
Gemini adds a semi-transparent white star/sparkle logo to generated images using alpha blending:
watermarked = alpha * 255 + (1 - alpha) * original
This tool reverses the equation to recover the original pixels:
original = (watermarked - alpha * 255) / (1 - alpha)
The alpha map (watermark transparency pattern) is generated mathematically as a 4-pointed star (central Gaussian core + 4 elongated cardinal rays) at two sizes:
- 48×48 with 32 px margin — images where either dimension ≤ 1024 px
- 96×96 with 64 px margin — images where both dimensions > 1024 px
For improved accuracy you can supply your own alpha map derived from a background
capture of the Gemini watermark on a white background (--alpha-map).
Detection
Before removal, a three-stage algorithm checks whether a watermark is present:
- Spatial NCC (50% weight) — normalised cross-correlation with the alpha map
- Gradient NCC (30% weight) — edge signature matching via Sobel operators
- Variance Analysis (20% weight) — texture dampening detection
Images without detected watermarks are automatically skipped.
CLI Parameters
| Parameter | Short | Default | Description |
|---|---|---|---|
input |
(required) | Input image file or directory | |
--output |
-o |
{name}_cleaned.{ext} |
Output file or directory |
--force |
-f |
false |
Skip detection, process unconditionally |
--threshold |
-t |
0.35 |
Detection confidence threshold (0.0–1.0) |
--force-small |
false |
Force 48×48 watermark size | |
--force-large |
false |
Force 96×96 watermark size | |
--alpha-map |
(built-in) | Custom grayscale alpha map image | |
--verbose |
-v |
false |
Enable detailed output |
--quiet |
-q |
false |
Suppress all non-error output |
Supported Formats
| Format | Read | Write |
|---|---|---|
| JPEG (.jpg, .jpeg) | Yes | Yes (quality 100) |
| PNG (.png) | Yes | Yes |
| WebP (.webp) | Yes | Yes |
| BMP (.bmp) | Yes | Yes |
Usage Examples
# Verbose output (shows detection confidence, watermark coordinates)
python3 scripts/remove_watermark.py photo.png -o clean.png -v
# Lower detection threshold (more sensitive)
python3 scripts/remove_watermark.py photo.jpg -t 0.15
# Force large watermark size regardless of image dimensions
python3 scripts/remove_watermark.py photo.jpg --force-large -o clean.jpg
# Batch process, quiet mode
python3 scripts/remove_watermark.py ./gemini_images/ -o ./cleaned/ -q
# Supply a custom alpha map for higher accuracy
python3 scripts/remove_watermark.py photo.jpg --alpha-map my_alpha.png
Deriving a Custom Alpha Map
For pixel-perfect removal, capture the Gemini watermark on a pure white background and compute:
alpha(x, y) = max(R, G, B) / 255
Save the result as a grayscale PNG and pass it via --alpha-map.
Output
- Single file — saves to
-opath, or{name}_cleaned.{ext}by default - Directory — saves all processed images to the output directory
- Skipped images — images without detected watermarks are not modified (unless
--force) - Exit code — 0 on success, 1 if any image fails
Troubleshooting
"No watermark detected" on a watermarked image
- Try lowering the threshold:
-t 0.1 - Or bypass detection entirely:
--force - Consider supplying a custom alpha map for your watermark variant
Image looks distorted after removal
- The image may not have a Gemini watermark. Use detection (avoid
--force) - Try
--force-smallor--force-largeto match the correct size - Supply a custom alpha map for better precision
"Image too small" warning
The image dimensions are smaller than the watermark region. This typically means the image does not have a Gemini watermark.
ModuleNotFoundError: Pillow or numpy
pip install Pillow numpy
# or
uv pip install Pillow numpy
Limitations
- Visible watermark only — this tool removes the visible star/sparkle logo watermark
- Cannot remove SynthID — Google's invisible watermark (SynthID) is embedded at the pixel level during generation and cannot be reversed
- Fixed position only — handles watermarks in the standard bottom-right position only
- Built-in alpha map is approximate — use
--alpha-mapwith a captured reference for exact results
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install gemini-watermark - After installation, invoke the skill by name or use
/gemini-watermark - Provide required inputs per the skill's parameter spec and get structured output
What is Gemini Watermark?
Remove visible Gemini AI watermarks from images via reverse alpha blending. Use for cleaning Gemini-generated images, removing the star/sparkle logo watermar... It is an AI Agent Skill for Claude Code / OpenClaw, with 351 downloads so far.
How do I install Gemini Watermark?
Run "/install gemini-watermark" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Gemini Watermark free?
Yes, Gemini Watermark is completely free (open-source). You can download, install and use it at no cost.
Which platforms does Gemini Watermark support?
Gemini Watermark is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Gemini Watermark?
It is built and maintained by h1bomb (@h1bomb); the current version is v2.1.0.