SOP TRTC SDK 仪表盘 Android TRTC 发送自定义采集的视频数据 Android TRTC 发送自定义采集音频解决方案 Android TRTC 实现横屏视频通话 iOS端 TRTC 发送自定义采集视频解决方案 iOS端 TRTC 发送自定义采集音频解决方案 APNS推送 脏字过滤 TXLiteAVSDK中使用 AVAudioSession 问题总结 AndroidStudio编译SDK报错 RoomService部署验证 Xcode编译SDK报错 iOS编译库冲突问题 iOS端移动直播自定义采集实现 iOS端TXLiteAVSDK与IMSDK 3.x集成冲突报错问题 Android端TXLiteAVSDK与IMSDK 3.x集成冲突报错问题 Android端LiteIM sdk升级IM4.x版本报错问题 移动直播iOS 12兼容问题 如何实现好的画质 如何计算PCM音量大小 使用播放器播放视频有黑边 直播拉流播放失败 直播拉流端卡顿现象 短视频上传失败 移动直播SDK对接第三方美颜库 移动直播连麦解决方案 Android移动直播推自定义采集的视频数据 Android移动直播推自定义采集的声音数据 Android直播播放如何获取YUV数据 Android直播播放如何自定义渲染 实时音视频画面黑屏 实时音视频订阅流显示 iOS 12默认新编译系统下文件名冲突问题 TXLiteAVSDK指标监控 进阶:小程序实时音视频参数透传 移动直播 Android 9.0 无法拉流问题 移动直播推流事件回调 移动直播拉流事件回调 短视频实现视频缩略图列表转GIF功能 roomService加入群组时报错invalid group id NTP时间戳转换 提示Role not exists 角色不存在 如何播放背景音乐 iOS端短视频添音频相关问题总结 Web同步终端离线推送TIMOfflinePushInfo说明文档 web端自定义消息发送 web端同步终端的已读回执 web端对群组内用户禁言操作 TRTC v2混流接口setMixTranscodingConfig使用指引

移动直播拉流事件回调?

发布日期:2018年10月31日 更新日期:2018年10月31日 贡献者:yyuanchen

场景

用户在直播过程中,可能会遇到以下情况,如拉流一直不成功、因网络波动导致无法拉到流。App 一般都会在 UI 上通过一些提示语来提示关注。我们移动直播 SDK 有完整的事件回调,开发者可以根据不同事件回调来提示观众。

解决方案

Android

1、实现 ITXLivePlayListener 接口 并实现 onPlayEvent()onNetStatus() 方法

2、在onPlayEvent()监听拉流事件

@Override
public void onPlayEvent(int event, Bundle param) {
    String playEventLog = "receive event: " + event + ", " + param.getString(TXLiveConstants.EVT_DESCRIPTION);
    Log.d(TAG, playEventLog);

    if (event == TXLiveConstants.PLAY_EVT_PLAY_BEGIN) {
        // 视频播放开始, 停止 loading 状态的动画
        stopLoadingAnimation();
        Log.d("AutoMonitor", "PlayFirstRender,cost=" +(System.currentTimeMillis()-mStartPlayTS));
    } else if (event == TXLiveConstants.PLAY_ERR_NET_DISCONNECT) {
        // 可能主播关播,也有可能是主播网络出现波动
        stopPlay();
    } else if (event == TXLiveConstants.PLAY_EVT_PLAY_LOADING){
        // 视频数据缓冲中……
        startLoadingAnimation();
    } else if (event == TXLiveConstants.PLAY_EVT_RCV_FIRST_I_FRAME) {
        // 网络接收到首个可渲染的视频数据包(IDR)
        stopLoadingAnimation();
    } else if (event == TXLiveConstants.PLAY_EVT_CHANGE_RESOLUTION) {
        // 直播流的分辨率改变
        streamRecord(false);
    } else if (event == TXLiveConstants.PLAY_EVT_CHANGE_ROTATION) {
        // 主播改变推流的方向
        return;
    }

    if (event < 0) {
        Toast.makeText(getApplicationContext(), param.getString(TXLiveConstants.EVT_DESCRIPTION), Toast.LENGTH_SHORT).show();
    }
}

iOS

1、实现 ITXLivePlayListener 接口 并实现 onPlayEvent()onNetStatus() 方法

2、在onPlayEvent()监听拉流事件

#pragma ###TXLivePlayListener

-(void) onPlayEvent:(int)EvtID withParam:(NSDictionary*)param
{
    NSDictionary* dict = param;

    dispatch_async(dispatch_get_main_queue(), ^{

        if (EvtID == PLAY_EVT_RCV_FIRST_I_FRAME) {
//            _publishParam = nil;
        }

        if (EvtID == PLAY_EVT_PLAY_BEGIN) {
            [self stopLoadingAnimation];
            long long playDelay = [[NSDate date]timeIntervalSince1970]*1000 - _startPlayTS;
            AppDemoLog(@"AutoMonitor:PlayFirstRender,cost=%lld", playDelay);
        } else if (EvtID == PLAY_ERR_NET_DISCONNECT ) {
            [self stopRtmp];
            NSString* Msg = (NSString*)[dict valueForKey:EVT_MSG];
            [self toastTip:Msg];
        } else if (EvtID == PLAY_EVT_PLAY_LOADING){
            [self startLoadingAnimation];
        }
        else if (EvtID == PLAY_EVT_CONNECT_SUCC) {
            BOOL isWifi = [AFNetworkReachabilityManager sharedManager].reachableViaWiFi;
            if (!isWifi) {
                __weak __typeof(self) weakSelf = self;
                [[AFNetworkReachabilityManager sharedManager] setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {
                    if (_playUrl.length == 0) {
                        return;
                    }
                    if (status == AFNetworkReachabilityStatusReachableViaWiFi) {
                        UIAlertController *alert = [UIAlertController alertControllerWithTitle:@""
                                                                                       message:@"您要切换到Wifi再观看吗?"
                                                                                preferredStyle:UIAlertControllerStyleAlert];
                        [alert addAction:[UIAlertAction actionWithTitle:@"是" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
                            [alert dismissViewControllerAnimated:YES completion:nil];
                            [weakSelf stopRtmp];
                            [weakSelf startRtmp];
                        }]];
                        [alert addAction:[UIAlertAction actionWithTitle:@"否" style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
                            [alert dismissViewControllerAnimated:YES completion:nil];
                        }]];
                        [weakSelf presentViewController:alert animated:YES completion:nil];
                    }
                }];
            }
        }else if (EvtID == PLAY_EVT_CHANGE_ROTATION) {
            return;
        }
    });
}

原理

使用移动直播 SDK 拉流成功, SDK 回调事件如下:

使用移动直播 SDK 拉流成功,但是过段时间因网络波动导致拉不到流,SDK 重连三次依然无法播放。SDK 回调事件如下:

移动直播 SDK 中拉流对象 TXLivePlayer 的内部原理,如下图

其他

如果您想了解更多的事件处理,见移动直播官网的事件处理文档

如果您想查看 SDK 中完整的事件回调, 见文档

results matching ""

    No results matching ""