Почему H.264, MPEG-4 HE AAC перестали работать на iphoneXS/Max?
Проблема с новым оборудованием
Я расследовал, как сумасшедший, и не нашел никаких подсказок, почему мои видео в кодировке H.264 перестали работать на этих новых устройствах.
Контекст: непосредственно с устройства ios оригинал отправляется на s3, затем эластичный транскодер затем кодирует оригинал в более сжатую предустановку H.264. Со вчерашнего дня коллега сообщал, что все видео были "черными", теперь, когда поставки на эти устройства выполняются, я получил подтверждение. Невозможно воспроизвести эту проблему на симуляторе. Закодированные видео, которые не воспроизводятся, я перечислил данные EXIF ниже.
Есть ли кто-нибудь с опытом в области кодеков, можете ли вы взвесить, почему новое устройство не сможет декодировать это видео H.264, когда устройства с iphoneX и ниже не имеют проблем?
➜ Downloads exiftool 30B3485D-24A3-4B6D-8B27-15B7C11FB864.mp4
ExifTool Version Number : 11.10
File Name : 30B3485D-24A3-4B6D-8B27-15B7C11FB864.mp4
Directory : .
File Size : 202 kB
File Modification Date/Time : 2018:09:24 20:35:47-07:00
File Access Date/Time : 2018:09:24 20:36:02-07:00
File Inode Change Date/Time : 2018:09:24 20:35:53-07:00
File Permissions : rw-r--r--
File Type : MP4
File Type Extension : mp4
MIME Type : video/mp4
Major Brand : MP4 Base Media v1 [IS0 14496-12:2003]
Minor Version : 0.2.0
Compatible Brands : isom, iso2, avc1, mp41
Movie Header Version : 0
Create Date : 0000:00:00 00:00:00
Modify Date : 0000:00:00 00:00:00
Time Scale : 1000
Duration : 4.12 s
Preferred Rate : 1
Preferred Volume : 100.00%
Preview Time : 0 s
Preview Duration : 0 s
Poster Time : 0 s
Selection Time : 0 s
Selection Duration : 0 s
Current Time : 0 s
Next Track ID : 3
Track Header Version : 0
Track Create Date : 0000:00:00 00:00:00
Track Modify Date : 0000:00:00 00:00:00
Track ID : 1
Track Duration : 4.12 s
Track Layer : 0
Track Volume : 100.00%
Balance : 0
Audio Format : mp4a
Audio Channels : 2
Audio Bits Per Sample : 16
Audio Sample Rate : 48000
Matrix Structure : 1 0 0 0 1 0 0 0 1
Image Width : 320
Image Height : 568
Media Header Version : 0
Media Create Date : 0000:00:00 00:00:00
Media Modify Date : 0000:00:00 00:00:00
Media Time Scale : 15360
Media Duration : 4.00 s
Media Language Code : und
Handler Description : VideoHandler
Graphics Mode : srcCopy
Op Color : 0 0 0
Compressor ID : avc1
Source Image Width : 320
Source Image Height : 568
X Resolution : 72
Y Resolution : 72
Bit Depth : 24
Pixel Aspect Ratio : 1:1
Video Frame Rate : 30
Handler Type : Metadata
Handler Vendor ID : Apple
Encoder : Lavf57.71.100
Movie Data Size : 202178
Movie Data Offset : 4545
Avg Bitrate : 393 kbps
Image Size : 320x568
Megapixels : 0.182
Rotation : 0
0 ответов
Эта ошибка была устранена для меня в бета-версии iOS13. Apple вернулась ко мне и сообщила, что заголовок H264 говорит, что мое видео было версии 4.0, но первый кадр H264 говорит, что это 3.1, и iOS12 не допустит этого.
Мне удалось исправить это в коде, указав версию заголовка как 3.1
У меня была похожая проблема с этим с черным видео на iPhone XS Max, и оказалось, что я устанавливал ключи kCVPixelBufferCGImageCompatibilityKey
а также kCVPixelBufferCGBitmapContextCompatibilityKey
ДА в sourcePixelBufferAttributes
словарь при создании AVAssetWriterInputPixelBufferAdaptor
, Комментирование этих двух ключей из словаря, похоже, решило проблему.
Я выяснил причину. IPhone Xs+ поддерживает все разрешения H.264 и частоту кадров. Однако для определенных частот кадров требуется HEVC:
- 1080p при 240 кадрах в секунду
- 4K @ 60 кадров в секунду
Таким образом, если вы не будете настраивать captureSession.sessionPreset на некоторые пользовательские значения с более низким разрешением:
if isFullHDVideoEnabled && captureSession.canSetSessionPreset(AVCaptureSession.Preset.hd1920x1080) {
captureSession.sessionPreset = AVCaptureSession.Preset.hd1920x1080
}
else {
captureSession.sessionPreset = AVCaptureSession.Preset.hd1280x720
}
iPhone будет записывать видео в формате H.265, и будет единственный вариант (.hevc) в movieFileOutput.availableVideoCodecTypes.
if #available(iOS 11.0, *) {
if movieFileOutput.availableVideoCodecTypes.contains(.h264) {
movieFileOutput.setOutputSettings([AVVideoCodecKey: AVVideoCodecType.h264], for: connection)
}
else if movieFileOutput.availableVideoCodecTypes.contains(.hevc) {
movieFileOutput.setOutputSettings([AVVideoCodecKey: AVVideoCodecType.hevc], for: connection)
}
}