Aseprite MCP Tools v2.0 是一款强大的 Python MCP(模型上下文协议)服务器,用于与 Aseprite 进行编程式交互。它具备增强的错误处理、配置管理、批处理等功能!
点击查看日语版 | macOS 安装指南
Aseprite MCP Tools v2.0 提供了一系列强大的功能,可帮助你更高效地与 Aseprite 进行交互。你可以创建精灵、添加图层和帧、绘制各种图形、管理调色板、批量处理文件等。
{
"mcpServers": {
"aseprite": {
"command": "/opt/homebrew/bin/uv",
"args": [
"--directory",
"/path/to/aseprite-mcp",
"run",
"-m",
"aseprite_mcp"
],
"env": {
"ASEPRITE_PATH": "/path/to/aseprite"
}
}
}
}
{
"mcpServers": {
"aseprite": {
"command": "python",
"args": ["-m", "aseprite_mcp"],
"cwd": "/path/to/aseprite-mcp",
"env": {
"ASEPRITE_PATH": "/path/to/aseprite"
}
}
}
}
pip install -r requirements.txt
# 创建一个新的精灵
await create_canvas(320, 240, "my_sprite.aseprite")
# 绘制像素
await draw_pixels("my_sprite.aseprite", [
{"x": 10, "y": 10, "color": "FF0000"}, # 红色
{"x": 11, "y": 10, "color": "00FF00"}, # 绿色
{"x": 12, "y": 10, "color": "0000FF"} # 蓝色
])
# 绘制图形
await draw_rectangle("my_sprite.aseprite", 50, 50, 100, 80, "FFFF00", fill=True)
await draw_circle("my_sprite.aseprite", 160, 120, 30, "FF00FF", fill=False)
await draw_line("my_sprite.aseprite", 0, 0, 320, 240, "FFFFFF", thickness=2)
# 填充区域
await fill_area("my_sprite.aseprite", 100, 100, "00FFFF", tolerance=10)
# 添加一个新的图层
await add_layer("my_sprite.aseprite", "Background")
# 添加动画帧
await add_frame("my_sprite.aseprite", after_frame=0)
# 应用预设调色板
await apply_preset_palette("my_sprite.aseprite", "gameboy")
# 可用预设:gameboy, gameboy-pocket, nes, pico-8, cga, monochrome, sepia
# 创建自定义调色板
await create_palette("my_sprite.aseprite", [
"264653", "2A9D8F", "E9C46A", "F4A261", "E76F51"
])
# 从图像中提取调色板
await extract_palette_from_image("reference.png", max_colors=16)
# 获取调色板信息
await get_palette_info("my_sprite.aseprite")
# 重映射颜色
await remap_colors("my_sprite.aseprite", {
"FF0000": "00FF00", # 红色到绿色
"0000FF": "FFFF00" # 蓝色到黄色
})
# 导出单个文件
await export_sprite("my_sprite.aseprite", "output.png", scale=2.0)
# 按帧范围导出
await export_sprite("animation.aseprite", "frames.gif", frame_range="1-10")
# 分别导出每个图层
await export_layers("my_sprite.aseprite", "layers/", format="png")
# 调整多个精灵的大小
await batch_resize(
input_dir="sprites/",
output_dir="sprites_small/",
scale=0.5,
file_pattern="*.aseprite"
)
# 批量导出为 PNG
await batch_export(
input_dir="sprites/",
output_dir="exports/",
format="png",
scale=2.0
)
# 将调色板应用于多个文件
await batch_apply_palette(
input_dir="sprites/",
palette_file="my_palette.aseprite",
create_backup=True
)
# 对多个文件运行自定义 Lua 脚本
await batch_process_custom(
input_dir="sprites/",
lua_script="app.activeSprite:flatten()",
output_dir="flattened/"
)
aseprite-mcp/
├── aseprite_mcp/
│ ├── core/
│ │ ├── commands.py # Aseprite 命令执行
│ │ ├── config.py # 配置管理
│ │ ├── exceptions.py # 自定义异常
│ │ ├── logging.py # 日志系统
│ │ ├── lua_builder.py # Lua 脚本生成器
│ │ └── validation.py # 输入验证
│ └── tools/
│ ├── batch.py # 批处理
│ ├── canvas.py # 画布操作
│ ├── drawing.py # 绘图工具
│ ├── export.py # 导出功能
│ └── palette.py # 调色板管理
├── tests/ # 单元测试
├── examples/ # 示例脚本
└── config.example.yaml # 配置示例
try:
result = await create_canvas(-100, 200, "test.aseprite")
except ValidationError as e:
print(f"验证失败: {e}")
except AsepriteError as e:
print(f"Aseprite 错误: {e}")
from aseprite_mcp.core.lua_builder import LuaBuilder
builder = LuaBuilder()
builder.create_sprite(200, 200)
builder.begin_transaction()
builder.set_color("FF0000")
builder.for_loop("i", 0, 10)
builder.draw_pixel("i * 10", "i * 10")
builder.end_loop()
builder.end_transaction()
builder.save_sprite("output.aseprite")
script = builder.build() # 返回简洁的 Lua 代码
运行所有测试:
pytest tests/ -v
运行特定测试:
pytest tests/test_validation.py -v
运行演示脚本:
python examples/demo_improvements.py
日志包括:
示例日志:
2024-06-11 10:30:45 - aseprite_mcp - INFO - 操作: create_canvas
2024-06-11 10:30:45 - aseprite_mcp - INFO - 画布创建成功
2024-06-11 10:30:45 - aseprite_mcp - INFO - 性能: create_canvas 耗时 0.234s
本项目采用 MIT 许可证,详情请参阅 LICENSE 文件。