【剪映小助手】贴纸处理接口

简介: 本文档详解贴纸处理接口:/v1/add_sticker(支持时间轴定位、缩放/位置调节与层级渲染)和/v1/search_sticker(关键词检索贴纸配置),涵盖架构设计、核心流程、参数规范、性能优化及故障排查,助力高效集成剪映贴纸能力。(239字)

贴纸处理接口

目录

  1. 简介
  2. 项目结构
  3. 核心组件
  4. 架构概览
  5. 详细组件分析
  6. 依赖分析
  7. 性能考量
  8. 故障排查指南
  9. 结论
  10. 附录

简介

本文档介绍贴纸处理接口,重点覆盖两个接口:

  • /v1/add_sticker:贴纸添加接口,支持在指定时间段内向剪映草稿中添加贴纸,可配置缩放与位置偏移
  • /v1/search_sticker:贴纸搜索接口,支持按关键词检索贴纸列表

文档说明请求参数、时间线定位机制、缩放与位置配置、层级关系与渲染顺序、透明度与动画效果的应用方式,并提供贴纸 ID 获取、贴纸预览与效果配置的示例与最佳实践。

项目结构

贴纸处理接口位于后端服务的 v1 路由模块中,采用“路由 → 模型(Schema)→ 服务(Service)”的分层设计:

  • 路由层:定义 /v1/add_sticker 与 /v1/search_sticker 的 HTTP 接口与响应模型
  • 模型层:使用 Pydantic 定义请求与响应的数据结构
  • 服务层:实现具体的业务逻辑,包括贴纸添加与贴纸搜索
  • 数据与配置:贴纸搜索依赖本地配置文件;贴纸添加依赖剪映草稿脚本与轨道系统
graph TB
Client["客户端"] --> Router["FastAPI 路由<br/>/v1/add_sticker<br/>/v1/search_sticker"]
Router --> SchemaAdd["请求模型<br/>AddStickerRequest"]
Router --> SchemaSearch["请求模型<br/>SearchStickerRequest"]
Router --> ServiceAdd["服务层<br/>add_sticker()"]
Router --> ServiceSearch["服务层<br/>search_sticker()"]
ServiceAdd --> Draft["剪映草稿脚本<br/>ScriptFile"]
ServiceAdd --> Track["贴纸轨道<br/>TrackType.sticker"]
ServiceSearch --> Config["贴纸配置文件<br/>sticker.json"]
Config --> ServiceSearch

核心组件

  • 贴纸添加接口(/v1/add_sticker)
    • 请求参数:draft_url、sticker_id、start、end、scale、transform_x、transform_y
    • 处理流程:参数校验 → 时间范围验证 → 从缓存获取草稿 → 创建贴纸轨道 → 构造图像调节设置(含缩放与位置)→ 创建贴纸片段 → 添加到轨道 → 保存草稿 → 返回 track_id、segment_id、duration
  • 贴纸搜索接口(/v1/search_sticker)
    • 请求参数:keyword
    • 处理流程:读取贴纸配置文件 → 关键词匹配 → 若无匹配则随机返回最多 50 条 → 截断至 50 条以内

架构概览

贴纸处理接口的调用链如下:

sequenceDiagram
participant C as "客户端"
participant R as "路由层(v1)"
participant S as "服务层"
participant D as "剪映草稿脚本"
participant T as "贴纸轨道"
C->>R : POST /v1/add_sticker
R->>S : 调用 add_sticker(...)
S->>S : 校验时间范围(end>start)
S->>D : 从缓存获取草稿
S->>T : 创建贴纸轨道(若不存在)
S->>S : 构造ClipSettings(scale, transform_x/960, transform_y/540)
S->>D : 创建StickerSegment并添加到轨道
S->>D : 保存草稿
S-->>R : 返回draft_url, sticker_id, track_id, segment_id, duration
R-->>C : 200 OK
C->>R : POST /v1/search_sticker
R->>S : 调用 search_sticker(keyword)
S->>S : 读取config/sticker.json
S->>S : 关键词匹配/随机采样(<=50)
S-->>R : 返回data列表
R-->>C : 200 OK

详细组件分析

