# PLT 裁片处理接口文档 (PS 插件专用) 本文档描述了用于处理 PLT 样板文件并生成 Photoshop 可用图像数据的后端接口。 ## 1. 接口概览 该接口接收 PLT 格式的服装样板文件,在服务器端进行解析、几何计算和渲染,最终返回按尺码分组的 **透明背景 PNG 图片 (Base64)** 以及在画布上的 **精确坐标信息**。 **新功能**: 支持同时上传两个文件(标准文件 + 旋转后文件),接口会自动进行轮廓匹配,计算出最佳的旋转角度和相似度。 Photoshop 插件可以直接使用返回的 Base64 图片数据创建图层,并根据坐标信息自动进行排版。 ## 2. 接口定义 - **URL**: `/api/v1/algorithm/process_plt` - **Method**: `POST` - **Content-Type**: `multipart/form-data` - **认证方式**: Bearer Token (需登录) ### 2.1 请求参数 (Form Data) | 参数名 | 类型 | 必填 | 默认值 | 说明 | | :--- | :--- | :--- | :--- | :--- | | `file` | File | **是** | - | **标准 PLT 文件** (.plt)。 | | `rotated_file` | File | **否** | - | **已旋转/待匹配的 PLT 文件** (.plt)。
如果上传此文件,接口将执行轮廓匹配算法。 | | `size_labels` | String | **是** | - | **尺码列表** (JSON 字符串)。
例如: `["S", "M", "L", "XL"]`
用于告诉算法文件里包含了哪些尺码。 | | `dpi` | Integer | 否 | `150` | **输出图片分辨率**。
建议与 PS 画布分辨率一致。 | | `rotation` | Integer | 否 | `0` | **强制旋转角度** (仅针对 `file`)。
可选值: `0`, `90`, `-90`, `180`。
接口会自动处理图片旋转和坐标变换。 | ### 2.2 响应结构 (JSON) ```json { "success": true, "total_groups": 5, // 裁片分组数据 (主要返回 file 的内容) "groups": [ { "group_id": 1, "pieces": [ { "size": "S", "image_base64": "data:image/png;base64,iVBORw0KGgo...", "width_px": 800, "height_px": 600, "width_cm": 13.54, "height_cm": 10.16, "center_x_cm": 25.4, "center_y_cm": 30.2, "left_cm": 18.63, "top_cm": 35.28 }, ... ] } ], // 匹配分析结果 (仅当上传了 rotated_file 时存在) "match_analysis": [ { "size": "S", "matches": [ { "standard_id": 0, // 标准文件中的裁片ID "rotated_id": 3, // 旋转文件中的裁片ID "distance": 0.7032, // Hausdorff 距离 (越小越相似) "angle": 0.0 // 建议旋转角度 }, { "standard_id": 5, "rotated_id": 1, "distance": 1.0371, "angle": 180.0 // 建议旋转 180 度 } ] }, ... ] } ``` ### 2.3 关键字段说明 * **`image_base64`**: * 这是最核心的字段。 * 包含了裁片的 **PNG 图片数据**(带透明通道)。 * 格式为标准 Data URI: `data:image/png;base64,...`。 * PS 插件可以直接读取此字符串并转换为图像对象。 * **`left_cm` / `top_cm`**: * **推荐使用**这两个字段进行定位。 * 表示裁片 **左上角** 在画布中的坐标(单位:厘米)。 * 坐标系原点通常取决于 PLT 文件的最小包围盒。 * **注意**: PS 的 Y 轴向下,而 CAD 通常向上。接口返回的 `top_cm` 是基于数学坐标系的,在 PS 中使用时可能需要根据画布高度进行翻转 (`CanvasHeight - top_cm`),或者直接使用(取决于具体需求)。 * **`match_analysis`**: * 用于分析两个 PLT 文件之间的裁片对应关系。 * 可以用来判断某些裁片是否需要旋转 180 度才能匹配(例如倒顺毛面料)。 ## 3. Photoshop 插件调用示例 (JavaScript/ExtendScript) ```javascript // 假设 response 是从接口获取的 JSON 对象 var groups = response.groups; for (var i = 0; i < groups.length; i++) { var group = groups[i]; var pieces = group.pieces; for (var j = 0; j < pieces.length; j++) { var piece = pieces[j]; // 1. 获取 Base64 图片数据 (去掉前缀) var base64Data = piece.image_base64.split(",")[1]; // 2. 保存为临时文件并打开 (伪代码) var tempFile = saveBase64ToPng(base64Data); var doc = app.open(tempFile); // 3. 复制到主文档 doc.activeLayer.copy(); app.activeDocument = mainDoc; var newLayer = mainDoc.paste(); newLayer.name = piece.size + "-" + group.group_id; // 4. 定位 (将厘米转换为像素) var dpi = 150; // 与请求参数一致 var x_px = piece.left_cm * dpi / 2.54; var y_px = piece.top_cm * dpi / 2.54; // 移动图层 newLayer.translate(x_px, y_px); } } ```