tencent cloud

文档反馈

最后更新时间:2022-05-24 15:47:54

    复用现有 UI

    视频拼接器具有比较复杂的交互逻辑,这也决定了其 UI 复杂度很高,所以我们比较推荐复用 SDK 开发包中的 UI 源码。VideoJoiner 目录包含短视频拼接器的 UI 源码。

    • VideoJoinerController:用于实现上图中的视频拼接列表,支持上下拖拽调整顺序。
    • VideoJoinerCell:用于实现拼接列表中的每一个视频片段。
    • VideoEditPrevController:用于预览拼接后的视频观看效果。

    自己实现 UI

    如果您不考虑复用我们开发包中的 UI 代码,想自己实现 UI 部分,则可以参考如下的攻略进行对接。

    1. 选择视频文件

    Demo 中使用了 QBImagePicker 这样一个开源库实现了多个文件的选择功能,相关代码在 Demo 的 MainViewController 里有所体现。

    2. 设置预览 View

    视频合成需要创建 TXVideoJoiner 对象,同 TXUGCEditer 类似,预览功能也需要上层提供预览 UIView:

    //准备预览 View
    TXPreviewParam *param = [[TXPreviewParam alloc] init];
    param.videoView = _videoPreview.renderView;
    param.renderMode = PREVIEW_RENDER_MODE_FILL_EDGE;
    // 创建 TXVideoJoiner 对象并设置预览 view
    TXVideoJoiner* _videoJoin = [[TXVideoJoiner alloc] initWithPreview:param];
    _videoJoin.previewDelegate = _videoPreview;
    // 设置待拼接的视频文件组 _composeArray,也就是第一步中选择的若干个文件
    [_videoJoin setVideoPathList:_composeArray];
    

    设置好预览 view 同时传入待合成的视频文件数组后,可以开始播放预览,合成模块提供了一组接口来做视频的播放预览:

    • startPlay:表示视频播放开始。
    • pausePlay:表示视频播放暂停。
    • resumePlay:表示视频播放恢复。

    3. 生成最终文件

    预览效果满意后调用生成接口即可生成合成后的文件:

    _videoJoin.joinerDelegate = self;
    [_videoJoin joinVideo:VIDEO_COMPRESSED_540P videoOutputPath:_outFilePath];
    

    合成时指定文件压缩质量和输出路径,输出的进度和结果会通过joinerDelegate以回调的形式通知用户。

    联系我们

    联系我们,为您的业务提供专属服务。

    技术支持

    如果你想寻求进一步的帮助,通过工单与我们进行联络。我们提供7x24的工单服务。

    7x24 电话支持