avtranscoder.h

概述

定义AVTranscoder接口。使用AVTranscoder提供的Native API将源视频文件转码为新视频文件。

引用文件: <multimedia/player_framework/avtranscoder.h>

库: libavtranscoder.so

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

相关模块: AVTranscoder

相关示例: AVPlayerNDKVideo

汇总

函数

名称 描述
OH_AVTranscoder_Config *OH_AVTranscoderConfig_Create() 创建转码配置参数实例。
OH_AVErrCode OH_AVTranscoderConfig_Release(OH_AVTranscoder_Config* config) 释放转码配置参数资源。
调用成功后,config实例会被释放并置为nullptr。
OH_AVErrCode OH_AVTranscoderConfig_SetSrcFD(OH_AVTranscoder_Config *config, int32_t srcFd, int64_t srcOffset, int64_t length) 设置转码源视频的文件描述符。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstFD(OH_AVTranscoder_Config *config, int32_t dstFd) 设置转码输出视频的文件描述符。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoType(OH_AVTranscoder_Config *config, const char *mimeType) 设置用于转码的输出视频的编码格式。
当前仅支持AVC和HEVC。若源视频编码格式为HEVC,则默认设置为HEVC,否则默认设置为AVC。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstAudioType(OH_AVTranscoder_Config *config, const char *mimeType) 设置用于转码的输出音频的编码格式。
当前仅支持AAC。若开发者不设置,则默认设置为AAC。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstFileType(OH_AVTranscoder_Config *config, OH_AVOutputFormat mimeType) 设置用于转码的输出视频文件的封装格式。
当前封装格式仅支持MP4。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstAudioBitrate(OH_AVTranscoder_Config *config, int32_t bitrate) 设置用于转码的输出音频的码率。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoBitrate(OH_AVTranscoder_Config *config, int32_t bitrate) 设置用于转码的输出视频的码率。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoResolution(OH_AVTranscoder_Config *config, int32_t width, int32_t height) 设置用于转码的输出视频的分辨率,单位为像素(px),其中width为输出视频帧的宽,height为输出视频帧的高。
此函数必须在OH_AVTranscoder_Prepare之前调用。
OH_AVErrCode OH_AVTranscoderConfig_EnableBFrame(OH_AVTranscoder_Config *config, bool enabled) 转码设置输出视频B帧编码。
B帧视频编码相关的约束和限制可以参考文档B帧视频编码约束和限制
如果当前不符合B帧视频编码的约束和限制,将忽略B帧,按不使能B帧进行编码。
OH_AVTranscoder *OH_AVTranscoder_Create(void) 创建转码实例。
OH_AVErrCode OH_AVTranscoder_Prepare(OH_AVTranscoder *transcoder, OH_AVTranscoder_Config *config) 进行视频转码的参数设置,准备转码。
此函数必须在OH_AVTranscoder_Start之前调用,调用成功之后进入AVTRANSCODER_PREPARED状态。
OH_AVErrCode OH_AVTranscoder_Start(OH_AVTranscoder *transcoder) 开始转码。
此函数必须在OH_AVTranscoder_Prepare成功调用之后调用,调用成功之后进入AVTRANSCODER_STARTED状态。
OH_AVErrCode OH_AVTranscoder_Pause(OH_AVTranscoder *transcoder) 暂停转码。
此函数必须在转码实例处于AVTRANSCODER_STARTED状态时调用,调用成功之后进入AVTRANSCODER_PAUSED状态。
OH_AVErrCode OH_AVTranscoder_Resume(OH_AVTranscoder *transcoder) 恢复转码。
此函数必须在转码实例处于AVTRANSCODER_PAUSED状态时调用,调用成功之后重新进入AVTRANSCODER_STARTED状态。
OH_AVErrCode OH_AVTranscoder_Cancel(OH_AVTranscoder *transcoder) 取消转码。
此函数须在转码实例处于AVTRANSCODER_STARTED和AVTRANSCODER_PAUSED状态时调用,调用成功之后进入AVTRANSCODER_CANCELLED状态。
OH_AVErrCode OH_AVTranscoder_Release(OH_AVTranscoder *transcoder) 释放转码实例资源。
OH_AVErrCode OH_AVTranscoder_SetStateCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnStateChange callback, void *userData) 注册触发转码状态修改事件的回调方法。
当触发状态修改事件时,通过注册的回调方法通知开发者。
开发者只能注册一个状态修改事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码状态修改,须在OH_AVTranscoder_Prepare之前注册转码状态回调。
OH_AVErrCode OH_AVTranscoder_SetErrorCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnError callback, void *userData) 注册触发转码错误事件的回调方法。
当触发错误事件时,通过注册的回调方法通知开发者。
如果AVTranscoder上报error事件,开发者需要通过OH_AVTranscoder_Release操作退出转码操作。
开发者只能注册一个错误事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码错误事件,须在OH_AVTranscoder_Prepare之前注册转码错误事件。
OH_AVErrCode OH_AVTranscoder_SetProgressUpdateCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnProgressUpdate callback, void *userData) 注册触发转码进度更新事件的回调方法。
当触发转码进度更新事件时,通过注册的回调方法通知开发者。
开发者只能注册一个错误事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码处理进度,则须在OH_AVTranscoder_Prepare之前注册该事件。