贴纸添加接口 /v1/add_sticker

  • 接口地址:/openapi/capcut-mate/v1/add_sticker
  • 方法:POST
  • 请求体字段

    • draft_url:草稿 URL(必填)
    • sticker_id:贴纸唯一标识(必填)
    • start:开始时间(微秒,必填)
    • end:结束时间(微秒,必填)
    • scale:缩放比例,默认 1.0(建议范围 0.1–5.0)
    • transform_x:X 轴位置偏移(像素,以画布中心为原点,默认 0)
    • transform_y:Y 轴位置偏移(像素,以画布中心为原点,默认 0)
  • 时间线定位机制

    • 贴纸在时间轴上的起止由 start 与 end 决定,持续时间为 duration = end - start
    • 时间范围必须满足 end > start,否则返回参数错误
  • 缩放与位置配置

    • scale 控制贴纸的缩放比例,1.0 表示原始尺寸
    • transform_x 与 transform_y 以像素为单位传入,内部转换为“半画布宽/高”单位进行存储:
      • transform_x 存储值 = transform_x / 960(假设画布宽度 1920)
      • transform_y 存储值 = transform_y / 540(假设画布高度 1080)
  • 层级关系与渲染顺序

    • 贴纸轨道类型为 sticker,渲染顺序高于视频、音频、特效、滤镜、文本等轨道
    • 轨道创建时使用唯一名称,确保同一草稿中贴纸轨道隔离
  • 透明度与动画效果

    • 透明度通过图像调节设置中的 alpha 字段控制(范围 0–1)
    • 动画效果可通过关键帧与片段动画实现(见“性能考量”与“附录”)
  • 响应字段

    • draft_url:更新后的草稿 URL
    • sticker_id:贴纸唯一标识
    • track_id:贴纸轨道 ID
    • segment_id:贴纸片段 ID
    • duration:贴纸显示时长(微秒)
  • 错误处理

    • 参数缺失或 end ≤ start:返回 400
    • 草稿不存在或无效:返回 404
    • 内部处理异常:返回 500
  • 使用示例

    • 基础贴纸添加、带缩放的贴纸、带位置偏移的贴纸
flowchart TD
Start(["进入 add_sticker"]) --> Validate["校验参数与时间范围"]
Validate --> Valid{"end > start ?"}
Valid --> |否| Err["返回 400 参数错误"]
Valid --> |是| GetDraft["从缓存获取草稿"]
GetDraft --> CreateTrack["创建贴纸轨道(若不存在)"]
CreateTrack --> BuildSettings["构建图像调节设置<br/>scale, transform_x/960, transform_y/540"]
BuildSettings --> CreateSegment["创建贴纸片段"]
CreateSegment --> AddToTrack["添加到轨道"]
AddToTrack --> Save["保存草稿"]
Save --> Return["返回 track_id, segment_id, duration"]

贴纸搜索接口 /v1/search_sticker

  • 接口地址:/openapi/capcut-mate/v1/search_sticker
  • 方法:POST
  • 请求体字段

    • keyword:关键词(必填)
  • 响应字段

    • data:贴纸数据列表,每项包含:
      • sticker:贴纸详细信息(large_image、preview_cover、sticker_package、sticker_type、track_thumbnail)
      • sticker_id:贴纸 ID
      • title:贴纸标题
  • 搜索策略

    • 从配置文件加载贴纸数据
    • 基于关键词在标题中进行包含匹配
    • 若无匹配结果,随机返回最多 50 条记录
    • 结果集超过 50 条时截断至 50 条
  • 使用示例

    • 关键词“人”搜索、关键词“动物”搜索
flowchart TD
S0(["进入 search_sticker"]) --> ReadCfg["读取 config/sticker.json"]
ReadCfg --> Match["按 keyword 在 title 中匹配"]
Match --> Found{"是否有匹配?"}
Found --> |是| Limit["限制返回数量<=50"]
Found --> |否| Sample["随机采样<=50条"]
Limit --> Done["返回 data 列表"]
Sample --> Done

贴纸 ID 获取、贴纸预览与贴纸效果配置

  • 贴纸 ID 获取
    • 通过 /v1/search_sticker 获取贴纸列表后,从响应 data 中提取 sticker_id
  • 贴纸预览
    • large_image.image_url 为贴纸大图 URL,track_thumbnail 为轨道缩略图 URL
  • 贴纸效果配置
    • 透明度:通过图像调节设置中的 alpha(0–1)控制
    • 动画效果:可结合关键帧与片段动画实现(参见“性能考量”与“附录”)

依赖分析

  • 路由到服务
    • /v1/add_sticker → service.add_sticker
    • /v1/search_sticker → service.search_sticker
  • 服务到模型
    • 请求模型:AddStickerRequest、SearchStickerRequest
    • 响应模型:AddStickerResponse、SearchStickerResponse
  • 服务到外部
    • 贴纸搜索依赖 config/sticker.json
    • 贴纸添加依赖剪映草稿脚本与轨道系统
graph LR
V1["路由 v1"] --> A["service.add_sticker"]
V1 --> B["service.search_sticker"]
A --> S["schemas.add_sticker"]
B --> S2["schemas.search_sticker"]
B --> C["config/sticker.json"]

性能考量

  • 贴纸搜索
    • 配置文件一次性加载,建议对大规模贴纸数据启用分页与缓存机制
    • 随机采样上限为 50,避免一次性返回过多数据
  • 贴纸添加
    • 自动创建贴纸轨道,避免重复创建带来的开销
    • 位置偏移转换为半画布单位,减少后续计算成本
  • 动画与透明度
    • 透明度与关键帧可叠加使用,建议合理设置关键帧密度,避免过度插值导致渲染压力

