Skip to main content

AI绘图插件 for NoneBot2,支持多种绘图API

Project description

AgnesDigitalLogo

NoneBotPluginText

nonebot_plugin_easy_aidraw 0.1.1

✨NoneBot & AI 绘图 插件 ✨

仓库   ·   反馈

python NoneBot pypi GitHub issues QQ Chat Group

介绍

本插件用于快速使用openai格式图像模型,兼容各种中转站或者其他openai兼容格式,只需要填写url/key/model三个参数即可快速使用

示例

快速开始

安装

nb plugin install nonebot-plugin-easy-aidraw

最小配置(仅 3 个参数即可使用)

只需要 draw_api_url / draw_api_key / draw_model,其余全部走默认值:

# .env 文件
draw_api_url = "https://api.openai.com/v1"   # 自定义中转站 base URL,必须以 /v1 类似结尾
draw_api_key = "your-api-key"                     # API 密钥
draw_model = "gpt-image-2"              # 模型名称
  • draw_api_url 留空时按 draw_backend 走官方默认(openai / gemini / sd)都不填写默认为openai
  • 填写时必须以 /v1 结尾,例如 https://api.openai.com/v1(插件会自动拼接 /images/generations)。若填写了 /v1/images/generations 也会被自动截断为 base URL。
  • 文生图与图生图共用同一个 base URL,结尾分别追加 /images/generations/images/edits

使用

  • /绘图 一只可爱的小猫
  • /绘图 --model gpt-image-2 --size 1024x1792 风景
  • /绘图 --n 2 同一提示词生成两张
  • 回复图片 + /绘图 画成动漫风(以图片为垫图,走 /images/edits
  • 回复消息 + /绘图 ...(从被回复消息中提取图片)

完整参数配置

在最小配置基础上,下列参数全部可选,按需启用。

后端选择

draw_backend = "openai"   # openai / gemini / sd

各后端默认端点:

后端 文生图 图生图
openai https://api.openai.com/v1/images/generations https://api.openai.com/v1/images/edits
gemini https://generativelanguage.googleapis.com/v1beta/images/generations https://generativelanguage.googleapis.com/v1beta/images/edits
sd http://localhost:7860/sdapi/v1/txt2img http://localhost:7860/sdapi/v1/img2img

端点覆盖

draw_api_url = "https://api.openai.com/v1"   # 文生图 base URL(必填其一或 draw_backend)
draw_api_url_edits = ""                          # 图生图 base URL(留空则与 draw_api_url 共享)

图生图采用 OpenAI 官方 multipart/form-data 规范(image 文件 + prompt + 其他表单字段),兼容中转站。

请求参数

draw_default_size = "1024x1024"   # 默认图片尺寸
draw_quality = "standard"         # openai 图片质量
draw_n = 1                        # openai 生成数量
draw_timeout = 120                # 请求超时(秒)
draw_proxy = ""                   # HTTP 代理,如 http://127.0.0.1:10808

访问控制

draw_user_cooldown = 60           # 单用户冷却时间(秒),0 禁用,超级用户无视
draw_concurrent = false           # 是否允许并发请求;false(默认)=前一个请求完成才继续下一个
draw_nsfw_enabled = false         # 启用 NSFW 关键词过滤(仅群聊)
draw_nsfw_keywords = []           # 敏感词列表
draw_whitelist_mode = false       # 白名单模式(true 启用白名单,false 走黑名单)
draw_whitelist = []               # 白名单用户 ID(QQ 号),对群/私聊统一生效
draw_blacklist = []               # 黑名单用户 ID

图片缓存

draw_cache_enabled = false        # 是否将 b64 图片落盘缓存(默认关闭)
draw_cache_dir = "data/nonebot_plugin_easy_aidraw"  # 缓存目录
draw_cache_ttl = 86400            # 缓存过期时间(秒)

超级用户指令

/清理绘图缓存

清理超过 draw_cache_ttl 秒的缓存图片(按 mtime 判断)。仅在 draw_cache_enabled=true 时生效。

功能

  • 支持 OpenAI / Gemini / Stable Diffusion 多种后端
  • 请求队列:默认前一个请求完成才继续下一个;draw_concurrent=true 时允许并发
  • 用户冷却:单用户 N 秒内只能请求一次(可配置,超级用户无视)
  • 图生图:回复图片时自动走 /images/edits(OpenAI 官方 multipart/form-data),文生图与图生图端点可独立配置
  • NSFW 关键词过滤(仅群聊)
  • 黑白名单访问控制(按用户 ID,全局生效)
  • URL / base64 两种返回格式(URL 发送失败自动回退下载转 base64 重发)
  • 可选图片缓存与一键清理
  • 子选项:--model / --size / --n 覆盖全局配置
  • 发送图片后输出耗时与中文 token 用量(⏱️ 耗时 X 秒 | 📊 消耗 输入 N、输出 M tokens,token 为 0 时只输出耗时)

协议

MIT © @Agnes4m

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nonebot_plugin_easy_aidraw-0.2.2.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nonebot_plugin_easy_aidraw-0.2.2-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

File details

Details for the file nonebot_plugin_easy_aidraw-0.2.2.tar.gz.

File metadata

  • Download URL: nonebot_plugin_easy_aidraw-0.2.2.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: pdm/2.27.0 CPython/3.12.3 Linux/6.17.0-1018-azure

File hashes

Hashes for nonebot_plugin_easy_aidraw-0.2.2.tar.gz
Algorithm Hash digest
SHA256 e4bd48b4881c24555f0894af098936c39050e2a90d1dead121d1d168a15e7c92
MD5 fef177360fdeb15648bad4e3427f2a01
BLAKE2b-256 735d13819b954254df158c94a738f33b385d2baf9eeb4574bd8b628fbde646b7

See more details on using hashes here.

File details

Details for the file nonebot_plugin_easy_aidraw-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for nonebot_plugin_easy_aidraw-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3f52ca683c29c9a00b64b70449afe4a2af1553c03e39267aef7c1b825f4abd60
MD5 44e2543cddea5e8bcddb8b7de899d877
BLAKE2b-256 af036106d8ee41abda80c98ede5f4266f02f1caab649806be7e836c174829480

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page