虚拟背景
enableVirtualBackground
启用或关闭虚拟背景功能。
C++
virtual int enableVirtualBackground(bool enabled, VirtualBackgroundSource backgroundSource, SegmentationProperty segproperty, agora::media::MEDIA_SOURCE_TYPE type = agora::media::PRIMARY_CAMERA_SOURCE) = 0;
自从
自 v3.7.200 版本新增。
虚拟背景功能支持本地用户将原始背景替换为静态图片、动态视频、模糊背景或人像背景分割,以实现画中画效果。启用虚拟背景功能后,频道内的所有用户都可以看到自定义背景。请在调用 enableVideo 或 startPreview 后调用此方法。
信息
- 使用视频作为虚拟背景会导致内存持续增长,可能引发应用崩溃。建议降低视频的分辨率和帧率。
- 此功能对设备性能要求较高。调用此方法时,SDK 会自动检测当前设备的性能。声网建议在以下处理器设备上使用虚拟背景功能:
- Snapdragon 700 系列 750G 及以上版本。
- Snapdragon 800 系列 835 及以上版本。
- Dimensity 700 系列 720 及以上版本。
- Kirin 800 系列 810 及以上版本。
- Kirin 900 系列 980 及以上版本。
- 配备 i5 及以上 CPU 的设备。
- 配备 A9 及以上芯片的设备,包括:
- iPhone 6S 及以上版本。
- iPad Air 第三代及以上版本。
- iPad 第五代及以上版本。
- iPad Pro 第一代及以上版本。
- iPad mini 第五代及以上版本。
- 声网建议在以下场景中使用此功能:
- 使用高清摄像头设备,且环境光线均匀。
- 拍摄画面中物体较少,人像为半身像且无遮挡。
- 背景为纯色,且与用户服装颜色有明显区别。
- 此方法依赖虚拟背景动态库 libagora_segmentation_extension.dll。若该动态库被删除,则无法正常启用该功能。
参数
- enabled
- 是否启用虚拟背景:
- true:启用虚拟背景。
- false:关闭虚拟背景。
- backgroundSource
- 自定义背景。SDK 会对自定义背景图像进行缩放和裁剪,以适配采集的视频分辨率,并确保图像内容不失真。详见 VirtualBackgroundSource。
- segproperty
- 背景图像的处理属性。详见 SegmentationProperty。
- type
- 应用滤镜效果的媒体源类型。详见 MEDIA_SOURCE_TYPE。
- 若使用摄像头采集本地视频,使用默认值
PRIMARY_CAMERA_SOURCE。 - 若使用自定义视频源,设置为
CUSTOM_VIDEO_SOURCE。
- 若使用摄像头采集本地视频,使用默认值
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
- -4:设备性能不满足虚拟背景功能的要求。建议在性能更高的设备上尝试此功能。