Files
capcut-mate/docs/add_keyframes.zh.md
Hommy 86c305aa52 1. 优化文档结构。
2. 删除多余文档。
3. 添加中英文切换开关。
2026-03-01 20:27:45 +08:00

6.8 KiB
Raw Blame History

ADD_KEYFRAMES API 接口文档

🌐 语言切换

中文版 | English

接口信息

POST /openapi/capcut-mate/v1/add_keyframes

功能描述

向现有草稿中添加关键帧。该接口用于在指定的片段上添加关键帧动画,支持多种属性类型的关键帧设置,如位置、缩放、旋转、透明度等。关键帧可以用于创建复杂的动画效果,增强视频的视觉表现力。

更多文档

📖 更多详细文档和教程请访问:https://docs.jcaigc.cn

请求参数

{
  "draft_url": "https://capcut-mate.jcaigc.cn/openapi/capcut-mate/v1/get_draft?draft_id=2025092811473036584258",
  "keyframes": "[{\"segment_id\":\"d62994b4-25fe-422a-a123-87ef05038558\",\"property\":\"KFTypePositionX\",\"offset\":5000000,\"value\":-0.1}]"
}

参数说明

参数名 类型 必填 默认值 说明
draft_url string - 目标草稿的完整URL
keyframes string - 关键帧信息列表的JSON字符串

keyframes 参数详解

基本结构

keyframes 是一个JSON字符串包含关键帧数组每个关键帧对象包含以下字段

字段名 类型 必填 说明
segment_id string 目标片段的唯一标识ID
property string 动画属性类型,支持的类型见下表
offset number 关键帧在片段中的时间偏移(微秒绝对时间)
value number 属性在该时间点的值

offset 参数说明

offset 参数只支持微秒绝对时间格式:

  • 以微秒为单位的整数,如 5000000 表示片段开始后5秒的位置
  • 系统会自动将微秒值转换为相对时间比例

支持的动画属性类型

属性类型 描述 值范围 示例
KFTypePositionX X轴位置 -1.0 到 1.0 0.0 (居中), -0.5 (左移), 0.5 (右移)
KFTypePositionY Y轴位置 -1.0 到 1.0 0.0 (居中), -0.5 (上移), 0.5 (下移)
KFTypeScaleX X轴缩放 0.1 到 10.0 1.0 (原始), 0.5 (缩小), 2.0 (放大)
KFTypeScaleY Y轴缩放 0.1 到 10.0 1.0 (原始), 0.5 (缩小), 2.0 (放大)
KFTypeRotation 旋转角度 -360 到 360 0 (无旋转), 90 (顺时针90度)
KFTypeAlpha 透明度 0.0 到 1.0 1.0 (不透明), 0.5 (半透明), 0.0 (透明)
UNIFORM_SCALE 统一缩放 0.1 到 10.0 1.0 (原始), 0.5 (缩小), 2.0 (放大)
KFTypeSaturation 饱和度 -1.0 到 1.0 0.0 (原始), -0.5 (降低), 0.5 (增强)
KFTypeContrast 对比度 -1.0 到 1.0 0.0 (原始), -0.5 (降低), 0.5 (增强)
KFTypeBrightness 亮度 -1.0 到 1.0 0.0 (原始), -0.5 (变暗), 0.5 (变亮)
KFTypeVolume 音量 0.0 到 2.0 1.0 (原始), 0.5 (降低), 2.0 (增强)

响应格式

成功响应 (200)

{
  "draft_url": "https://capcut-mate.jcaigc.cn/openapi/capcut-mate/v1/get_draft?draft_id=2025092811473036584258",
  "keyframes_added": 3,
  "affected_segments": ["segment_001", "segment_002"]
}

响应字段说明

字段名 类型 说明
draft_url string 更新后的草稿URL
keyframes_added integer 添加的关键帧数量
affected_segments array 受影响的片段ID列表

错误响应 (4xx/5xx)

{
  "detail": "错误信息描述"
}

使用示例

cURL 示例

1. 基本关键帧添加(使用微秒时间)

curl -X POST https://capcut-mate.jcaigc.cn/openapi/capcut-mate/v1/add_keyframes \
  -H "Content-Type: application/json" \
  -d '{
    "draft_url": "YOUR_DRAFT_URL",
    "keyframes": "[{\"segment_id\":\"segment-id\",\"property\":\"UNIFORM_SCALE\",\"offset\":0,\"value\":1},{\"segment_id\":\"segment-id\",\"property\":\"UNIFORM_SCALE\",\"offset\":5000000,\"value\":1.3}]"
  }'

2. 多属性关键帧

curl -X POST https://capcut-mate.jcaigc.cn/openapi/capcut-mate/v1/add_keyframes \
  -H "Content-Type: application/json" \
  -d '{
    "draft_url": "YOUR_DRAFT_URL",
    "keyframes": "[{\"segment_id\":\"segment-uuid\",\"property\":\"KFTypePositionX\",\"offset\":0,\"value\":0},{\"segment_id\":\"segment-uuid\",\"property\":\"KFTypePositionY\",\"offset\":0,\"value\":0},{\"segment_id\":\"segment-uuid\",\"property\":\"KFTypeRotation\",\"offset\":2500000,\"value\":90},{\"segment_id\":\"segment-uuid\",\"property\":\"KFTypeAlpha\",\"offset\":5000000,\"value\":0}]"
  }'

错误码说明

错误码 错误信息 说明 解决方案
400 draft_url是必填项 缺少草稿URL参数 提供有效的draft_url
400 keyframes是必填项 缺少关键帧参数 提供有效的keyframes数据
400 无效的关键帧信息请检查keyframes字段值是否正确 关键帧数据格式错误 检查关键帧数据格式是否符合要求
404 草稿不存在 指定的草稿URL无效 检查草稿URL是否正确
404 片段未找到 指定的segment_id在草稿中不存在 确认片段ID是否正确
400 无效的片段类型 该片段不支持关键帧功能 确保为目标片段是视觉片段(视频、图片、贴纸、文本)
400 无效的关键帧属性类型 指定的property类型不受支持 检查属性类型是否在支持列表中
500 关键帧添加失败 内部处理错误 联系技术支持

注意事项

  1. 片段ID验证: segment_id 必须是草稿中存在的有效片段ID
  2. 片段类型限制: 只有视觉片段(视频、图片、贴纸、文本)支持关键帧
  3. 时间偏移范围: offset 值必须是非负整数(微秒)
  4. 属性值范围: 不同的属性类型有不同的值范围限制
  5. 重复关键帧: 相同片段相同属性的关键帧会被累加,不会覆盖
  6. 性能考虑: 单次请求建议不超过100个关键帧
  7. 缩放属性: 设置KFTypeScaleX或KFTypeScaleY会自动取消锁定XY轴缩放比例

工作流程

  1. 验证必填参数draft_url, keyframes
  2. 解析关键帧数据JSON字符串
  3. 从缓存中获取草稿
  4. 验证每个关键帧数据的有效性
  5. 查找目标片段并验证片段类型
  6. 为每个关键帧创建关键帧列表并添加到片段
  7. 保存草稿
  8. 返回添加结果信息

相关接口