函数说明

OH_AVTranscoderConfig_Create()

OH_AVTranscoder_Config *OH_AVTranscoderConfig_Create()

描述

创建转码配置参数实例。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

返回:

类型 说明
OH_AVTranscoder_Config * 如果创建成功返回指向OH_AVTranscoder_Config实例的指针,否则返回空指针。

OH_AVTranscoderConfig_Release()

OH_AVErrCode OH_AVTranscoderConfig_Release(OH_AVTranscoder_Config* config)

描述

释放转码配置参数资源。
调用成功后,config实例会被释放并置为nullptr。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config* config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:释放成功。
AV_ERR_INVALID_VAL:config是空指针。

OH_AVTranscoderConfig_SetSrcFD()

OH_AVErrCode OH_AVTranscoderConfig_SetSrcFD(OH_AVTranscoder_Config *config, int32_t srcFd, int64_t srcOffset, int64_t length)

描述

设置转码源视频的文件描述符。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
int32_t srcFd 源视频的文件描述符。
int64_t srcOffset 源视频在文件描述符中的偏移量,单位:字节/Byte。
int64_t length 源视频的长度,单位:字节/Byte。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入config为空指针,或者源视频文件相关参数错误。

OH_AVTranscoderConfig_SetDstFD()

OH_AVErrCode OH_AVTranscoderConfig_SetDstFD(OH_AVTranscoder_Config *config, int32_t dstFd)

描述

设置转码输出视频的文件描述符。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
int32_t dstFd 输出视频的文件描述符。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入config为空指针,或者输出视频文件描述符是无效的。

OH_AVTranscoderConfig_SetDstVideoType()

OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoType(OH_AVTranscoder_Config *config, const char *mimeType)

描述

设置用于转码的输出视频的编码格式。
当前仅支持AVC和HEVC。若源视频编码格式为HEVC,则默认设置为HEVC,否则默认设置为AVC。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
const char *mimeType 输出视频的编码格式,详细请参见native_avcodec_base.h

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者mimeType是不被允许的。

OH_AVTranscoderConfig_SetDstAudioType()

OH_AVErrCode OH_AVTranscoderConfig_SetDstAudioType(OH_AVTranscoder_Config *config, const char *mimeType)

描述

设置用于转码的输出音频的编码格式。
当前仅支持AAC。若开发者不设置,则默认设置为AAC。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
const char *mimeType 输出音频的编码格式,详细请参见native_avcodec_base.h

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者mimeType是不被允许的。

OH_AVTranscoderConfig_SetDstFileType()

OH_AVErrCode OH_AVTranscoderConfig_SetDstFileType(OH_AVTranscoder_Config *config, OH_AVOutputFormat mimeType)

描述

