CicadaPlayer实现多屏同步播放介绍

简介: # 1. 多屏同步的使用场景 此功能来自于一个需求:在同一个屏幕上同步显示同一个内容的四个不同码率的画面,用来展示不同的分辨率和码率最终被播放出来的画质的差异。 抽象一下此需求的场景,其实就是要多个播放器之间进行同步的需求,这些播放器之间可以不一定是同一个app内,甚至可以是互联网上的任何两个播放器实例。 ## 使用场景一 一个App中多个播放器间同步,如同最原始的需求。 ## 使用场景

1. 多屏同步的使用场景

此功能来自于一个需求:在同一个屏幕上同步显示同一个内容的四个不同码率的画面,用来展示不同的分辨率和码率最终被播放出来的画质的差异。
抽象一下此需求的场景,其实就是要多个播放器之间进行同步的需求,这些播放器之间可以不一定是同一个app内,甚至可以是互联网上的任何两个播放器实例。

使用场景一

一个App中多个播放器间同步,如同最原始的需求。

使用场景二

一个博物馆要投射一个模拟清明上河图的场景再现视频,由于清明上河的宽度非常宽,如果用普通的方案去投射,那么视频将无法观看,博物馆采用的方案是使用多个投影仪排成一排,每个投影仪投射整个视频的一部分,多个投影仪同步播放,这样就可以更好的把清明上河图的场景再现视频更好的播放了。

此场景可以使用一台比较强大的主机,同时播放各个部分的画面,然后通过hdmi阵列输出,如果这样实现,则和场景一差不多,只是内容不是相同的而已。如果这么实现,那么对主机的要求就比较高了,需要一个强大的解码功能,和多hdmi输出的显卡,并需要考虑画面和hdmi的输出对应关系。

此场景也可以使用局域网来连接多个播放设备进行同步,这样的成本就会低很多,设备的摆放和线路的连接也要容易得多。

使用场景三

互联网上有个虚拟的房间,房间里面的人会观看同一个内容的视频,但是希望房间里面的所有观看者观看的视频的进度是一致的,这样可以更好的进行一些互动。如答题,猜球之类。

此场景需要互联网上的两个播放器进行同步。

2实现

从上面能想到的场景来看,只要播放器之间可以通过网络进行通信,上述的所有需求都可以满足,所以CicadaPlayer多屏同步采用的是tcp网络协议进行同步。

可以参考https://github.com/alibaba/CicadaPlayer/blob/develop/cmdline/example/syncPlayer.cpp
中的实现。

其中实现了一个用tcp client server的方式实现了一个master播放器和多个slave播放器之间进行同步的例子

static string serverIp = "tcp://localhost:8888";
server的地址,如果在同一台机器上跑,则host就是localhost或者127.0.0.1,如果跑在不同的机器上,请填入正确的ip地址。

此例子中同时实现了master和slave player,通过bMaster变量进行控制,
如果想启动server,则

./syncPlayer  file

如果想启动slave

./syncPlayer  file  1

由于播放的内容可能是网络内容,也有可能是直播,所以要想让两个视频能内容同步,则必须让两个播放器同时prepare,同时start才行,所以在syncPlayer中prepare是用户来控制的,并且不能autostart。

此示例是所有的slave只向master同步,未考虑双向通信,双向通信在后面如果有需求再去实现。

如果是master

创建一个messageServer并初始化,播放器的设置按照正常的逻辑走,在

syncPlayerEventListener::onPrePare中prepare自己,并同时向server中发送prepare消息,让所有的slave开始prepare。

onStatusChanged onLoadingStart onLoadingEnd中根据状态向server中发送start或者pause消息。

在一个循环中定时GetMasterClockPts获取当前播放器的clock发送给sever。

如果是slave

创建一个messageClient,并连接server,用来接收来自server的消息。

播放器设置成只播放视频(音视频都播放的case暂时还不支持),在一个循环中收到消息后进行处理,pause prepare start 暂不多说,slave中自己启动一个时钟来记录从server中发送过来的clock的值,由于server不可能特别频繁的发送clock值,所有slave中的clock本身就具有计时功能,在server的clock发送过来的时候只是进行校正而已。