故障排查指南

  • /v1/add_sticker 常见问题
    • 参数缺失或 end ≤ start:检查请求体字段完整性与时间范围
    • 草稿不存在:确认 draft_url 有效且草稿已缓存
    • 贴纸添加失败:检查贴纸 ID 是否存在、轨道是否创建成功
  • /v1/search_sticker 常见问题
    • 关键词未命中:尝试更宽泛的关键词或检查配置文件是否存在
    • 返回空列表:确认配置文件路径与权限

结论

贴纸处理接口提供了完整的贴纸添加与搜索能力。通过清晰的参数模型与稳健的服务实现,开发者可以便捷地在剪映草稿中添加贴纸、控制其时间、缩放与位置,并通过关键词快速检索贴纸资源。

建议在生产环境中结合缓存与分页策略优化贴纸搜索性能,并合理使用透明度与关键帧实现丰富的动画效果。

附录

A. 请求与响应模型

  • 贴纸添加请求模型
    • 字段:draft_url、sticker_id、start、end、scale、transform_x、transform_y
    • 默认值:scale=1.0,transform_x=0,transform_y=0
  • 贴纸添加响应模型
    • 字段:draft_url、sticker_id、track_id、segment_id、duration
  • 贴纸搜索请求模型
    • 字段:keyword
  • 贴纸搜索响应模型
    • 字段:data(贴纸项列表)

B. 贴纸数据结构

  • 贴纸项(StickerItem)
    • 包含:sticker(StickerInfo)、sticker_id、title
  • 贴纸信息(StickerInfo)
    • 包含:large_image(LargeImage)、preview_cover、sticker_package(StickerPackage)、sticker_type、track_thumbnail
  • 大图信息(LargeImage)
    • 包含:image_url
  • 贴纸包信息(StickerPackage)
    • 包含:height_per_frame、size、width_per_frame

C. 贴纸轨道与渲染顺序

  • 贴纸轨道类型:sticker
  • 渲染顺序:高于视频、音频、特效、滤镜、文本等轨道
  • 轨道创建:按需创建,名称唯一

D. 图像调节设置与透明度

  • 图像调节设置(ClipSettings)
    • 字段:alpha(透明度,0–1)、scale_x/scale_y(缩放)、transform_x/transform_y(半画布单位)
  • 透明度控制:通过 alpha 设置,0 为完全透明,1 为不透明

E. 测试参考

  • 贴纸搜索测试
    • 正常搜索、无匹配随机返回、空关键词场景
  • 简化版贴纸搜索测试
    • 与服务层逻辑一致的简化实现
相关文章
|
7天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
3486 15
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
15天前
|
人工智能 开发工具 iOS开发
Claude Code 新手完全上手指南:安装、国产模型配置与常用命令全解
Claude Code 是一款运行在终端环境中的 AI 编程助手,能够直接在命令行中完成代码生成、项目分析、文件修改、命令执行、Git 管理等开发全流程工作。它最大的特点是**任务驱动、终端原生、轻量高效、多模型兼容**,无需图形界面、不依赖 IDE 插件,能够深度融入开发者日常工作流。
3567 12
|
9天前
|
人工智能 自然语言处理 供应链
|
18天前
|
Shell API 开发工具
Claude Code 快速上手指南(新手友好版)
AI编程工具卷疯啦!Claude Code凭借任务驱动+终端原生的特性,成了开发者的效率搭子。本文从安装、登录、切换国产模型到常用命令,手把手带新手快速上手,全程避坑,30分钟独立用起来。
3685 25
|
11天前
|
人工智能 Linux BI
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
JeecgBoot AI专题研究 一键脚本:Claude Code + JeecgBoot Skills + DeepSeek 全平台接入 一行命令装好 Claude Code + JeecgBoot Skills + DeepSeek 接入,无需翻墙使用 Claude Code,支持 Wind
2921 7
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
|
9天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全+三种模式+记忆体系+实战工作流完整手册
Claude Code 是当前最流行的终端级 AI 编程助手,能够直接在命令行中完成代码生成、项目理解、文件修改、命令执行、错误修复等全流程开发工作。它不依赖图形界面、不占用额外资源,却能深度理解项目结构,自动生成规范代码,大幅提升研发效率。
1424 3
|
1月前
|
人工智能 JSON 供应链
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
LucianaiB分享零成本畅用JVS Claw教程(学生认证享7个月使用权),并开源GeoMind项目——将JVS改造为科研与产业地理情报可视化AI助手,支持飞书文档解析、地理编码与腾讯地图可视化,助力产业关系图谱构建。
23621 15
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
|
16天前
|
存储 Linux iOS开发
【2026最新】MarkText中文版Markdown编辑器使用图解(附安装包)
MarkText是一款免费开源、跨平台的Markdown编辑器,主打所见即所得实时预览,支持Windows/macOS/Linux。内置数学公式、流程图、代码高亮、多主题及PDF/HTML导出,是Typora的轻量免费替代首选。(239字)

热门文章

最新文章