EasyRTMP作为TISNGSEE青犀视频开发的视频推流组件,其功能稳定可靠,经过多年项目实战,多种复杂环境运行,长期在线检验,已经能够在手机直播、桌面直播、摄像机直播、课堂直播等方面实现优秀的推流功能。
在用户的使用过程中,创建一个推流后,也有随时监控推流状态的需求,如何获取EasyRTMP当前的推流状态?这个需要根据回调函数来进行判定。EasyRTMP回调函数定义如下:
代码语言:javascript复制int __EasyRTMP_Callback(int _frameType, char *pBuf, EASY_RTMP_STATE_T _state, void *_userPtr)
{
_channel_info* pChannel = (_channel_info*)_userPtr;
switch(_state)
{
case EASY_RTMP_STATE_CONNECTING:
TRACE_LOG(pChannel->fLogHandle, "Connecting...n");
break;
case EASY_RTMP_STATE_CONNECTED:
TRACE_LOG(pChannel->fLogHandle, "Connectedn");
break;
case EASY_RTMP_STATE_CONNECT_FAILED:
TRACE_LOG(pChannel->fLogHandle, "Connect failedn");
break;
case EASY_RTMP_STATE_CONNECT_ABORT:
TRACE_LOG(pChannel->fLogHandle, "Connect abortn");
break;
case EASY_RTMP_STATE_DISCONNECTED:
TRACE_LOG(pChannel->fLogHandle, "Disconnect.n");
break;
default:
break;
}
return 0;
}
根据回调函数我们可以获取当前推流的状态,具体的函数释义如下:
EASY_RTMP_STATE_CONNECTING = 1, /* 连接中 * / EASY_RTMP_STATE_CONNECTED, /* 连接成功 * / EASY_RTMP_STATE_CONNECT_FAILED, /* 连接失败 * / EASY_RTMP_STATE_CONNECT_ABORT, /* 连接异常中断 * / EASY_RTMP_STATE_PUSHING, /* 推流中 * / EASY_RTMP_STATE_DISCONNECTED, /* 断开连接 */
EasyRTMP组件具备简单易用,运行高效等特点,能非常灵活地让用户自定义延时和缓冲区的大小,便于用户的调整和开发。作为TSINGSEE青犀视频开发产品的一份子,EasyRTMP当然也是支持测试的,欢迎了解。