在它生效之前,我不知道问题是什么。
- (NSString *)titleForAudioFileModel:(APAudioPlayerModel *)audioFileModel {
AVPlayerItem *avItem = [AVPlayerItem playerItemWithURL:[NSURL fileURLWithPath:audioFileModel.filePath]];
NSUInteger titleIndex = [avItem.asset.commonMetadata indexOfObjectPassingTest:^BOOL(id obj, NSUInteger idx, BOOL *stop) {
AVMutableMetadataItem *metaItem = (AVMutableMetadataItem *)obj;
if ([metaItem.commonKey isEqualToString:AVMetadataCommonKeyTitle]) {
return YES;
}
return NO;
}];
if (titleIndex == NSNotFound) {
return @"";
}
AVMutableMetadataItem *item = avItem.asset.metadata[titleIndex];// Incompatible pointer types initializing 'AVMutableMetadataItem *' with an expression of type 'AVMetadataItem *'
return (NSString *)item.value;
}提前谢谢你。
发布于 2015-11-16 14:31:57
要分配给item变量的属性声明为:
@property(nonatomic, readonly) NSArray <AVMetadataItem *> *metadata这意味着编译器希望数组中的每个项都是AVMetadataItem类型的。该类是AVMutableMetadataItem的超类,不能将对超类的引用分配给子类的变量。
它以前起作用的原因可能是SDK和编译器并不总是支持泛型(属性声明中的<AVMetadataItem *> )。只要你不认为item是可变的,它就会起作用。
修复方法是要么更改item的类型,要么指定一个mutableCopy of avItem.asset.metadata[titleIndex]。
https://stackoverflow.com/questions/33737477
复制相似问题