设置用于转码的输出视频文件的封装格式。
当前封装格式仅支持MP4。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
OH_AVOutputFormat mimeType 输出视频的封装格式,详细请参见native_avcodec_base.h

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者mimeType是无效的。

OH_AVTranscoderConfig_SetDstAudioBitrate()

OH_AVErrCode OH_AVTranscoderConfig_SetDstAudioBitrate(OH_AVTranscoder_Config *config, int32_t bitrate)

描述

设置用于转码的输出音频的码率。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
int32_t bitrate 输出音频的码率,单位为比特率(bps)。支持范围[1-500000],默认设置为48Kbps。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者bitrate值是无效的。

OH_AVTranscoderConfig_SetDstVideoBitrate()

OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoBitrate(OH_AVTranscoder_Config *config, int32_t bitrate)

描述

设置用于转码的输出视频的码率。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
int32_t bitrate 输出视频的码率,单位为比特率(bps)。默认码率按输出视频的分辨率设置。
[240P,480P]默认码率值为1Mbps。
(480P,720P]默认码率值为2Mbps。
(240P,1080P]默认码率值为4Mbps。
1080P及以上默认码率值为8Mbps。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者bitrate值是无效的。

OH_AVTranscoderConfig_SetDstVideoResolution()

OH_AVErrCode OH_AVTranscoderConfig_SetDstVideoResolution(OH_AVTranscoder_Config *config, int32_t width, int32_t height)

描述

设置用于转码的输出视频的分辨率,单位为像素(px),其中width为输出视频帧的宽,height为输出视频帧的高。
此函数必须在OH_AVTranscoder_Prepare之前调用。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
int32_t width 输出视频帧的宽,支持范围[240-3840],默认设置为源视频帧的宽。
int32_t height 输出视频帧的高,支持范围[240-2160],默认设置为源视频帧的高。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针,或者width、height值是无效的。

OH_AVTranscoderConfig_EnableBFrame()

OH_AVErrCode OH_AVTranscoderConfig_EnableBFrame(OH_AVTranscoder_Config *config, bool enabled)

描述

转码设置输出视频B帧编码。
B帧视频编码相关的约束和限制可以参考文档B帧视频编码约束和限制
如果当前不符合B帧视频编码的约束和限制,将忽略B帧,按不使能B帧进行编码。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。
bool enabled 是否使能B帧编码。true表示使能B帧编码,false表示不使能B帧编码,默认为false。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:设置成功。
AV_ERR_INVALID_VAL:输入的config为空指针。

OH_AVTranscoder_Create()

OH_AVTranscoder *OH_AVTranscoder_Create(void)

描述

创建转码实例。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

返回:

类型 说明
OH_AVTranscoder * 如果创建成功返回指向OH_AVTranscoder实例的指针,否则返回空指针。

OH_AVTranscoder_Prepare()

OH_AVErrCode OH_AVTranscoder_Prepare(OH_AVTranscoder *transcoder, OH_AVTranscoder_Config *config)

描述

进行视频转码的参数设置,准备转码。
此函数必须在OH_AVTranscoder_Start之前调用,调用成功之后进入AVTRANSCODER_PREPARED状态。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。
OH_AVTranscoder_Config *config 指向OH_AVTranscoder_Config实例的指针。
传入的config指针必须为OH_AVTranscoderConfig_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功设置视频转码的参数设置,进入AVTRANSCODER_PREPARED状态。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码准备操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Prepare操作,或者是不支持的格式。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_Start()

OH_AVErrCode OH_AVTranscoder_Start(OH_AVTranscoder *transcoder)

描述

开始转码。
此函数必须在OH_AVTranscoder_Prepare成功调用之后调用,调用成功之后进入AVTRANSCODER_STARTED状态。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功开始转码,进入AVTRANSCODER_STARTED状态。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码开始操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Start操作。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_Pause()

OH_AVErrCode OH_AVTranscoder_Pause(OH_AVTranscoder *transcoder)

描述

