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使用指引

Android TRTC 实现横屏视频通话

发布时间:2019年3月25日 更新时间:2019年3月25日 贡献者:yyuanchen

问题场景

如果您因业务场景需求,需要用户将手机横着放,然后进行视频通话。可以参考以下文档实现该功能。

解决方案

场景一:用户习惯是手机固定横着放。

1. 将 Activity 设置为横屏
  • Android:

假设视频通话界面名为 TRTCMainActivity,在 AndroidManifest.xml 中将该界面设置为横屏。

<activity
    android:name=".trtc.TRTCMainActivity"
    android:launchMode="singleTask"
    android:windowSoftInputMode="adjustPan"
    android:screenOrientation="landscape" />
2.将视频分辨率设置为横屏
  • Android:
private TRTCCloud trtcCloud;              /// TRTC SDK 实例对象
private TRTCCloudListener trtcListener;   /// TRTC SDK 回调监听

// 创建 trtcCloud 实例
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ....
    trtcListener = new TRTCCloudListenerImpl(this);
    trtcCloud = TRTCCloud.sharedInstance(this);
    trtcCloud.setListener(trtcListener);
    // 预览前配置默认参数
    setTRTCCloudParam();
    // 开启视频采集预览
    ......
    //进房
    trtcCloud.enterRoom(trtcParams, TRTCCloudDef.TRTC_APP_SCENE_VIDEOCALL);
}

/**
 * 设置视频通话的视频参数(分辨率、帧率和流畅模式等参数)
 */
private void setTRTCCloudParam() {

    // 大画面的编码器参数设置
    TRTCCloudDef.TRTCVideoEncParam encParam = new TRTCCloudDef.TRTCVideoEncParam();
    encParam.videoResolution = TRTCCloudDef.TRTC_VIDEO_RESOLUTION_640_360;  
    encParam.videoFps = 15;
    encParam.videoBitrate = 550;
    // videoResolutionMode 设置为横屏
    encParam.videoResolutionMode = TRTCCloudDef.TRTC_VIDEO_RESOLUTION_MODE_LANDSCAPE; 
    trtcCloud.setVideoEncoderParam(encParam);

    ......
}

场景二:用户习惯是手机固定横着放,但需支持手机旋转 360 度。

  • Android:

首先按照场景一的流程实现,然后开启 SDK 的重力接口即可。

/**
 * 设置视频通话的视频参数(分辨率、帧率和流畅模式等参数)
 */
private void setTRTCCloudParam() {

    // 大画面的编码器参数设置
    TRTCCloudDef.TRTCVideoEncParam encParam = new TRTCCloudDef.TRTCVideoEncParam();
    encParam.videoResolution = TRTCCloudDef.TRTC_VIDEO_RESOLUTION_640_360;  
    encParam.videoFps = 15;
    encParam.videoBitrate = 550;
    // videoResolutionMode 设置为横屏
    encParam.videoResolutionMode = TRTCCloudDef.TRTC_VIDEO_RESOLUTION_MODE_LANDSCAPE; 
    trtcCloud.setVideoEncoderParam(encParam);

    // 开启重力感应
    trtcCloud.setGSensorMode(TRTCCloudDef.TRTC_GSENSOR_MODE_UIAUTOLAYOUT);
    ......
}

原理说明

TRTC SDK 还提供了 5个 改变渲染角度(本地预览、远端观众)的接口,方便您根据场景需要进行各种调整。

接口函数 调节区域
setLocalViewRotation 设置本地预览画面的顺时针旋转角度(支持 90、180、270)
setLocalViewFillMode 设置本地预览画面的填充模式(是裁剪还是留黑边?)
setRemoteViewRotation 设置远端视频画面的顺时针旋转角度(支持 90、180、270)
setRemoteViewFillMode 设置远端视频画面的填充模式(是裁剪还是留黑边?)
setVideoEncoderRotation 设置编码器输出的画面顺时针旋转角度(目前仅支持180度旋转)

补充

1) 为什么横屏预览会有出现裁剪的问题?

建议您先将TRTC SDK 更新到 6.3 版本或以上,问题应该能迎刃而解。

2) 是否能设置预览画面的渲染效果(填充 or 适应)?

SDK 支持该功能。您可以使用TrtcCloud.setLocalViewFillMode(); 接口来实现效果。其中的值分别是:
填充模式(画面可能会被拉伸裁剪)值为 TRTCCloudDef.TRTC_VIDEO_RENDER_MODE_FIT
适应模式(画面可能会有黑边)值为 TRTCCloudDef.TRTC_VIDEO_RENDER_MODE_FILL

3) 参考文档

results matching ""

    No results matching ""