我正在尝试从视频文件中提取音轨并使用此类.mp4
转换为.m4a
音频文件outputSettings
AVAssetWriter
AudioChannelLayout channelLayout;
memset(&channelLayout, 0, sizeof(AudioChannelLayout));
channelLayout.mChannelLayoutTag = kAudioChannelLayoutTag_Stereo;
NSDictionary *outputSettings = [NSDictionary dictionaryWithObjectsAndKeys:
[NSNumber numberWithInt: kAudioFormatMPEG4AAC], AVFormatIDKey,
[NSNumber numberWithFloat:44100.0], AVSampleRateKey,
[NSNumber numberWithInt:2], AVNumberOfChannelsKey,
[NSNumber numberWithInt:128000], AVEncoderBitRateKey, // 128 kbps
[NSData dataWithBytes:&channelLayout length:sizeof(AudioChannelLayout)], AVChannelLayoutKey,
nil];
案例 1:带有音轨参数的 .mp4 视频文件(使用 打印CMFormatDescriptionRef
):
mediaType:'soun'
mediaSubType:'aac '
mSampleRate: 44100.000000
mFormatID: 'aac '
mChannelsPerFrame: 2
ACL: {Stereo (L R)}
结果:使用定义的输出参数成功创建.m4a
输出文件
案例 2:带有音轨参数的 .mp4 视频文件(使用 打印CMFormatDescriptionRef
):
mediaType:'soun'
mediaSubType:'aac '
mSampleRate: 48000.000000
mFormatID: 'aac '
mChannelsPerFrame: 6
ACL: {5.1 (C L R Ls Rs LFE)}
结果:转换失败,添加[AVAssetWriter appendSampleBuffer: ...]
未知样本缓冲区时error
:
Error Domain: NSOSStatusErrorDomain
code: -12780
description: The operation could not be completed
要将视频转换为音频,我使用与此处所述相同的算法:https ://github.com/rs/SDAVAssetExportSession/blob/master/SDAVAssetExportSession.m
此外,我尝试使用设置和channelLayout.mChannelLayoutTag
更新kAudioChannelLayoutTag_MPEG_5_1_D
值,但它对我不起作用。AVNumberOfChannelsKey
6
谁能帮我理解我做错了什么?可能没有解决方案可以仅使用 iOS AVFoundation 框架来执行此任务吗?我应该outputParams
为 5.1 aac 6 通道的音轨使用不同的音轨吗?