替代或延遲系結的音訊可讓您在視訊軌的可用音軌間切換。 如此,使用者就可在播放視訊時選取語言軌道。
當TVSDK建立目前視訊的MediaPlayerItem
例項時,會為每個可用的音軌建立AudioTrack
項目。 項目包含name
屬性,此字串通常包含該追蹤語言的使用者可識別描述。 項目也包含是否依預設使用該追蹤的資訊。
在播放視訊時,您可以要求提供可用音軌的清單、選擇性讓使用者選擇一個音軌,並設定視訊與選取的音軌一起播放。
雖然很少,但若在建立MediaPlayerItem
後有其他音軌可用,TVSDK會觸發MediaPlayerItem.AUDIO_UPDATED
事件。
已新增下列API以支援替代音訊:
hasAlternateAudio
如果指定的媒體具有預設音軌以外的替代音軌,則此布爾函式返回true
。 如果沒有替代音軌,函式將返回false
。
bool MediaPlayerItemImpl::hasAlternateAudio() const {
return _hasAlternateAudio;
}
getAudioTracks
此函式會傳回指定媒體中所有目前可用音軌的清單。
virtual PSDKErrorCode getAudioTracks(PSDKImmutableArray<AudioTrack>*& out) const {
if (_audioTracks) {
out = _audioTracks;
out->addRef();
return kECSuccess;
}
return kECDataNotAvailable;
}
getSelectedAudioTrack
此函式可傳回目前選取的替代音軌和屬性,例如語言。 還可以提取軌道的自動選擇。
PSDKErrorCode MediaPlayerItemImpl::getSelectedAudioTrack(AudioTrack &out) const {
out = _currentAudioTrack;
return kECSuccess;
}
selectAudioTrack
此函式會選取要播放的替代音軌。
PSDKErrorCode MediaPlayerItemImpl::selectAudioTrack(const AudioTrack &audioTrack) {
_lastPlayedAudioTrack = _currentAudioTrack;
if(_mediaPlayer && _mediaPlayer->_trickPlay)
return kECUnsupportedOperation;
_currentAudioTrack = audioTrack;
PSDKErrorCode result = kECSuccess;
if (_currentAudioTrack) {
media::TimeLine* timeline = NULL;
if (_mediaPlayer->_fragHttpStreamer)
_mediaPlayer->_fragHttpStreamer->GetTimeLine(&timeline);
if (timeline) {
for (int32_t i = timeline->GetFirstPeriodIndex(); i <= timeline->GetLastPeriodIndex(); i++){
media::ErrorCode error = selectTrack(timeline,_mediaPlayer->_fragHttpStreamer, i, audioTrack.getName(), media::kSTTAudioIndex);
return _mediaPlayer->convertToPSDKError(error);
}
}
}
return result;
}