暂停转码。
此函数必须在转码实例处于AVTRANSCODER_STARTED状态时调用,调用成功之后进入AVTRANSCODER_PAUSED状态。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功暂停转码,进入AVTRANSCODER_PAUSED状态。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码暂停操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Pause操作。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_Resume()

OH_AVErrCode OH_AVTranscoder_Resume(OH_AVTranscoder *transcoder)

描述

恢复转码。
此函数必须在转码实例处于AVTRANSCODER_PAUSED状态时调用,调用成功之后重新进入AVTRANSCODER_STARTED状态。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功恢复转码,进入AVTRANSCODER_STARTED状态。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码恢复操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Resume操作。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_Cancel()

OH_AVErrCode OH_AVTranscoder_Cancel(OH_AVTranscoder *transcoder)

描述

取消转码。
此函数须在转码实例处于AVTRANSCODER_STARTED和AVTRANSCODER_PAUSED状态时调用,调用成功之后进入AVTRANSCODER_CANCELLED状态。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功取消转码,进入AVTRANSCODER_CANCELLED状态。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码取消操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Cancel操作。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_Release()

OH_AVErrCode OH_AVTranscoder_Release(OH_AVTranscoder *transcoder)

描述

释放转码实例资源。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:成功释放转码实例资源。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者转码释放资源操作失败。
AV_ERR_OPERATE_NOT_PERMIT:当前状态不允许执行Release操作。
AV_ERR_IO:IO访问相关的错误。
AV_ERR_SERVICE_DIED:媒体服务已停止。

OH_AVTranscoder_SetStateCallback()

OH_AVErrCode OH_AVTranscoder_SetStateCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnStateChange callback, void *userData)

描述

注册触发转码状态修改事件的回调方法。
当触发状态修改事件时,通过注册的回调方法通知开发者。
开发者只能注册一个状态修改事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码状态修改,须在OH_AVTranscoder_Prepare之前注册转码状态回调。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。
OH_AVTranscoder_OnStateChange callback 转码状态回调方法,详细说明请参见OH_AVTranscoder_OnStateChange
void *userData 用户特定数据的指针。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:注册成功。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者callback是空指针。

OH_AVTranscoder_SetErrorCallback()

OH_AVErrCode OH_AVTranscoder_SetErrorCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnError callback, void *userData)

描述

注册触发转码错误事件的回调方法。
当触发错误事件时,通过注册的回调方法通知开发者。
如果AVTranscoder上报error事件,开发者需要通过OH_AVTranscoder_Release操作退出转码操作。
开发者只能注册一个错误事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码错误事件,须在OH_AVTranscoder_Prepare之前注册转码错误事件。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。
OH_AVTranscoder_OnError callback 转码错误回调方法,详细说明请参见OH_AVTranscoder_OnError
void *userData 用户特定数据的指针。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:注册成功。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者callback是空指针。

OH_AVTranscoder_SetProgressUpdateCallback()

OH_AVErrCode OH_AVTranscoder_SetProgressUpdateCallback(OH_AVTranscoder *transcoder, OH_AVTranscoder_OnProgressUpdate callback, void *userData)

描述

注册触发转码进度更新事件的回调方法。
当触发转码进度更新事件时,通过注册的回调方法通知开发者。
开发者只能注册一个错误事件的回调方法,当开发者重复注册时,以最后一次注册的回调接口为准。
若开发者需监听转码处理进度,则须在OH_AVTranscoder_Prepare之前注册该事件。

系统能力: SystemCapability.Multimedia.Media.AVTranscoder

起始版本: 20

参数:

参数项 描述
OH_AVTranscoder *transcoder 指向OH_AVTranscoder实例的指针。传入的transcoder指针必须为OH_AVTranscoder_Create创建的实例。
OH_AVTranscoder_OnProgressUpdate callback 转码进度更新回调方法,详细说明请参见OH_AVTranscoder_OnProgressUpdate
void *userData 用户特定数据的指针。

返回:

类型 说明
OH_AVErrCode AV_ERR_OK:注册成功。
AV_ERR_INVALID_VAL:输入的transcoder是空指针,或者callback是空指针。