Skip to main content

将 Pencil .pen 文件转换为 PowerPoint .pptx,通过 Pencil MCP server 获取精确布局

Project description

pencil2pptx

Pencil .pen 文件转换为 PowerPoint .pptx 文件。

通过 Pencil MCP server 获取精确的布局数据(坐标、尺寸由 Pencil 引擎计算),渲染为原生 PPT 元素(文本框、形状、图片),不可还原的节点(图标、SVG 路径、图片填充)按需导出为 PNG 保真插入。

安装

pip install pencil2pptx

使用

前提:Pencil 桌面应用需要正在运行。

# 基本用法(输出同名 .pptx)
pencil2pptx input.pen

# 指定输出路径
pencil2pptx input.pen -o output.pptx

# 调整字体缩放系数(默认 0.73)
pencil2pptx input.pen --font-scale 0.70

# 指定 Pencil MCP server 路径
pencil2pptx input.pen --pencil-cmd "/path/to/mcp-server"

uvx 免安装运行:

uvx pencil2pptx input.pen
uvx pencil2pptx input.pen -o output.pptx
uvx pencil2pptx input.pen --font-scale 0.70

python -m 运行:

python -m pencil2pptx input.pen -o output.pptx

参数

参数 说明 默认值
input 输入 .pen 文件路径 必填
-o, --output 输出 .pptx 路径 同名 .pptx
--font-scale 字体缩放系数 (Pencil px → PPT pt) 0.73
--pencil-cmd Pencil MCP server 可执行文件路径 Windows: %LOCALAPPDATA%\Programs\Pencil\...\mcp-server-windows-x64.exe

特性

按需图片导出

不再将整页导出为背景图,而是根据节点类型智能判断:

  • 原生 PPT 元素textrectangleellipselineframe 等节点直接用 PPT 原生形状渲染,保持可编辑
  • 图片填充节点fill{"type": "image"} 的节点,优先通过 export_nodes 导出,失败时从 .pen 文件的图片 URL 解析本地路径作为 fallback
  • SVG 路径节点path 类型节点(如 logo)导出为 4x 高清 PNG 插入
  • 图标节点icon_font 类型节点导出为 4x 高清 PNG 插入
  • Context Imagecontext 属性为 image/img 的节点整体导出为 PNG,适用于复杂表格、图表等

图片透明度与遮罩

图片填充节点的 opacity 属性通过 PPT 的 alphaModFix 机制正确还原。配合父级 frame 的纯色填充,可精确还原设计稿中的颜色遮罩效果(如蓝色底 + 半透明图片叠加)。

页面顺序

导出的 PPT 页面顺序与 Pencil 画布上的视觉排列一致,按从上到下、从左到右排序。

工作原理

  1. 通过 MCP 协议连接正在运行的 Pencil 桌面应用
  2. 调用 snapshot_layout 获取 Pencil 引擎计算后的精确布局(坐标、尺寸)
  3. 按画布位置(先 y 后 x)排序顶层帧,确保页面顺序与 Pencil 视觉顺序一致
  4. 调用 batch_get 获取节点属性(类型、样式、文本内容等)
  5. 按节点类型按需导出图片:
    • icon_font → 4x PNG
    • path → 4x PNG
    • 图片填充 → 2x PNG(或本地路径 fallback)
    • context: image/img → 2x PNG
  6. 合并布局和属性数据,渲染为原生 PPT 元素,不可还原的节点以图片插入

依赖

更新日志

v0.3.0 (2025-04-23)

重构:按需导出替代整页背景图

  • 移除整页背景图导出策略,改为根据节点类型智能判断是否需要导出为图片
  • 新增 path 类型节点(SVG 路径)的收集与导出支持
  • 图片填充节点增加本地路径 fallback:当 export_nodes 失败时,从 .pen 文件的图片 URL 解析本地路径
  • 新增 _set_picture_opacity 函数,通过 alphaModFix 正确设置图片透明度,还原设计稿中的颜色遮罩效果
  • 移除 skip_bg_shapes 逻辑,所有节点统一按类型渲染
  • 导出速度显著提升(无需等待整页截图)

v0.2.2

  • 初始发布
  • 支持 text、rectangle、ellipse、line、frame、icon_font 节点渲染
  • 支持 context image 整体导出
  • 支持图片填充节点导出
  • 支持整页背景图导出(已在 v0.3.0 中移除)

License

MIT

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

pencil2pptx-0.3.0.tar.gz (261.4 kB view details)

Uploaded Source

Built Distribution

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

pencil2pptx-0.3.0-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

Details for the file pencil2pptx-0.3.0.tar.gz.

File metadata

  • Download URL: pencil2pptx-0.3.0.tar.gz
  • Upload date:
  • Size: 261.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for pencil2pptx-0.3.0.tar.gz
Algorithm Hash digest
SHA256 0c4e47f100b40715f8a118a5df4b2ac012eddf7f713350b45692db1911c7c78d
MD5 a9707662bc773fe5cf9cb23806d6bba0
BLAKE2b-256 d75f522f2261c1c3ab86ca682deab6beb8b8783bf6de589b10bf63a6080401fe

See more details on using hashes here.

File details

Details for the file pencil2pptx-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: pencil2pptx-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 13.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for pencil2pptx-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3e59de73dcf6fdcc78735a8c4ad5ca40a3c2ccf2bcec9dcff2d067bfa4f8cf96
MD5 ecadaad314acda66d0097dea2c0701e5
BLAKE2b-256 b3b0be22aa20218cf65f686dc92c661ece57088963656220369fd518c1eabf34

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