本插件由使用 PIL(Pillow)
库将纯文字消息转为图片,启动时会检测所需资源是否存在,若不存在会自动下载到对应位置。生成的图片以 base64
格式发送,不保存到磁盘。
完整文档可以在 这里 查看。
请在创建项目时选用合适的适配器,并且按照文档完成最小实例的创建。
nb plugin install nonebot-plugin-txt2img
pip install nonebot-plugin-txt2img
需要在 bot 根目录 pyproject.toml
文件中 [tool.nonebot] 部分添加:
plugins = ["nonebot_plugin_txt2img"]
自动下载资源文件需要参考 driver 配置项,添加 ForwardDriver
支持,在对应 env 文件(如 .env
.env.prod
)中,如:
DRIVER=~fastapi+~httpx
在对应 env 文件(如 .env
.env.prod
)中,可以修改下载资源时使用的 GitHub 代理:
GITHUB_PROXY="https://ghproxy.com"
指令匹配方式添加了 to_me()
规则,在群聊中使用时需要在命令首部或尾部添加 @机器人 或 机器人昵称。
使用指令:txt2img
发送指令后根据提示输入标题、内容与字体大小,即可完成图片生成。
- 标题:以
1.5
倍字体大小排版在首行居中位置。 - 内容:以
1
倍字体大小左对齐排版。 - 字体大小:位于
20~120
之间的数字。
若内容不满一行,或每行都是较短的内容,会根据内容文本宽度调节图片宽度。
如需在其他插件中使用文本转图片功能,可以从本插件导入。
导入方式:
from nonebot import require
require("nonebot_plugin_txt2img")
from nonebot_plugin_txt2img import Txt2Img
基本使用方式(以 OneBot V11
为例):
from nonebot.adapters.onebot.v11 import MessageSegment
# 标题设置为 '' 或 ' ' 可以去除标题行
title = '标题'
text = '正文内容'
font_size = 32
txt2img = Txt2Img()
# 设置字体大小
txt2img.set_font_size(font_size)
# # 同时设置内容与标题字体大小
# title_font_size = 48
# txt2img.set_font_size(font_size, title_font_size)
# # 设置固定宽度
# # 设置后不会在内容较窄时自动调整宽度
# width = 1080
# txt2img.set_width(1080)
# # 绘制 PIL.Image.Image 图片
# pic = txt2img.draw_img(title, text)
# 绘制 ByteIO 图片并发送
pic = txt2img.draw(title, text)
msg = MessageSegment.image(pic)
使用模板:
插件内置 ["default", "simple"]
两个模板,分别是小米便笺以及黑底白字简单风格。默认模板是 "default"
,可使用以下代码修改使用的模板:
...
# 使用简约模板
pic = txt2img.draw(title, text, "simple")
msg = MessageSegment.image(pic)
也可以传入一个 Template
对象以实现自定义模板,具体字段请参考代码内的标注,示例如下:
from nonebot_plugin_txt2img import Template
template = Template(...)
...
# 使用自定义模板
pic = txt2img.draw(title, text, template)
msg = MessageSegment.image(pic)
本项目基于以下项目或服务实现,排名不分先后。