我在苹果开发者论坛上发布了这个,我们进行了热烈的(请原谅双关语)讨论。这是对提出类似概念的人的回答。
如果我错了,我想纠正我,并举个例子,如果你不同意从 AVCaptureVideoDataOutput 获得的原始 h264 创建 mpeg ts 不是一件容易的事,除非你使用 x264 或类似的东西进行转码。让我们假设您可以轻松获取 mpeg ts 文件,然后在 m3u8 容器中编译它们,启动一个小型 Web 服务器并为它们提供服务将是一件简单的事情。据我所知,并且有很多应用程序可以做到这一点,从设备使用 localhost 隧道不是拒绝问题。因此,也许您可以以某种方式从设备生成 hls,我质疑您将获得的性能。
等到技术 2 仍然使用 AvCaptureVideoDataOutput,您捕获帧,将它们包装在一些简洁的小协议、json 或者更深奥的东西中,比如 bencode 打开一个套接字并将它们发送到您的服务器。啊……祝你好运,最好有一个强大的网络,因为即使通过 wifi 发送未压缩的帧也需要带宽。
等等技术3。
您使用 avassetwriter 编写新电影并使用标准 c 函数从临时文件中读回,这很好,但是您拥有的是原始 h264,mp4 不完整,因此它没有任何 moov 原子,现在有趣的部分正在重新生成这个标题。祝你好运。
等等,似乎实际上有一些优点的技术 4
我们创建的不是一个而是两个 avassetwriter,我们使用 gcd dispatch_queue 管理它们,因为在实例化 avassetwriter 后只能使用一次,我们在计时器上启动第一个,在预定时间段(例如 10 秒)之后,我们开始第二个,而拆掉第一个。现在我们有了一系列包含完整 moov 原子的 .mov 文件,每个文件都包含压缩的 h264 视频。现在我们可以将它们发送到服务器并将它们组合成一个完整的视频流。或者,我们可以使用一个简单的流媒体,它获取 mov 文件并使用 librtmp 将它们包装在 rtmp 协议中并将它们发送到媒体服务器。
我们是否可以将每个单独的 mov 文件发送到另一台苹果设备,从而实现设备到设备的通信,这个问题被误解了很多次,通过 wifi 在同一子网中定位另一台 iPhone 设备非常容易并且可以完成。通过蜂窝连接在 tcp 上定位另一个设备几乎是神奇的,如果它可以在使用可寻址 ip 的蜂窝网络上完成,而不是所有常见的运营商都可以做到。
假设您可以,那么您还有一个额外的问题,因为非 avfoundation 视频播放器将能够处理许多不同的单独电影文件之间的转换。您可能必须基于 ffmpeg 解码编写自己的流媒体播放器。(那确实工作得很好)