slave播放器将自己的clock当成播放器的参考时钟,通过SetClockRefer api设置给播放器,这样slave播放器内部在播放视频的时候就会获取这个参考时钟,从而实现和master同步播放的功能。

未完成的工作

  1. 目前slave只支持纯视频播放,如果要音视频都要播放,要考虑slave播放过快或者过慢的时候要进行音频的等待或者丢帧(倍速也可以)。
  2. 目前只支持了单向通信,目前还不完善,只能比较好的实现通一个App内的同步,多进程间要考虑在每个slave都prepare完成后才能start。
  3. 目前无整体进度同步的逻辑,若在场景三种使用,则master应该不是一个实体播放器,应该是一个放到公网上的虚拟播放器,虚拟播放器通过所有的client端反馈上来的状态来决定什么时候要开始播放,怎么确定主时钟的值等,来让绝大部分播放器同步。
相关文章
|
开发工具 Windows
Windows平台RTMP推送|轻量级RTSP服务实现本地摄像头|屏幕|叠加数据预览
大家在做Windows平台RTMP推送或轻量级RTSP服务的时候,不管是采集屏幕还是采集摄像头,亦或屏幕摄像头的叠加模式,总会有这样的诉求,采集到的数据,希望能本地看看具体采集的数据或者图像实际效果,也就是本次介绍的“预览”功能。
256 0
|
Web App开发 编解码 前端开发
VUE网页实时播放海康、大华摄像头RTSP视频流完全方案,300毫秒延迟,支持H.265、可多路同时播放
在遍地都是摄像头的今天,往往需要在各种信息化、数字化、可视化B/S系统中集成实时视频流播放等功能,海康、大华、华为等厂家摄像头或录像机等设备一般也都遵循监控行业标准,支持国际标准的主流传输协议RTSP输出,而Chrome、Firefox、Edge等新一代浏览器从2015年开始取消了NPAPI插件技术支持导致RTSP流无法直接原生播放了
3169 0
|
4月前
|
安全 API 开发工具
Android平台RTMP推送|轻量级RTSP服务如何实现麦克风|扬声器声音采集切换
Android平台扬声器播放声音的采集,在无纸化同屏等场景下,意义很大,早期低版本的Android设备,是没法直接采集扬声器audio的(从Android 10开始支持),所以,如果需要采集扬声器audio,需要先做系统版本判断,添加相应的权限。
|
7月前
技术经验分享:AVFoundation播放视频时显示字幕,切换音轨
技术经验分享:AVFoundation播放视频时显示字幕,切换音轨
57 0
|
7月前
|
图形学 异构计算
蓝易云 - Unity下如何实现低延迟的全景RTMP|RTSP流渲染
以上就是在Unity中实现低延迟的全景RTMP/RTSP流渲染的基本步骤。具体的实现可能会根据你的具体需求和所使用的库有所不同。
121 0
|
8月前
文字转语音后的音频结束以后,再播放一段时间的背景音乐。什么方案能实现
【2月更文挑战第13天】文字转语音后的音频结束以后,再播放一段时间的背景音乐。什么方案能实现
79 2
|
8月前
|
编解码
音视频录制播放原理
音视频录制播放原理
155 1
|
编解码 数据处理 vr&ar
VR头显Unity下如何实现毫秒级延迟的RTMP或RTSP播放?
VR头显Unity下如何实现毫秒级延迟的RTMP或RTSP播放?
257 1
|
存储 编解码 缓存
海康摄像头开发笔记(一):连接防爆摄像头、配置摄像头网段、设置rtsp码流、播放rtsp流、获取rtsp流、调优rtsp流播放延迟以及录像存储
Hik防爆摄像头录像,因为防爆摄像头会有对应的APP软件,与普通的网络摄像头和球机不一样,默认认为它不可以通过web网页配置,所以弄了个来实测确认。经测试实际上也是可以通过web网页配置(与网络摄像头基本是一致的,在码流方面可能会有些不一样),然后提取rtsp流的,界面与球机无异,只是没有球机的云台控制功能,但是界面上也是有的。
海康摄像头开发笔记(一):连接防爆摄像头、配置摄像头网段、设置rtsp码流、播放rtsp流、获取rtsp流、调优rtsp流播放延迟以及录像存储
|
监控 C#
C#大华监控画面切换
C#大华监控画面切换
160 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等