2024/08/14 16:11:49
鱼眼镜头畸变矫正与分离显示
在乐器陪练场景中,学生端可能会配置鱼眼镜头,用于让教师看到学生的弹奏动作,但是鱼眼镜头拍摄的画面存在失真。本文介绍如何使用声网提供的 API 对鱼眼镜头的画面进行畸变矫正和分离显示处理,以帮助教师在教学过程中更好地演示和纠正学生的弹奏动作。
前提条件
开始前请确保你的项目满足如下条件: 你已经集成了声网 RTC 教育特殊版 SDK 并实现了基本的音视频功能。详见快速开始。
实现方法
鱼眼镜头画面畸变矫正
你可以通过以下步骤进行鱼眼镜头画面畸变校正。声网建议在学生端进行鱼眼镜头画面矫正操作。
注意
由于鱼眼镜头画面畸变矫正参数较为复杂且与具体镜头型号有关,声网建议你提交工单联系技术支持协助调参。
-
根据镜头的实际情况,设置鱼眼镜头画面矫正参数。
C++// 鱼眼镜头画面矫正参数。
FishCorrectionParams params;
// _x_center 和 _y_center 代表鱼眼图像处理的中心位置。取值范围 [0.4, 0.6]。
params._x_center = 0.5;
params._y_center = 0.5;
// 鱼眼镜头成像的区域大小。取值范围 [1, 5]。
params._scale_factor = 2;
// 镜头焦距。取值范围 [20, 40]。
params._focal_length = 28;
// 标定鱼眼镜头的参数,通过镜头焦距计算。取值范围 [20, 40]。
params._pol_focal_length = 31;
// 鱼眼矫正效果切分高度。取值范围 [0, 1]。在切分线以上的画面有鱼眼矫正效果,在切分线以下的画面无鱼眼矫正效果。
params._split_height = 0.469;
// 镜头的一组参数,通过多项式拟合得到。不同类型的鱼眼镜头会有不同的值。
params._ss[0] = 0.8327;
params._ss[1] = 0.0;
params._ss[2] = -0.5536;
params._ss[3] = 0.4999;
params._ss[4] = -0.5590; -
调用
enableFishCorrection
开启鱼眼镜头画面矫正。C++m_lpAgoraEngine->enableFishCorrection(true, params);
画面分离显示
你可以通过以下步骤进行画面分离。声网建议在教师端进行画面分离操作,分离后的画面再传回学生端。
-
在调用
setupRemoteVideo
、setupLocalVideo
、setLocalVideoMirrorMode
、setRemoteRenderMode
、setLocalRenderMode
之前,调用enableVideoMultiRenderer
启用多重渲染。C++m_lpAgoraEngine->enableVideoMultiRenderer(true);
-
调用
setupLocalVideo
和setupRemoteVideo
分别增加本地和远端的渲染视图。C++VideoCanvas canvas;
// 设置渲染的视频源
canvas.sourceType = VIDEO_SOURCE_CAMERA_PRIMARY;
// 设置裁剪后出现在渲染区域的图像
canvas.area.xPoint = 100;
canvas.area.yPoint = 100;
canvas.area.width = 400;
canvas.area.height = 400;
// 增加本地渲染视图
m_lpAgoraEngine->setupLocalVideo(canvas, VIDEO_VIEW_SETUP_ADD);
// 增加远端渲染视图
m_lpAgoraEngine->setupRemoteVideo(canvas, VIDEO_VIEW_SETUP_ADD);
API 参考
你可以参考在线音乐教学 API 参考了解更多 API 使用信息。