返回顶部
n

nanobanana2

Generate/edit images with nanobanana2 (Gemini 3.1 Flash Image preview). Use for image create/modify requests incl. edits. Supports text-to-image + image-to-image; 512/1K/2K/4K; aspect ratios; use --input-image.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 2.0.0
安全检测
已通过
150
下载量
0
收藏
概述
安装方式
版本历史

nanobanana2

# nanobanana2 Image Generation & Editing Generate new images or edit existing ones using Google's [nanobanana2 API](https://ai.google.dev/gemini-api/docs/image-generation?hl=zh-cn) (**Gemini 3.1 Flash Image** preview, model id `gemini-3.1-flash-image-preview`). ## Usage Run the script using absolute path (do NOT cd to skill directory first): **Generate new image:** ```bash uv run "$HOME/.openclaw/skills/skills/nanobanana2/scripts/generate_image.py" --prompt "your image description" --filename "output-name.png" [--resolution 512|1K|2K|4K] [--aspect-ratio RATIO] [--api-key KEY] ``` **Edit existing image:** ```bash uv run "$HOME/.openclaw/skills/nanobanana2/scripts/generate_image.py" --prompt "editing instructions" --filename "output-name.png" --input-image "path/to/input.png" [--resolution 512|1K|2K|4K] [--aspect-ratio RATIO] [--api-key KEY] ``` **Important:** Always run from the user's current working directory so images are saved where the user is working, not in the skill directory. ## Default Workflow (draft → iterate → final) Goal: fast iteration without burning time on 4K until the prompt is correct. - Draft (1K): quick feedback loop - `uv run "$HOME/.openclaw/skills/nanobanana2/scripts/generate_image.py" --prompt "<draft prompt>" --filename "yyyy-mm-dd-hh-mm-ss-draft.png" --resolution 1K` - Iterate: adjust prompt in small diffs; keep filename new per run - If editing: keep the same `--input-image` for every iteration until you’re happy. - Final (4K): only when prompt is locked - `uv run "$HOME/.openclaw/skills/nanobanana2/scripts/generate_image.py" --prompt "<final prompt>" --filename "yyyy-mm-dd-hh-mm-ss-final.png" --resolution 4K` ## Resolution (`image_size`) nanobanana2 accepts these `image_size` values (see [docs](https://ai.google.dev/gemini-api/docs/image-generation?hl=zh-cn)): **`512`**, **`1K`**, **`2K`**, **`4K`**. Use uppercase **`K`** for 1K/2K/4K; **`512`** has no `K` suffix (smaller output, Flash-only). - **512** — lowest tier (~512px shortest side per aspect table); good for thumbnails / fastest drafts - **1K** (default) — ~1024px class - **2K** — ~2048px class - **4K** — ~4096px class Map user requests: - No mention of resolution → `1K` - "tiny", "thumbnail", "512", "low pixel" → `512` - "low resolution", "1080", "1080p", "1K" → `1K` - "2K", "2048", "normal", "medium resolution" → `2K` - "high resolution", "high-res", "hi-res", "4K", "ultra" → `4K` ## Aspect ratio (`aspect_ratio`) Optional. If omitted, the API defaults apply (e.g. **1:1** for pure text-to-image, or match input image when editing — per API behavior). Supported values for **Gemini 3.1 Flash Image**: `1:1`, `1:4`, `1:8`, `2:3`, `3:2`, `3:4`, `4:1`, `4:3`, `4:5`, `5:4`, `8:1`, `9:16`, `16:9`, `21:9`. Pass explicitly when the user asks for wallpaper, story, reel, banner, etc., e.g. `--aspect-ratio 9:16` or `--aspect-ratio 16:9`. ## API Key The script checks for API key in this order: 1. `--api-key` argument (use if user provided key in chat) 2. `GEMINI_API_KEY` environment variable If neither is available, the script exits with an error message. ## Preflight + Common Failures (fast fixes) - Preflight: - `command -v uv` (must exist) - `test -n \"$GEMINI_API_KEY\"` (or pass `--api-key`) - If editing: `test -f \"path/to/input.png\"` - Common failures: - `Error: No API key provided.` → set `GEMINI_API_KEY` or pass `--api-key` - `Error loading input image:` → wrong path / unreadable file; verify `--input-image` points to a real image - “quota/permission/403” style API errors → wrong key, no access, or quota exceeded; try a different key/account ## Filename Generation Generate filenames with the pattern: `yyyy-mm-dd-hh-mm-ss-name.png` **Format:** `{timestamp}-{descriptive-name}.png` - Timestamp: Current date/time in format `yyyy-mm-dd-hh-mm-ss` (24-hour format) - Name: Descriptive lowercase text with hyphens - Keep the descriptive part concise (1-5 words typically) - Use context from user's prompt or conversation - If unclear, use random identifier (e.g., `x9k2`, `a7b3`) Examples: - Prompt "A serene Japanese garden" → `2025-11-23-14-23-05-japanese-garden.png` - Prompt "sunset over mountains" → `2025-11-23-15-30-12-sunset-mountains.png` - Prompt "create an image of a robot" → `2025-11-23-16-45-33-robot.png` - Unclear context → `2025-11-23-17-12-48-x9k2.png` ## Image Editing When the user wants to modify an existing image: 1. Check if they provide an image path or reference an image in the current directory 2. Use `--input-image` parameter with the path to the image 3. The prompt should contain editing instructions (e.g., "make the sky more dramatic", "remove the person", "change to cartoon style") 4. Common editing tasks: add/remove elements, change style, adjust colors, blur background, etc. ## Prompt Handling **For generation:** Pass user's image description as-is to `--prompt`. Only rework if clearly insufficient. **For editing:** Pass editing instructions in `--prompt` (e.g., "add a rainbow in the sky", "make it look like a watercolor painting") Preserve user's creative intent in both cases. ## Prompt Templates (high hit-rate) Use templates when the user is vague or when edits must be precise. - Generation template: - “Create an image of: <subject>. Style: <style>. Composition: <camera/shot>. Lighting: <lighting>. Background: <background>. Color palette: <palette>. Avoid: <list>.” - Editing template (preserve everything else): - “Change ONLY: <single change>. Keep identical: subject, composition/crop, pose, lighting, color palette, background, text, and overall style. Do not add new objects. If text exists, keep it unchanged.” ## Output - Saves PNG to current directory (or specified path if filename includes directory) - Script outputs the full path to the generated image - **Do not read the image back** - just inform the user of the saved path - Generated images include **SynthID** watermark (API policy). ## Examples **Generate new image:** ```bash uv run "$HOME/.openclaw/skills/nanobanana2/scripts/generate_image.py" --prompt "A serene Japanese garden with cherry blossoms" --filename "2025-11-23-14-23-05-japanese-garden.png" --resolution 4K --aspect-ratio 16:9 ``` **Edit existing image:** ```bash uv run "$HOME/.openclaw/skills/nanobanana2/scripts/generate_image.py" --prompt "make the sky more dramatic with storm clouds" --filename "2025-11-23-14-25-30-dramatic-sky.png" --input-image "original-photo.jpg" --resolution 2K ```

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 nanobanana2-1776021042 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 nanobanana2-1776021042 技能

通过命令行安装

skillhub install nanobanana2-1776021042

下载 Zip 包

⬇ 下载 nanobanana2 v2.0.0

文件大小: 5.42 KB | 发布时间: 2026-4-13 11:10

v2.0.0 最新 2026-4-13 11:10
Nano Banana 2 initial release: Local CLI wrapper for Google Gemini 3.1 Flash Image (text-to-image + image editing).

- Generate or edit images using a Python script with Gemini 3.1 Flash Image Preview.
- Supports prompt-based generation and local image editing (with --input-image).
- Handles resolutions 512, 1K, 2K, 4K and various aspect ratios.
- API key can be passed by argument or environment variable; errors are surfaced clearly.
- Script saves generated/edited images with timestamped filenames in the user's working directory.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部