AVAsset是一个抽象的,不可变的类,用于模拟定时视听媒体,如视频和声音。 Asset
可以包含旨在一起呈现或处理的一个或多个轨道,统一媒体类型中的每一个,包括但不限于音频,视频,文本,隐藏式字幕和字幕。
概览
AVAsset定义构成Asset
的轨道的集合属性。 (您可以访问代表集合轨道的AVAssetTrack实例,因此,如果需要,您可以单独检查每个实例。)
您通常使用AVURLAsset(一个AVAsset的具体子类)实例化一个Asset
- 使用涉及视听媒体资源(例如流(包括HTTP直播流),QuickTime电影文件,MP3文件和其他类型的文件)的URL。您还可以使用其他具体子类实例化Asset
,这些子类以有用的方式扩展视听媒体的基本模型,因为AVComposition用于临时编辑。
Asset
的属性作为一个整体由AVAsset定义。另外,可以获得对表示集合的轨道的AVAssetTrack实例的引用,使得可以独立地检查这些中的每一个。
由于定时视听媒体的性质,在Asset
成功初始化时,其密钥的一些或所有值可能不会立即可用。任何键的值可以在任何时候被请求,并且资产总是同步地返回它的值,尽管它可能必须阻塞调用线程以这样做。为了避免阻塞,您可以注册对特定键的通知,并在其值可用时收到通知。有关更多详细信息,请参阅AVAsynchronousKeyValueLoading。
要播放AVAsset的实例,使用它初始化AVPlayerItem的实例,使用播放器项目来设置其呈现状态(例如是否应该播放资源的有限时间范围等),并将播放器项目提供给根据该项目是要自己播放还是与其他项目的集合一起播放的AVPlayer对象。
您可以将AVAsset对象插入到AVMutableComposition对象中,以便从一个或多个源资产组合视听构造。
属性和方法表
| OC | Swift|备注
----|------|----|----|
创建一个Asset | + assetWithURL: |init(url: URL) |返回一个用于检查媒体资源的Asset
载入数据| - cancelLoading | func cancelLoading()|取消加载所有观察者的所有值
检查Asset | duration | var duration: CMTime|Asset的持续时间
|providesPreciseDurationAndTiming|var providesPreciseDurationAndTiming: Bool|一个布尔值,表示Asset是否提供精确的时间。
|creationDate|var creationDate: AVMetadataItem?|表示Asset的创建日期。
|preferredRate|var preferredRate: Float|Asset播放时的固有速率
|preferredTransform|var preferredTransform: CGAffineTransform|应用于Asset的可视内容以进行呈现或处理的优选变换。
|preferredVolume|var preferredVolume: Float|要播放Asset的可听媒体的优选音量。
测定可用性 |playable |var isPlayable: Bool|指示Asset或其网址是否可用于初始化AVPlayerItem的实例。
|exportable|var isExportable: Bool|一个布尔值,表示导出Asset是否可以使用
|readable|var isReadable: Bool|一个布尔值,表示是否可以使用AVAssetReader提取Asset的媒体数据。
|composable|var isComposable: Bool|一个布尔值,表示Asset是否可以在AVCompositionTrack对象的段内使用。
|hasProtectedContent|var hasProtectedContent: Bool|表示Asset是否具有受保护内容的一个布尔值。
|compatibleWithAirPlayVideo|var isCompatibleWithAirPlayVideo: Bool|表示该Asset是否与AirPlay视频兼容。
|compatibleWithSavedPhotosAlbum|var isCompatibleWithSavedPhotosAlbum: Bool|一个布尔值,表示是否可以将Asset写入“已保存的照片”相册。
访问曲目|tracks|var tracks: [AVAssetTrack]|Asset包含的所有曲目的集合。
|trackGroups|var trackGroups: [AVAssetTrackGroup]|包含Asset中所有轨道组的数组。
|- trackWithTrackID:|func track(withTrackID: CMPersistentTrackID)|返回具有指定轨道ID的轨道。
|- tracksWithMediaType:|tracks(withMediaCharacteristic: String)|返回呈现指定类型的媒体的Asset的Asset曲目的数组。
|- tracksWithMediaCharacteristic:|func tracks(withMediaCharacteristic: String)|返回呈现具有指定特征的媒体的Asset的AVAssetTrack对象的数组。
|- unusedTrackID|func unusedTrackID()|返回Asset中的任何曲目当前未使用的ID。
访问元数据|lyrics|var lyrics: String?|适用于当前语言环境的Asset的歌词。
|metadata|var metadata: [AVMetadataItem]|用于值可用的所有元数据标识符的元数据项数组。
|commonMetadata|var commonMetadata: [AVMetadataItem]|每个可用值为其的公共元数据键值的元数据项数组。
|availableMetadataFormats|var availableMetadataFormats: [String]|字符串数组,每个字符串表示Asset可用的元数据格式。
|- metadataForFormat:|func metadata(forFormat: String)|返回AVMetadataItem对象的数组,每个元素对应指定格式的容器中的每个元数据项。
使用章节元数据|availableChapterLocales|var availableChapterLocales: [Locale]|可用于Asset中章节元数据的语言环境。
|- chapterMetadataGroupsWithTitleLocale:containingItemsWithCommonKeys:|func chapterMetadataGroups(withTitleLocale: Locale, containingItemsWithCommonKeys: [String]?)|返回一个包含给定标题语言环境并包含指定键的章节数组。
|- chapterMetadataGroupsBestMatchingPreferredLanguages:|func chapterMetadataGroups(bestMatchingPreferredLanguages: [String])|返回其语言环境最佳匹配首选语言列表的章节数组。
查找选择媒体|preferredMediaSelection|var preferredMediaSelection: AVMediaSelection|此Asset的媒体选择组的默认媒体选择。
|availableMediaCharacteristicsWithMediaSelectionOptions|var availableMediaCharacteristicsWithMediaSelectionOptions: [String]|媒体选择选项可用的媒体特性数组。
|- mediaSelectionGroupForMediaCharacteristic:|func mediaSelectionGroup(forMediaCharacteristic: String)|返回包含一个或多个具有指定媒体特征的选项的AVMediaSelectionGroup对象。
管理参考限制|referenceRestrictions||