← 返回 Skills 市场
zealman2025

nanobanana2

作者 zealman2025 · GitHub ↗ · v2.0.0 · MIT-0
cross-platform ✓ 安全检测通过
213
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install 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-i...
使用说明 (SKILL.md)

nanobanana2 Image Generation & Editing

Generate new images or edit existing ones using Google's nanobanana2 API (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:

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:

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 "\x3Cdraft 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 "\x3Cfinal prompt>" --filename "yyyy-mm-dd-hh-mm-ss-final.png" --resolution 4K

Resolution (image_size)

nanobanana2 accepts these image_size values (see docs): 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: \x3Csubject>. Style: \x3Cstyle>. Composition: \x3Ccamera/shot>. Lighting: \x3Clighting>. Background: \x3Cbackground>. Color palette: \x3Cpalette>. Avoid: \x3Clist>.”
  • Editing template (preserve everything else):

    • “Change ONLY: \x3Csingle 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:

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:

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
安全使用建议
This skill appears to do what it claims: call Google's Gemini image API to generate or edit PNGs. Before installing/using it: (1) Confirm you trust the skill source — it will send prompts and any input images to Google's API (privacy concern for sensitive images). (2) Provide a Gemini API key via --api-key or GEMINI_API_KEY; do not paste secrets into public chats. (3) Ensure your environment has Python >=3.10, the 'uv' runner (used in examples), and install the python packages google-genai and pillow (pip). (4) Note the skill includes the script but no automated install — dependency installation is manual. (5) If you need stricter controls, isolate runs in a sandbox/VM and avoid sending private images or PII to the API.
功能分析
Type: OpenClaw Skill Name: nanobanana2 Version: 2.0.0 The skill bundle provides a legitimate interface for generating and editing images using Google's Gemini 3.1 Flash Image API. The Python script (scripts/generate_image.py) uses standard libraries (google-genai, pillow) to handle API requests and image processing, with no evidence of data exfiltration, unauthorized execution, or malicious prompt injection.
能力评估
Purpose & Capability
Name/description match the included Python script which calls Google's Gemini image model. Minor inconsistency: the skill metadata lists no required binaries or env vars, but the SKILL.md and script expect the 'uv' runner, Python >=3.10, and the GEMINI_API_KEY (or --api-key). The dependencies are declared as in-file comments (google-genai, pillow) but not as an install spec.
Instruction Scope
SKILL.md and the script stay within the stated scope: building prompts, optionally loading a local input image, and sending prompt+image to the Gemini image API; they only reference the current working directory and the input image path. There are no instructions to read unrelated files, credentials, or system state.
Install Mechanism
There is no install spec (instruction-only skill) and no network/downloads in code. However, the script comments list Python dependencies (google-genai, pillow) and a Python version requirement; the skill does not provide an automated install step for these, which is a minor omission users must handle manually.
Credentials
The only credential the script expects is a Gemini API key (passed via --api-key or GEMINI_API_KEY), which is proportional for calling the Gemini image API. The script does not request unrelated secrets or environment variables.
Persistence & Privilege
always is false and the skill does not request special platform privileges or attempt to modify other skills or system configs. It saves generated images to the user's working directory (expected behavior).
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install nanobanana2
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /nanobanana2 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v2.0.0
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.
元数据
Slug nanobanana2
版本 2.0.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

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-i... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 213 次。

如何安装 nanobanana2?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install nanobanana2」即可一键安装,无需额外配置。

nanobanana2 是免费的吗?

是的,nanobanana2 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

nanobanana2 支持哪些平台?

nanobanana2 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 nanobanana2?

由 zealman2025(@zealman2025)开发并维护,当前版本 v2.0.0。

💬 留言讨论