Media3

Medya kullanım alanları için destek kitaplıkları.
Son Güncelleme Kararlı Sürüm Sürüm Adayı Beta Sürümü Alfa Sürümü
17 Aralık 2025 1.9.0 - - -

Bağımlılıkları bildirme

Media3'e bağımlılık eklemek için Google Maven deposunu projenize eklemeniz gerekir. Daha fazla bilgi için Google'ın Maven deposunu okuyun.

Uygulamanız veya modülünüz için build.gradle dosyasına ihtiyacınız olan yapılarla ilgili bağımlılıkları ekleyin:

Eski

dependencies {
    def media3_version = "1.9.0"

    // For media playback using ExoPlayer
    implementation "androidx.media3:media3-exoplayer:$media3_version"

    // For DASH playback support with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-dash:$media3_version"
    // For HLS playback support with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-hls:$media3_version"
    // For SmoothStreaming playback support with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-smoothstreaming:$media3_version"
    // For RTSP playback support with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-rtsp:$media3_version"
    // For MIDI playback support with ExoPlayer (see additional dependency requirements in
    // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md)
    implementation "androidx.media3:media3-exoplayer-midi:$media3_version"
    // For ad insertion using the Interactive Media Ads SDK with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-ima:$media3_version"

    // For loading data using the Cronet network stack
    implementation "androidx.media3:media3-datasource-cronet:$media3_version"
    // For loading data using the OkHttp network stack
    implementation "androidx.media3:media3-datasource-okhttp:$media3_version"
    // For loading data using librtmp
    implementation "androidx.media3:media3-datasource-rtmp:$media3_version"

    // For building media playback UIs using Jetpack Compose
    implementation "androidx.media3:media3-ui-compose:$media3_version"
    // For building media playback UIs using Jetpack Compose with Material Design 3
    implementation "androidx.media3:media3-ui-compose-material3:$media3_version"
    // For building media playback UIs using Views
    implementation "androidx.media3:media3-ui:$media3_version"
    // For building media playback UIs for Android TV using the Jetpack Leanback library
    implementation "androidx.media3:media3-ui-leanback:$media3_version"

    // For exposing and controlling media sessions
    implementation "androidx.media3:media3-session:$media3_version"

    // For extracting data from media containers
    implementation "androidx.media3:media3-extractor:$media3_version"

    // For inspecting media files
    implementation "androidx.media3:media3-inspector:$media3_version"

    // For integrating with Cast
    implementation "androidx.media3:media3-cast:$media3_version"

    // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer
    implementation "androidx.media3:media3-exoplayer-workmanager:$media3_version"

    // For transforming media files
    implementation "androidx.media3:media3-transformer:$media3_version"

    // For applying effects on video frames
    implementation "androidx.media3:media3-effect:$media3_version"

    // For muxing media files
    implementation "androidx.media3:media3-muxer:$media3_version"

    // Utilities for testing media components (including ExoPlayer components)
    implementation "androidx.media3:media3-test-utils:$media3_version"
    // Utilities for testing media components (including ExoPlayer components) via Robolectric
    implementation "androidx.media3:media3-test-utils-robolectric:$media3_version"

    // Common functionality for reading and writing media containers
    implementation "androidx.media3:media3-container:$media3_version"
    // Common functionality for media database components
    implementation "androidx.media3:media3-database:$media3_version"
    // Common functionality for media decoders
    implementation "androidx.media3:media3-decoder:$media3_version"
    // Common functionality for loading data
    implementation "androidx.media3:media3-datasource:$media3_version"
    // Common functionality used across multiple media libraries
    implementation "androidx.media3:media3-common:$media3_version"
    // Common Kotlin-specific functionality
    implementation "androidx.media3:media3-common-ktx:$media3_version"
}

Kotlin

dependencies {
    val media3_version = "1.9.0"

    // For media playback using ExoPlayer
    implementation("androidx.media3:media3-exoplayer:$media3_version")

    // For DASH playback support with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-dash:$media3_version")
    // For HLS playback support with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-hls:$media3_version")
    // For SmoothStreaming playback support with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-smoothstreaming:$media3_version")
    // For RTSP playback support with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-rtsp:$media3_version")
    // For MIDI playback support with ExoPlayer (see additional dependency requirements in
    // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md)
    implementation("androidx.media3:media3-exoplayer-midi:$media3_version")
    // For ad insertion using the Interactive Media Ads SDK with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-ima:$media3_version")

    // For loading data using the Cronet network stack
    implementation("androidx.media3:media3-datasource-cronet:$media3_version")
    // For loading data using the OkHttp network stack
    implementation("androidx.media3:media3-datasource-okhttp:$media3_version")
    // For loading data using librtmp
    implementation("androidx.media3:media3-datasource-rtmp:$media3_version")

    // For building media playback UIs using Compose
    implementation("androidx.media3:media3-ui-compose:$media3_version")
    // For building media playback UIs using Views
    implementation("androidx.media3:media3-ui:$media3_version")
    // For building media playback UIs using Jetpack Compose
    implementation("androidx.media3:media3-ui-compose:$media3_version")
    // For building media playback UIs for Android TV using the Jetpack Leanback library
    implementation("androidx.media3:media3-ui-leanback:$media3_version")

    // For exposing and controlling media sessions
    implementation("androidx.media3:media3-session:$media3_version")

    // For extracting data from media containers
    implementation("androidx.media3:media3-extractor:$media3_version")

    // For integrating with Cast
    implementation("androidx.media3:media3-cast:$media3_version")

    // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer
    implementation("androidx.media3:media3-exoplayer-workmanager:$media3_version")

    // For transforming media files
    implementation("androidx.media3:media3-transformer:$media3_version")

    // For applying effects on video frames
    implementation("androidx.media3:media3-effect:$media3_version")

    // For muxing media files
    implementation("androidx.media3:media3-muxer:$media3_version")

    // Utilities for testing media components (including ExoPlayer components)
    implementation("androidx.media3:media3-test-utils:$media3_version")
    // Utilities for testing media components (including ExoPlayer components) via Robolectric
    implementation("androidx.media3:media3-test-utils-robolectric:$media3_version")

    // Common functionality for reading and writing media containers
    implementation("androidx.media3:media3-container:$media3_version")
    // Common functionality for media database components
    implementation("androidx.media3:media3-database:$media3_version")
    // Common functionality for media decoders
    implementation("androidx.media3:media3-decoder:$media3_version")
    // Common functionality for loading data
    implementation("androidx.media3:media3-datasource:$media3_version")
    // Common functionality used across multiple media libraries
    implementation("androidx.media3:media3-common:$media3_version")
    // Common Kotlin-specific functionality
    implementation("androidx.media3:media3-common-ktx:$media3_version")
}

Bağımlılıklar hakkında daha fazla bilgi için Derleme Bağımlılıkları Ekleme başlıklı makaleyi inceleyin.

Geri bildirim

Geri bildiriminiz Jetpack'in iyileştirilmesine yardımcı olur. Sorulara, bilinen sorunlara ve özellik isteklerine yanıt bulmak, ayrıca yeni sorunlar bildirmek için Media3 sorun izleyicisini kullanabilirsiniz.

Sürüm 1.9.0

1.9.0

17 Aralık 2025

  • Ortak kitaplık:
    • Diğer AndroidX kitaplıklarıyla uyumlu olması için minSdk sürümünü 23 olarak güncelleyin.
    • Oynatma durumunun Player örnekleri arasında aktarılmasını kolaylaştıran PlayerTransferState işlevi eklendi.
    • void mute() ve void unmute() yöntemlerini, Player'ın sesini sıfıra ayarlamadan önce ve sonra koruyup geri yükleyen Player'a ekleyin.
    • Daha önce ExoPlayer tarafından dahili olarak kullanılan WakeLockManager, WifiLockManager, AudioFocusManager, AudioBecomingNoisyManager ve StuckPlayerDetector yardımcı sınıflarını yayınlayarak diğer oyuncular tarafından yeniden kullanılmalarını sağlayın (#1893).
    • Temel temsilci oynatıcı, dinleyici örneklerini karşılaştırmak için referans eşitliğini kullandığında ForwardingPlayer dinleyici işleme sorununu düzeltin (#2675).
    • Üzerinde işlem yapılması gereken belirli Player.Events öğesini belirten Player.listenTo askıya alma uzantısı işlevi ekleyin.media3-common-ktx
    • Bildirilen arabelleğe alınmış konum, bildirilen süreden çok daha uzun olduğunda BasePlayer.getBufferedPercentage içinde tamsayı taşmasından kaynaklanan kilitlenme düzeltildi (#2750).
    • Özel örnek MIME türünü yoksaymayarak ve kapsayıcı MIME türünden potansiyel olarak yanlış parça türünü kullanmaya geri dönerek TrackGroup parça türünün otomatik olarak algılanması düzeltildi (#2860).
  • ExoPlayer:
    • Oynatıcının takılıp kaldığı algılandığında StuckPlayerException oynatıcı hatasını tetikleyen bir algılama özelliği eklendi. Bu durum aşağıdaki durumlarda meydana gelir. Gerekirse her varsayılan zaman aşımı ExoPlayer.Builder bölümünde yapılandırılabilir:
      • Oynatmaya çalışırken 10 dakika boyunca STATE_BUFFERING simgesi gösteriliyor ve arabelleğe alma işlemi ilerlemiyor.
      • Oynatmaya çalışırken 10 saniye boyunca STATE_READY simgesi gösteriliyor ve oynatma ilerlemiyor.
      • Öğenin sonuna ulaşılmadan, belirtilen sürenin STATE_READY dakika aşılması.
      • Oynatma sırasında 10 dakika boyunca oynatma engelleme nedeni gösterildikten sonra.
    • Arka planda oynatma sırasında arabelleğe alma ile ilgili sorunları düzeltmek için uyandırma kilidi işlemeyi varsayılan olarak etkinleştirin. Bu, ExoPlayer.Builder.setWakeMode öğesini C.WAKE_MODE_LOCAL olarak ayarlamaya eşdeğerdir.
    • Başlangıçta Context öğesine iletilen ExoPlayer.Builder öğesinde bir değişiklik bildirildiğinde sanal cihaz kimliğini otomatik olarak güncelleyecek dinleme mantığı ekleyin.
    • ExoPlayer.setVirtualDeviceId, ExoPlayer.Builder'ye aktarılan Context'den alınan sanal cihaz kimliğini manuel olarak güncellemek için ekleyin.
    • Oluşturucuların, geçerli öğenin bitiminden 10 saniye önce sonraki oynatma listesi öğesinden veri tüketmediğinden emin olun.
    • İnşaat tamamlandıktan sonra bu ayarları güncellemek için setSeekBackIncrementMs, setSeekForwardIncrementMs ve setMaxSeekToPreviousPositionMs öğelerini ExoPlayer'e ekleyin (#2736).
    • DefaultPreloadManager'e önbelleğe alma işlevi ekleyin. Uygulamalar artık DefaultPreloadManager.PreloadStatus.specifiedRangeCached(startPositionMs, durationMs) veya DefaultPreloadManager.PreloadStatus.specifiedRangeCached(durationMs) döndürebilir TargetPreloadStatusControl.getTargetPreloadStatus(T rankingData) aracılığıyla bir medya öğesinin önceden önbelleğe alınması gerektiğini belirtmek için.
    • Shorts demo uygulamasında DefaultPreloadManager'nın önden belleğe alma işlevini kullanın.
    • Yerel oynatma için DefaultLoadControl.Builder ayarlayıcıları ekleyin ve DefaultLoadControl varsayılan değerlerini çok çeşitli yerel dosyalarla iyi çalışacak şekilde ayarlayın.
    • Boş bir oynatma listesi ayarlamanın oynatıcıyı STATE_READY veya STATE_BUFFERING durumunda bırakabildiği hata düzeltildi.
    • Ön yükleme yöneticisi API'lerini geliştirin:
      • Medya öğelerini veya medya kaynaklarını toplu olarak ekleyen ve ardından invalidate() işlevini otomatik olarak çağıran addMediaItems(List<MediaItem>, List<T>) ve addMediaSources(List<MediaSource>, List<T>) işlevlerini ekleyin.
      • Medya öğelerini veya medya kaynaklarını toplu olarak kaldıran removeMediaItems((List<MediaItem>) ve removeMediaSources(List<MediaSource>) ekleyin. Ayrıca, önceden yükleme yöneticisinin, kaldırılan öğeleri önceden yüklemeye başlamadığından veya önceden yüklemeye devam etmediğinden emin olun.
      • DefaultPreloadManager.setCurrentPlayingIndex(int) cihazının kendini otomatik olarak geçersiz kılmasına izin verin. Uygulamaların, mevcut oynatma dizinini güncelledikten sonra artık invalidate() işlevini açıkça çağırması gerekmez.
    • Fırçalama modundayken aynı resim grubunda ileri sarma işlemlerinde animasyon karesi sıfırlamayı atlama özelliği eklendi.
    • Belirtilen playerName ile bir oynatıcı için hedef arabellek baytlarının değerini ayarlamak üzere uygulamalara DefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int) ekleyin. DefaultLoadControl artık her oyuncunun kararlarını, ayrılan baytlarına ve hedef arabellek baytlarına göre ayrı ayrı verebilir.
    • Reklam grubundaki her reklam için atlama bilgilerini taşımak üzere SkipInfo öğesini AdPlaybackState.AdGroup öğesine ekleyin.
    • Bir yayın sonrası reklam oynatılırken removeMediaItems(List)'ı aramanın kilitlenmeye neden olduğu hata düzeltildi (#2746).
    • Oynatma listesi oynatılırken karelerin yanlışlıkla her zaman son örnek olarak ayarlanıp oluşturulması nedeniyle yaşanan takılma sorunu düzeltildi.
    • Oynatıcı ses oturumu kimliği oluşturamazsa yeniden deneme yolunu etkinleştirme (#2382, #2678).
    • Ön yükleme için toplam arabellek baytlarının rastgele büyümesini önlemek amacıyla DefaultPreloadManager içindeki kaynakların toplam arabellek baytlarını kontrol etme desteği ekleyin. Varsayılan kontrol mantığını kullanmak için uygulamalar, DefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int) aracılığıyla önceden yükleme için hedef arabellek baytlarını PlayerId.Preload.name playerName'si ("preload") olarak ayarlayabilir ve oluşturulan DefaultLoadControl'yi DefaultPreloadManager.Builder.setLoadControl(LoadControl) aracılığıyla yerleştirebilir.
    • Varsayılan bir uygulama ile cloneAndSet(int, int) öğesini ShuffleOrder öğesine ekleyin (#2834).
    • Arama ayarlamasından veya otomatik geçişten sonra reklam oynatmayı atladığınızda içeriğin devam ettirileceği noktayı ekleyin (#2484).
    • Ses ve video parçaları için codec parametrelerini ayarlamak ve gözlemlemek üzere API ekleyin. Bu özellik, MediaCodec tabanlı oluşturucular için uygulanır ve API 29 veya sonraki sürümleri gerektirir.
      • Parametreleri uygulamak için ExoPlayer.setAudioCodecParameters() ve ExoPlayer.setVideoCodecParameters() özelliklerini kullanın.
      • Değişiklikleri dinlemek için ExoPlayer.addAudioCodecParametersChangeListener() ve ExoPlayer.addVideoCodecParametersChangeListener() özelliklerini kullanın. Tedarikçiye özel anahtarların gözlemlenmesi için API 31 veya sonraki sürümler gerekir.
    • Sıfır olmayan bir konuma gidildikten sonra boş bir medya kaynağı ayarlanması ve ardından oynatıcının boş olmayan bir medya kaynağıyla hazırlanması nedeniyle oluşan IllegalStateException sorunu düzeltildi.
    • Sarma modundayken diğer medya öğelerinde arama yapmanın IllegalStateException'ya neden olabildiği hata düzeltildi.
    • DefaultPlaybackSessionManager içinde olası NullPointerException sorununu düzeltin (#2885).
    • Uygun videolarda arama performansını iyileştirmeyi etkinleştirin.
    • Bu platform API'siyle ilgili zaman aşımı sorunlarının düzeltildiği API 36 ve sonraki sürümlerde MediaCodec'te eşzamansız şifre çözme kullanımını yeniden etkinleştirin (#1641).
    • MediaCodecVideoRenderer.experimentalSetLateThresholdToDropDecoderInputUs öğesinin varsayılan değerini 15 ms olarak değiştirin ve uygun videolarda kod çözme işleminden önce video karelerinin daha verimli şekilde bırakılmasını sağlayın.
    • DefaultLoadControl bölümündeki otomatik bellek hesaplamasına maksimum bellek sınırı ekleyin. Bu yalnızca aşırı sayıda parça seçildiğinde geçerli olmalıdır (#2860).
    • Oynatma listesinde veya tekrarlama modunda oynatılırken, sonlara doğru hızlıca ileri veya geri sarma modunda arama yapıldığında bir sonraki medya öğesine arama yapılmasına neden olan hata düzeltildi.
  • CompositionPlayer:
    • Deneme için kullanıma sunulduğunu ancak geliştirme aşamasında olduğunu belirtmek üzere CompositionPlayer, yeni bir @ExperimentalApi ek açıklaması altında yayınlayın. Bazı API'lerin gelecekteki sürümlerde önemli ölçüde değişmesi muhtemeldir. Ayrıca bazı kullanım alanlarıyla ilgili bilinen sorunlar ve sınırlamalar (bazıları belgelenmemiştir) vardır.
    • CompositionPlayer'da COMMAND_SET_AUDIO_ATTRIBUTES ve ses odağı işleme desteği eklendi.
    • CompositionPlayer'daki ikincil sıralarda hız değiştirme desteği eklendi.
    • EditedMediaItem.removeVideo için destek ekleyin.
  • Dönüştürücü:
    • Varsayılan muxer olarak InAppMp4Muxer kullanın.
    • EditedMediaItem.Builder#setSpeed() eklendi ve Effects#createExperimentalSpeedChangingEffects() desteği sonlandırıldı.
    • forceAudioTrack ve forceVideoTrack öğelerini trackTypes ile değiştirin. EditedMediaItemSequence
  • Parça Seçimi:
    • Diğer daha spesifik tercihleri belirtmeden herhangi bir metin parçasının seçilmesini tercih etmek için TrackSelectionParameters.selectTextByDefault ekleyin.
    • preferredVideoLabels, preferredAudioLabels ve preferredTextLabels öğelerini TrackSelectionParameters içine ekleyerek belirli bir etikete sahip parçalarla ilgili tercihi (ör. HLS NAME etiketlerinden okunanlar) belirtebilirsiniz (#1666).
  • Ayıklayıcılar:
    • FLAC: Kodlanmış FLAC verilerinde sahte üstbilgilerin bulunma ihtimalini azaltmak için üstbilgi algılamayı sıkılaştırın. Bu, kod çözme hatalarına neden olur (#558).
    • MP3: MP3 dosyalarının başında ID3 etiketleri arasında (ve öncesinde) boşluklara izin verin (#811,#5718).
    • MP3: Bir senkronizasyon baytı için mevcut arama sınırıyla eşleşecek şekilde koklama sınırını 128 kB'ye yükseltin (#2713).
    • MP3: FLAG_ENABLE_INDEX_SEEKING değerini, varsa meta veri üstbilgilerinden (Xing ve VBRI gibi) bilgi aramayı tercih edecek şekilde değiştirin. Başka arama bilgisi yoksa dizine dayalı aramaya geri dönülür. Bu, arama meta verileri içeren dosyaların performansını artırır (#2839).
    • MP3: Arama meta verileri (ör.Mp3Extractor Xing, VBRI) bulunsa bile FLAG_ENABLE_INDEX_SEEKING ayarlanmış olsa bile. Bu, CBR'nin standart olduğu ve VBR'nin açık başlıklar gerektirdiği MP3 spesifikasyon geçmişine dayanmaktadır. Bu işlem, meta verileri olmayan dosyaların anında aranabilirliğini artırır. Ancak başlıkları olmayan VBR dosyalarının doğruluğu düşebilir. CBR varsayımı aranabilir değilse (ör. uzunluğu bilinmeyen akışlar için) artık dizin arama yedek olarak kullanılır (#2848).
    • MP4: Ayıklayıcıdan bir parça biçimi yayınlamadan önce ilk örneğin katman değerine göz atarak audio/mpeg (MP3), audio/mpeg-L1 ve audio/mpeg-L2 MIME türleri arasında ayrım yapın (#2683).
    • MP4: 1 MB'tan büyük bir stbl kutusunun, dosyanın parçalanmamış olması gerektiği anlamına geldiğini varsayarak çok büyük dosyaların koklama verimliliğini artırın (#2650).
    • MP4: ©mvn (hareket adı) ve ©mvi (hareket dizini) meta verileri için destek eklendi. Bu meta veriler artık MVNM ve MVIN kimlikleriyle Format.metadata içinde TextInformationFrame nesneleri olarak yayınlanıyor (#2754).
    • MP4: Eksik stsd kutusu olan parçaları yok sayın (dosyanın tamamını ayrıştırmayı başaramamak yerine).
    • Matroska: DTS-HD algılama desteği eklendi (#6225).
    • MatroskaExtractor'da, birden fazla parça içeren dosyalarda arama işleminin yanlış olmasına neden olan sorun düzeltildi. İşaret noktaları artık ilgili parçalarıyla doğru şekilde ilişkilendiriliyor. Bu sayede daha hassas bir şekilde arama yapılabiliyor.
    • MPEG-TS: Zaman damgası olmayan PES paketlerinin neden olduğu IllegalArgumentException ile ReorderingBufferQueue arasındaki IllegalArgumentException düzeltildi (#2764).
    • HEIC hareketli fotoğrafları ayıklama desteği eklendi. HeifExtractor artık yerleştirilmiş video ve ses kanalları içeren HEIC dosyalarını ayrıştırabilir.
  • İnceleyici:
    • Medya inceleme yardımcı programları için özel bir ana sayfa görevi görecek yeni bir :media3-inspector modülü kullanıma sunuldu. Bu modülde artık yeni bir androidx.media3.inspector.MetadataRetriever bulunuyor. Bu androidx.media3.inspector.MetadataRetriever, hem meta veri hem de çerçeve çıkarma için birleşik bir API sağlayacak. Mevcut androidx.media3.exoplayer.MetadataRetriever, bu yeni sürüm lehine kullanımdan kaldırıldı.
    • Kare çıkarma için yeni bir herkese açık API olan androidx.media3.inspector.FrameExtractor kullanıma sunuldu. Bu AutoCloseable sınıfı, HDR video, video efektleri ve özel kod çözücü seçimi desteğiyle kareleri ayıklamanın bir yolunu sunar. Belirli bir MediaItem için Builder aracılığıyla oluşturulmalıdır.
    • FrameExtractor: Belirli bir zaman damgası gerektirmeden bir medya dosyasından temsili bir küçük resim karesi çıkarmak için getThumbnail() ekleyin.
    • androidx.media3.inspector.MediaExtractorCompat adlı bir kitaplık ekleyin. Bu kitaplık, platformun android.media.MediaExtractor yerine kullanılabilen ve medya dosyasından ham, kodlanmış medya örnekleri ayıklama olanağı sağlayan bir kitaplıktır. Mevcut androidx.media3.exoplayer.MediaExtractorCompat, bu yeni sınıf lehine artık kullanımdan kaldırılmıştır.
  • Ses:
    • AudioProcessor örneklerinin arama işleminden haberdar olmasını sağlayın.
    • Özel ses çıkışı yollarını desteklemek için yeni AudioOutputProvider arayüzünün DefaultAudioSink.Builder içine yerleştirilmesine izin verin. Varsayılan değer AudioTrackAudioOutputProvider'dır.
    • GainProcessor uygulamasında arama çubuğuyla arama yapma
    • Parça biçimindeki AC-4 kod çözücü profilini ve düzey özelliklerini kullanma destek değerlendirmesi (#2580).
    • Oynatma başlangıcında yönlendirme değişikliği geri aramalarının işlenmesinden kaynaklanan olası gecikmeleri önleyin (#2646).
    • EAC3, EAC3-JOC ve AC-4 biçimleri için codec'in yeniden kullanılmasına izin verin (#1346).
    • Sonic içinde kayan nokta PCM örnekleri için destek ekleyin.
    • ToFloatPcmAudioProcessor'da 16 bit PCM örnekleri için destek ekleyin.
  • Video:
    • Farklı profillere sahip Dolby Vision içeriklerinde codec'in yeniden kullanılmasını devre dışı bırakın.
    • Güvenli codec'ler için yanlış bildirilen performans noktalarıyla ilgili geçici çözümü yeniden etkinleştirme (#2856).
  • Metin:
    • Dolby Vision içeriklerinde CEA-6/708 altyazılarının ayrıştırılması düzeltildi (#2775).
  • Resim:
    • DASH küçük resim parçası üzerinde kaydırma yapılırken oynatıcının takılmasına neden olan ScrubbingMode sorunu düzeltildi (#2815).
  • DRM:
    • Ek isteğe bağlı bilgilerin döndürülmesine izin vermek için MediaDrmCallback yöntemlerinin dönüş türünü byte[]'den yeni bir MediaDrmCallback.Response türüne değiştirin. Bu, kaynağı bozan bir değişikliktir ancak önceki byte[] dönüş değerini döndürmeden önce new Response ile sarmalayarak bozulmalar kolayca çözülebilir.
    • URL ve gecikme gibi önemli istek bilgilerini AnalyticsListener.onDrmKeysLoaded (#1001) numaralı hata koduna ekleyin.
    • Temel hazırlık isteği verilerini URL parametresinden POST gövdesine taşıyın.
  • Etki:
    • Presentation tek bir kenar uzunluğuyla oluşturulduğunda ayarlanmamış çıkış kenarını yuvarlamak için Presentation.copyWithUnsetSideRoundedTo ekleyin.
  • Muxers:
    • MediaMuxerCompat (framework MediaMuxer için doğrudan değiştirme) eklendi.
    • Hareketli fotoğraf oluşturmaya izin vermek için MuxerUtil.createMotionPhotoFromJpegImageAndBmffVideo() ekleyin.
    • WebmMuxer, OPUS, VORBIS, VP8 ve VP9 medya akışlarının webm dosya biçiminde çoklanmasına izin vermek için ekleyin.
  • IMA uzantısı:
    • Özel ProGuard kurallarının kaldırılması. Böylece uygulamalar, bunun yerine IMA Android arşivinde yayınlanan kuralları kullanabilir.
    • IMA SDK'nın reklam tanımlayıcılarını Google Ad Manager ayarlarında belirtildiği şekilde işlemesi için Google Ad Manager ağ kodunu ayarlamaya yönelik yeni bir API olan ImaServerSideAdInsertionUriBuilder.setNetworkCode'yı ekleyin. Ağ kodları isteğe bağlıdır ancak tam hizmet akışı istekleri için önerilir. Ağ kodunu bulmak için bu makaleyi inceleyin.
    • IMA bağımlılığını 3.37.0 sürümüne yükseltin. Bu sürümde temel kitaplıkta desugaring'in etkinleştirilmesi gerekir. Bu, bağımlı uygulamalar tarafından da etkinleştirilmelidir. IMA'nın config notes bölümüne bakın. * SSAI URI oluşturucuda IMA DAI özel kullanıcı arayüzü seçenekleri desteklenir. Sunucu taraflı reklam ekleme için özel kullanıcı arayüzü seçenekleri arasında "Atlanabilir" ve "Bu Reklam Hakkında" oluşturma desteği yer alır. Bu özellik şu anda izin verilenler listesindeki belirli yayıncılar tarafından kullanılabilir. Bu değişiklik, özel kullanıcı arayüzü seçenekleri API'sine erişmek için IMA SDK sürümünü 3.38.0'a (sürüm notları) da yükseltir.
    • Reklamdan sonraki içerik için içerik hazırlama hatasının yanlışlıkla reklam oynatma hatası olarak bildirilmesine neden olan sorun düzeltildi (#2656).
  • Oturum:
    • Aramanın yalnızca bilgi toplamak için mi yoksa oynatmayı başlatmak için mi yapıldığını belirtmek üzere MediaSession.Callback.onPlaybackResumption parametresine yeni parametre eklendi (#1764).
    • MediaSession.ControllerInfo.isTrusted, kendi uygulamasındaki denetleyicileri de güvenilir olarak bildirecek şekilde güncellendi (#2542).
    • Bildirim güncellemesini manuel olarak tetiklemek için MediaSessionService.triggerNotificationUpdate simgesini ekleyin (#1833).
    • Özel komut yöntemlerine ProgressListener ekleyin.
    • MediaLibrarySession.Builder.setLibraryErrorReplicationMode için varsayılan değeri ölümcül olmayan olarak değiştirin.
    • Context parametresini MediaButtonReceiver.onForegroundServiceStartNotAllowedException öğesine ekleyin MediaButtonReceiver.onForegroundServiceStartNotAllowedException (#2625).
    • Cilt aracılığıyla getirmek yerine PlaybackInfo platformundan ses kontrolü kimliğini okuyun. Bu sayede, oynatma türü ve ses kontrolü kimliğinin atomik olarak okunması ve birbirleriyle eşleşmesi sağlanır.
    • ACTION_UP önemli etkinliklerinin, özel işleme için geri çağırma işlevine iletilmeden önce filtrelendiği hata düzeltildi. Bu, media1'in yaptığı ve platformun yaptığı işlemlerle eşitlik sağlar (#2637).
    • Komut kullanılamadığında bile getCurrentTimeline() işlevinin PlayerWrapper tarafından çağrılması hatası düzeltildi (#2665).
    • Bir mesajın ana döngüleyicinin mesaj kuyruğunda bırakılması nedeniyle hizmet sonlandırıldıktan sonra bellek sızıntısına neden olan hata düzeltildi (#2692).
    • MediaBrowser ile eski bir oturum uygulamasına bağlandığında, özel komutlar yalnızca özel işlem, eski oturumun PlaybackStateCompat bölümünde özel işlem olarak tanıtılıyorsa oturuma gönderilir. Diğer tüm özel işlemler hizmete gönderilir.
    • Oturum tarafından bir ses oturumu kimliği ayarlandığında medya denetleyicilerini bilgilendirmek için onAudioSessionIdChanged uygulandı (#244).
    • KEYCODE_HEADSETHOOK ve onStartCommand()'ye medya tuşu etkinliği Intent geldiğinde oynatıcının başlatılamamasına neden olan hata düzeltildi. Bu sorun, "KEYCODE_HEADSETHOOK" öğesini KEYCODE_MEDIA_PLAY_PAUSE gibi işleyerek düzeltildi (#2816).
    • Oturum ile denetleyici arasında Surface boyutunun iletilmemesi nedeniyle demo oturumunda video efektlerinin uygulanamamasına neden olan hata düzeltildi. Kumanda kullanıyorsanız ve oynatıcınız setVideoSurfaceHolder çağrısını işleyemiyorsa bu değişiklik, oynatıcınızın çalışmasını engelleyebilir.
    • String CharSequence olmayan meta veri değerlerinin (ör. span stilinde dizeler) yayılmasını düzeltme ( #2853).
    • Denetleyicilerin amaçlanan işlemi daha kolay tetikleyebilmesi için CommandButton.executeAction ekleyin. Ayrıca, hangi işlemin tetikleneceğini tanımlamak için bazı oynatıcı ve oturum komutlarının parametrelerinin belirtilmesine de izin verilir.
    • CommandButton örnekleri için geriye dönük uyumluluk ekleyin. Bu örnekler, işlemlerini tanımlamak için Player.Command veya özel olmayan SessionCommand kullanır. Bunlar artık platform medya oturumlarında (ör. Sistem Kullanıcı Arayüzü veya Android Auto) doğru şekilde gösteriliyor.
    • MediaController, platform medya oturumuna bağlanırken aynı Bitmap öğesinin birden çok kez sıkıştırılması sorunu düzeltildi.
  • UI:
    • ProgressStateWithTickInterval sınıfını ve ilgili rememberProgressStateWithTickInterval Composable'ı media3-ui-compose modülüne ekleyin. Bu durum tutucu, demo-compose içinde geçerli konumu ve süreyi metin biçiminde göstermek için kullanılır.
    • Player sesinin kapatılmasını sağlayan ui-compose öğesine MuteButtonState ekleyin. Bu durum tutucu, demo-compose içinde sessize alma/sesi açma açma/kapatma düğmesini göstermek için kullanılır.
    • ProgressStateWithTickCount sınıflarını ve bunlara karşılık gelen rememberProgressStateWithTickCount Composable'ı media3-ui-compose modülüne ekleyin. Bu durum tutucu, demo-compose içinde ilerlemeyi yatay, salt okunur bir ilerleme çubuğu olarak göstermek için kullanılır.
    • ContentFrame Composable'ı, PlayerSurface yönetimini en boy oranı yeniden boyutlandırma ve örtü ile birleştiren media3-ui-compose'ye ekleyin.
    • API 34 platformunda, Compose AndroidView içinde SurfaceView kullanılırken videoların uzamasına/kırpılmasına neden olan ve dolayısıyla ContentFrame ile PlayerSurface composable'larını SURFACE_TYPE_SURFACE_VIEW ile etkileyen bilinen bir hatayı geçici olarak çözme (#1237, #2811).
    • Yeni bir media3-ui-compose-material3 modülü oluşturun ve bu modüle Material3 temalı Composables'ı (PlayPauseButton, NextButton, PreviousButton, SeekBackButton, SeekForwardButton, RepeatButton, ShuffleButton, MuteButton) ekleyin.
    • Oyuncunun ilerleme durumunu metin biçiminde göstermek için TimeText composable'ı media3-ui-compose-material3 öğesine ekleyin. Mevcut konumu, süreyi veya kalan süreyi gösterecek şekilde yapılandırılabilir.
    • PlayerView konumuna medya rotası düğmesi yerleştirme desteği eklendi.
    • Sağdan sola yazılan metinlerdeki noktalama işaretlerini doğru şekilde göstermek için BidiFormatter kullanın (#11214).
  • HLS uzantısı:
    • HLS geçiş reklamı atlama özelliklerini ayrıştırın.
    • HLS oynatma listesindeki ve öğe listesi dokümanındaki atlama kontrolü özelliklerini, herkese açık erişim için AdPlaybackState ile eşleyin.
    • Başlangıç zamanını tanımlayan EXT-X-PROGRAM-START-DATE etiketi bir oynatma listesinden kaldırıldığında oynatma listesinin başlangıç zamanının düşmesine neden olan hata düzeltildi (#2760).
    • Oynatma listesindeki belirli bir konumun segment dizinini bulmak için ikili arama kullanma (#2826).
    • HlsInterstitialsAdsLoader.skipCurrentAd() ve skipCurrentAdGroup() ile reklamları ve reklam gruplarını dizine göre atlamak için ilgili yöntemleri ekleyin.
    • Bir reklam döneminin başlangıcını bildirmek için HlsInterstitialsAdsLoader.Listener.onAdStarted ekleyin (#2859).
    • ISO 8601 tarih-saat dizelerinde tarih/saat ayırıcı olarak boşluğu kabul edin.
    • Segment içermeyen bir HlsMediaPlaylist için sonraki parçanın getirilmesini düzgün şekilde işleyin (#2821).
    • Canlı yayınlarda videodan önce gösterilen reklamlar için varsayılan başlangıç konumunu kullanın.
  • DASH uzantısı:
    • Hiyerarşik olmayan data: URI manifestiyle DASH akışları oynatılırken UnsupportedOperationException sorununu düzeltin (#2688).
    • LiveConfiguration, yayınlandığında ve medya öğesi kullanıcı tarafından güncellendiğinde DashMediaSource'nin MediaItem tarafından sağlanan değere sıfırlanır (#2606).
    • Geçersiz manifest güncellemelerinin neden olduğu ve oynatıcı hatası olarak bildirilmeyen kilitlenmeleri önleyin (#2805).
  • RTSP uzantısı:
    • H264 ve H265 için parçalanmış NAL birimleri işlenirken eksik RTP paketlerinin hatasını işleme (#2613).
  • Kod çözücü uzantıları (FFmpeg, VP9, AV1 vb.):
    • AV1 Uzantısı: AV1 yazılım kod çözücüsü artık yüksek performanslı dav1d kitaplığını kullanıyor. Bu kitaplık, kod çözme hızını artırmak için önceki libgav1 uygulamasının yerini alıyor.
    • FFmpeg uzantısı: STREAMINFO bloğunun doğru şekilde ayrıştırılıp kod çözücüye aktarılmasını sağlayarak bazı FLAC dosyalarının oynatılmasını engelleyen sorun düzeltildi (#2887).
  • Yayın uzantısı:
    • CastPlayer.Builder ekleyin. Bu, CastPlayer cihazının hem yerel hem de Cast oynatma yapmasını sağlar. Yalnızca Cast oynatmayı destekleyen eski CastPlayer davranışını korumak için RemoteCastPlayer kullanabilirsiniz. Önceden var olan CastPlayer oluşturucular eski davranışlarını korur ancak bunun yerine CastPlayer veya RemoteCastPlayer oluşturucularının kullanılması önerilir.
    • DefaultMediaItemConverter içinde boş olmayan bir MIME türünün zorunlu kılınmasını durdurun.
    • Kullanılabiliyorsa DefaultCastOptionsProvider#toMediaQueueItem içinde kullanılacak Cast MEDIA_TYPE'ı belirlemek için MediaItem.mediaMetadata.mediaType öğesini kullanın.
    • DefaultCastOptionsProvider uygulamasında uzaktan yerel aktarımları etkinleştirin.
    • Oturum demosunda Cast desteği eklendi.
    • Composable kullanıcı arayüzünde medya rotası düğmesinin gösterilmesi için destek ekleyin.
    • İşlem çubuğu menüsünde medya rotası düğmesi görüntüleme desteği eklendi.
    • Medya rotası düğmesinin View kullanıcı arayüzü olarak gösterilmesi için destek eklendi.
  • Test yardımcı programları:
    • FakeClock için otomatik ilerleme davranışına maksimum zaman farkı ekleyin. Varsayılan olarak 1 saniyedir ancak FakeClock.Builder aracılığıyla yapılandırılabilir.
    • RobolectricUtil.runMainLooperUntil (ve runLooperUntil) için iletiler arasındaki maksimum zaman farkını ekleyin. Varsayılan olarak 1 saniyedir ancak bu yöntemlerin yeni aşırı yüklemeleri aracılığıyla yapılandırılabilir.
    • CapturingRenderersFactory tutarındaki bütçe, test-utils kampanyasından test-utils-robolectric kampanyasına aktarılacak.
  • Desteği sonlandırılan sembolleri kaldırın:
    • Desteği sonlandırılan DefaultPreloadManager oluşturucusunu kaldırın. Bunun yerine DefaultPreloadManager.Builder kullanın.
    • Kullanımdan kaldırılan EditedMediaItemSequence oluşturucuları kaldırıldı. Bunun yerine EditedMediaItemSequence.Builder kullanın.
    • BitmapFactoryImageDecoder.BitmapDecoder öğesini kaldırın. Bunun yerine ExternallyLoadedImageDecoder kullanın.
    • Kullanımdan kaldırılan ShadowMediaCodecConfig.forAllSupportedMimeTypes() öğesini kaldırın. Bunun yerine ShadowMediaCodecConfig.withAllDefaultSupportedCodecs() politikasını kullanın.
    • Kullanımdan kaldırılan ShadowMediaCodecConfig.withNoDefaultSupportedMimeTypes() öğesini kaldırın. Bunun yerine ShadowMediaCodecConfig.withNoDefaultSupportedCodecs() kullanın.

1.9.0-rc01

1 Aralık 2025

1.9.0 kararlı sürümünü kullanın.

1.9.0-beta01

20 Kasım 2025

1.9.0 kararlı sürümünü kullanın.

1.9.0-alpha01

22 Ekim 2025

1.9.0 kararlı sürümünü kullanın.

Sürüm 1.8.0

Sürüm 1.8.0

30 Temmuz 2025

1.8.0 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • ForwardingSimpleBasePlayer içinde oyuncu değişikliği yapma desteği eklendi.
  • ExoPlayer:
    • Karışık çalma modu için ExoPlayer arayüzüne getter ekleyin (#2522).
    • DefaultAudioSink öğesine birden fazla iş parçacığından erişilirse daha net bir şekilde istisna oluşturulur. Bu durum, oynatıcı dışında RendererCapabilities.getFormatSupport çağrısından kaynaklanıyorsa bu yöntemi ExoPlayer'ın oynatma iş parçacığıyla aynı iş parçacığında çağırdığınızdan veya oynatma için kullanılan örnekten farklı bir örnek kullandığınızdan emin olun (#1191).
    • TV'lerdeki stereo olmayan ses biçimlerinin DefaultTrackSelector tarafından desteklenmiyor olarak işaretlenmesi hatası düzeltildi.
    • MediaCodec'in DECODE_ONLY işaretini (varsayılan olarak sarma modunda etkindir) kullanırken son karenin doğru şekilde oluşturulduğundan emin olun.
    • Context öğesinden ExoPlayer.Builder öğesine iletilen sanal cihaz kimliğinin kullanılması için destek eklendi.
    • Sarma modunda dinamik planlamayı varsayılan olarak etkinleştirin.
    • Bir öğenin sonuna gitmeye çalışırken kaynağın gereksiz yere yeniden yüklenmesini önleyin.
    • Sarma modunda varsayılan olarak MediaCodec.BUFFER_FLAG_DECODE_ONLY uygulamasını kullanın.
    • Önceden yükleme iş parçacığından farklı bir oynatma iş parçacığına sahip bir ExoPlayer tarafından PreloadMediaSource oynatıldığında IllegalStateException oluşturulur (#2495).
    • Varsayılan uygulama ile cloneAndMove öğesini ShuffleMode öğesine ekleyin (#2226).
    • render çağrısı gerekmiyorsa Renderer.getMinDurationToProgressUs'nın varsayılan davranışını daha büyük bir değer döndürecek şekilde değiştirin.
    • Durdurulmuş durumdayken son kareye gitme işlemi yapıldığında dahili planlamanın son kareyi geciktirmesine neden olan hata düzeltildi. Şimdilik hata düzeltmesi yalnızca ExoPlayer.Builder.experimentalSetDynamicSchedulingEnabled etkinse geçerli olur.
    • ExoPlayer.setScrubbingModeEnabled(boolean) yöntemini ekleyin. Bu, oynatıcıyı sık sık yapılan arama işlemleri (ör. kullanıcının kaydırma çubuğunu sürüklemesi) için optimize eder. Sarma modunun davranışı, ExoPlayer ve ExoPlayer.Builder üzerinde setScrubbingModeParameters(..) ile özelleştirilebilir.
    • Sarma modunda kısmi arama toleransının özelleştirilmesine izin verilir.
    • Sarma modunda codec'in çalışma hızını artırın.
    • AdsMediaSource içeriğindeki hazırlama hatalarının hiçbir zaman bildirilmemesine (#2337) neden olan hata düzeltildi.
    • MergingMediaSource'daki bellek sızıntısı düzeltildi. Örneğin, altyazılar yan yüklenirken bu sızıntı oluşuyordu (#2338).
    • Belirli medya öğeleri için CMCD günlüğünü devre dışı bırakmak üzere CmcdConfiguration.Factory'nın null döndürmesine izin verin (#2386).
    • Varsayılan görüntü arabellek boyutunu 128 KB'tan (metin parçalarından kopyalama-yapıştırma hatası) 26 MB'a yükseltin. Bu boyut, 50 MP Ultra HDR görüntüler için yeterlidir (#2417).
    • Uygulamaların, belirtilen başlangıç konumu ve süresiyle tek bir medyayı önceden önbelleğe almasına olanak tanıyan PreCacheHelper işlevi eklendi.
    • DefaultPreloadManager içinde belirtilen konumdan önceden yükleme desteği eklendi.
  • Dönüştürücü:
    • Video kodlama ayarlarının yonga setine özgü optimizasyonlarını sağlayan CodecDbLite eklendi.
    • CodecDB Lite ayarlarının optimizasyonunu etkinleştirmek için setEnableCodecDbLite işaretini DefaultEncoderFactory öğesine ekleyin. Bu işaret varsayılan olarak false değerine ayarlanır.
    • Başlangıçtaki bir boşluğu (addGap() ile eklenir) artık sessiz sesle doldurmak için EditedMediaItemSequence.Builder içinde experimentalSetForceAudioTrack(true) değerinin açıkça ayarlanması gerekir. Boşluk dizinin ortasındaysa bu işaret gerekli değildir.
    • Muxer arayüzünü media3-transformer konumundan media3-muxer konumuna taşıyın.
    • Medya öğesini resim olarak içe aktarmak için MediaItem.Builder().setImageDuration(long) ayarını zorunlu kılın.
    • Kırpma işlemi sırasında, kırpma başlangıç noktasından önceki animasyon karesi ile kırpma başlangıç noktası arasındaki örnekleri yok saymaları için oyunculara talimat veren bir MP4 düzenleme listesi içeren Transformer.Builder().experimentalSetMp4EditListTrimEnabled(boolean) ekleyin.
    • Composition Demo uygulamasını Kotlin ve Jetpack Compose kullanacak şekilde güncelleyin ve dizileri 2x2 veya PiP düzeninde yerleştirmek için özel bir VideoCompositorSettings ekleyin.
  • Ayıklayıcılar:
    • Parçalanmış MP4 dosyalarından meta verileri ayrıştırma (#2084).
    • JPEG: Başında Exif segmenti olmayan hareketli fotoğrafları destekler (#2552).
    • Birden fazla sidx atomu içeren parçalanmış MP4'te arama için destek ekleyin. Bu davranış, FLAG_MERGE_FRAGMENTED_SIDX işaretinin FragmentedMp4Extractor üzerinde kullanılmasıyla etkinleştirilebilir (#9373).
    • FLAC dosyalarındaki boş arama tablolarını (yalnızca yer tutucu arama noktaları içerenler dahil) yoksayın ve dosyanın süresi biliniyorsa ikili arama aramasına geri dönün (#2327).
    • H.265 SEI birimlerinin ayrıştırılmasıyla ilgili sorunu düzelterek tanınmayan SEI türlerinin tamamen atlanmasını sağladık (#2456).
    • WavExtractor türündeki bir dosya ayrıştırılırken ses biçimi için üstbilgi uzantısının SubFormat verilerini kullanacak şekilde WavExtractor öğesini güncelleyin.WAVE_FORMAT_EXTENSIBLE
    • MP4: Ham PCM ses parçalarını tanımlayan ipcm ve fpcm kutuları için destek ekleyin (64 bit kayan nokta PCM desteklenmez).
    • MP4: Hem videoyu döndüren hem de yansıtan tkhd dönüşüm matrislerinin döndürme kısmını işler. Bu sayede, iPhone'un ön kamerasıyla çekilen yansıtılmış videoların doğru şekilde yukarı bakması sağlanır ancak y ekseninde yanlış şekilde yansıtılır (#2012).
    • MP3: FLAG_ENABLE_CONSTANT_BITRATE_SEEKING(_ALWAYS) nedeniyle sabit bit hızlı arama işlemine geri dönüldüğünde, aranamayan Xing, VBRI ve benzeri değişken bit hızlı meta verilerden elde edilen süre ve veri boyutunu kullanın (#2194).
  • Ses:
    • Ses oynatma, medyanın sonuna çok yakın bir noktada başlatıldığında AnalyticsListener.onAudioPositionAdvancing işlevinin çağrılmamasına neden olan hata düzeltildi.
    • ChannelMappingAudioProcessor ve TrimmingAudioProcessor'da tüm doğrusal PCM örnek biçimleri için destek ekleyin.
    • CompositionPlayer içinde ses boşlukları için destek ekleyin.
    • BaseAudioProcessor#reset() adlı kişiden BaseAudioProcessor#flush() adlı kişiye yapılan sahte aramayı kaldırın.
    • DefaultAudioMixer'da sabit güç upmixing/downmixing'ine izin verin.
    • ChannelMappingAudioProcessor, TrimmingAudioProcessor ve ToFloatPcmAudioProcessor öğelerini herkese açık hale getirin (#2339).
    • En iyi çaba tahmini yerine DefaultAudioSink'deki yetersizlikleri tespit etmek için AudioTrackPositionTracker'te AudioTrack#getUnderrunCount() kullanın.
    • Ses çıkış cihazından beklenmedik konum kayması durumunda ses zaman damgası düzeltme işlemini iyileştirir.
    • Bluetooth cihazlarına bağlandıktan sonra duraklatmadan devam ettirildiğinde ilk 10 saniye boyunca A/V senkronizasyonunun bozulmasına neden olan hata düzeltildi.
    • AnalyticsListener.onAudioPositionAdvancing öğesinin, sesin ilerlemeye başladığı zamanı değil, ilk ölçümün zamanını bildirmesine neden olan hata düzeltildi.
    • Bazı cihazlarda stereo sese geri dönüş yapıldıktan sonra çok kanallı sese geri dönme sorunu düzeltildi (#2258).
  • Video:
    • Ayrılmış yüzey geçici çözümünü "lenovo" ve "motorola" cihazlara genişletme (#2059).
    • Ses örnekleri tam olarak istenen konumda başlamadığında başlangıçta video karelerinin sorunsuz şekilde yayınlanması iyileştirildi.
    • Ayrılmış yüzey geçici çözümünü "realme" cihazlara genişletme (#2059).
    • Yalnızca kod çözme giriş arabelleklerini sıraya alırken ExoPlayer işaretini eklemek için deneysel MediaCodec.BUFFER_FLAG_DECODE_ONLY API'yi ekleyin. Bu işaret, kod çözücüye yalnızca kod çözme arabelleklerini atlama sinyali vererek daha hızlı arama yapılmasını sağlar. DefaultRenderersFactory.experimentalSetEnableMediaCodecBufferDecodeOnlyFlag ile etkinleştirin. * Yazılım video codec'leri için codec performansı kontrollerini iyileştirme. Bu durum, bazı ek parçaların EXCEEDS_CAPABILITIES olarak işaretlenmesine neden olabilir.
    • Bazı cihazlarda VP9 Widevine oynatma hatalarını düzeltme (#2408).
  • Metin:
    • MP4 dosyalarında VobSub parçaları için destek eklendi (#2510).
    • Bir altyazı segmenti ilk başta yüklenemediğinde ve daha sonra başarıyla yüklendiğinde, ardından birkaç boş altyazı segmenti geldiğinde yaşanan oynatma duraklamasını düzeltin (#2517).
    • Altyazılar etkinleştirildiğinde devam eden bir ipucunun gösterilmesi için SSA ve SubRip'i düzeltin (#2309).
    • Altyazı hatası olan bir yayından boş altyazı parçası içeren bir canlı yayına geçiş yaparken oynatmanın takılması sorunu düzeltildi (#2328).
    • B kareleri içeren H.262 akışları oynatılırken bozuk çıkan CEA-608 altyazıları düzeltildi (#2372).
    • Matroska dosyalarında CodecId = S_TEXT/SSA ile SSA altyazıları için destek ekleyin. Daha önce MatroskaExtractor yalnızca SubStation Alpha altyazılarının "gelişmiş" (v4+) varyantını temsil etmesi amaçlanan CodecId = S_TEXT/ASS biçimini destekliyordu (ancak ExoPlayer'ın ayrıştırma mantığı her iki varyant için de aynıdır) (#2384).
    • Aynı anda ekranda birden fazla ipucu gösterildiğinde ipuçlarının z sırasını tanımlamak için kullanılan SubStation Alpha (SSA) altyazı dosyalarında layer özelliği için destek eklendi (#2124).
  • Meta veri:
    • Timeline'dan medya süresini ve Timeline'yı alma desteği eklendi ve bu API, örnek tabanlı AutoCloseable API'ye taşındı.MetadataRetriever Builder kullanarak MediaItem için bir örnek oluşturun, ardından meta veriler için ListenableFuture'leri almak üzere retrieveTrackGroups(), retrieveTimeline() ve retrieveDurationUs()'i çağırın. Önceki statik yöntemler kullanımdan kaldırıldı (#2462).
  • Resim:
    • Çok büyük (ör. 50 MP) resimleri görüntülemeye çalışırken uygulamanın BitmapFactoryImageDecoder içinde PlayerView kaynaklı Canvas: trying to draw too large bitmap. ile kilitlenmesini önlemek için çözümlenmiş bit eşlemleri ekran boyutuyla sınırlayın.
    • DefaultRenderersFactory.getImageDecoderFactory() işlevinin imzasını Context parametresini alacak şekilde değiştirin.
    • CompositionPlayer içinde kullanılan maksimum bit eşlem çıkış boyutunu, Transformer içinde kullanılanla aynı olacak şekilde ayarlayın (yani CompositionPlayer, ExoPlayer'ın aksine bit eşlemleri kodunu çözerken ekran boyutunu dikkate almaz).
  • DRM:
    • HTTP istek üstbilgilerinin doğru şekilde uygulanabilmesi için OfflineLicenseHelper.newWidevineInstance işlevine MediaItem.DrmConfiguration kabul eden yeni bir aşırı yükleme ekleyin (#2169).
  • Etki:
    • Giriş yönünden bağımsız olarak en kısa kenarın her zaman verilen değere karşılık gelmesini sağlayan Presentation oluşturan Presentation.createForShortSide(int) işlevini ekleyin.
  • Muxers:
    • Parçalanmış MP4'teki ses örnekleri için doğru örnek işaretlerinin ayarlanmamasına neden olan hata düzeltildi.
    • writeSampleData() API artık MediaCodec.BufferInfo yerine muxer'a özel BufferInfo sınıfını kullanıyor.
    • Varsayılan olarak false değerine sahip Muxer.Factory#supportsWritingNegativeTimestampsInEditList özelliğini ekleyin.
  • IMA uzantısı:
    • Bir reklamdaki yükleme hatasının yanlışlıkla başka bir reklam grubunu geçersiz kılmasına neden olan hata düzeltildi.
    • VOD penceresinin sonundaki reklam gruplarının oynatmayı duraklatmasına neden olan hata düzeltildi. Pencereden sonraki bir başlangıç zamanına sahip reklam grupları artık MediaPeriodQueue sırasına alınmıyor (#2215).
  • Oturum:
    • Ayrıcalıklı olmayan üçüncü taraf Media3 denetleyicilerinden gelen bağlantıların yoksayıldığı hata düzeltildi.
    • Eski bir MediaBrowserServiceCompat cihazına özel komutlar gönderirken kullanılabilir komutlar için işareti kaldırın. Bu, eski bir uygulamaya bağlandığında eski kumandaların/tarayıcıların davranışıyla aynıdır.
    • Oynatıcının ilk oynatma hatasının yanlışlıkla kalıcı özel istisna olarak değerlendirilmesine neden olan hata düzeltildi. Bu durum, uygulamanın kurtarılmasını engeller.
    • Oturum tarafından işlenmeyen bazı denetleyici değişikliklerinin IllegalStateExceptions neden olabildiği hata düzeltildi.
    • Oturum tarafından işlenmeyen denetleyici işlemlerinin, denetleyiciyi geçersiz bir durumda bırakmasına neden olan hata düzeltildi.
    • StrictMode güvenli olmayan başlatma ihlali uyarısını düzeltin (#2330).
    • Oynatıcı ana iş parçacığından farklı bir uygulama iş parçacığında çalıştırılırken ana iş parçacığından setSessionExtras çağrıldığında IllegalStateException'ye (#2265) neden olan hata düzeltildi.
    • Bir oynatıcı, medya öğeleri hazırlanmadan veya oynatılmadan ayarlanırsa otomatik olarak bildirim göstermeyin (#2423https://github.com/androidx/media/issues/2423). Bu davranış, MediaSessionService.setShowNotificationForIdlePlayer üzerinden yapılandırılabilir.
    • Tüm veya seçili denetleyiciler için özel PlaybackException ekleyin.
    • MediaController cihazda canlı yayında ileri veya geri sarmanın IllegalArgumentException hatasına neden olabilmesi sorunu düzeltildi.
    • Android Auto kullanıcı arayüzünde (ve platform medya oturumundan bu bilgileri kullanan diğer denetleyicilerde) konum artefaktlarını önlemek için canlı yayınlarda, platform medya denetleyicileri için oynatma konumunun yayınlanmasını ve mevcut öğede arama yapma özelliğini durdurun (#1758).
    • Eski bir MediaBrowserServiceCompat cihazına bağlı MediaBrowser cihazının getLibraryRoot bölümüne null değerinin iletilmesinin NullPointerException oluşturmasına neden olan hata düzeltildi.
    • Özel işlemler, arama sonucu veya getItem isteği gönderildiğinde eski oturum uygulamasının ClassNotFoundException ile kilitlenmesine neden olan hata düzeltildi.
    • MediaItem.LocalConfiguration.uri öğesinin platform oturumlarının MediaMetadata ile paylaşılmasına neden olan hata düzeltildi. Denetleyicilerin medyayı yeniden istemesine izin vermek için URI'yi kasıtlı olarak paylaşmak istiyorsanız bunun yerine MediaItem.RequestMetadata.mediaUri değerini ayarlayın.
  • UI:
    • Yeniden kullanılabilir bileşenlerdeki PlayerSurface öğesinin doğru çalışmaması hatası düzeltildi (#2493).LazyColumn
    • İlk düğme durumlarını ayarlama ile durumdaki değişikliği (ör. simge şekilleri veya etkinleştirme) gözlemleme arasında boşluk oluşmasına neden olan bir Compose hatası düzeltildi. Gözlem dönemi dışında oynatıcıda yapılan değişiklikler artık algılanıyor (#2313).
    • SeekBackButtonState ve SeekForwardButtonState için media3-ui-compose modülüne durum tutucular ve composable'lar ekleyin.
    • ExoPlayer'ın sarma modu için PlayerControlView desteği eklendi. Etkinleştirildiğinde, kullanıcı kaydırma çubuğunu sürüklemeye başladığında oynatıcıyı kaydırma moduna geçirir, her hareket için bir player.seekTo çağrısı yapar ve dokunma işlemi ekrandan kaldırıldığında kaydırma modundan çıkar. Bu entegrasyon, XML'de time_bar_scrubbing_enabled = true veya Java/Kotlin'de setTimeBarScrubbingEnabled(boolean) yöntemiyle etkinleştirilebilir.
    • PlayerSurface, boş değer atanabilir bir Player bağımsız değişkenini kabul etsin.
  • İndirilenler:
    • Aşamalı akışlar için kısmi indirme desteği eklendi. Uygulamalar, DownloadHelper ile aşamalı bir akış hazırlayabilir ve indirme işleminin kapsaması gereken zamana dayalı medya başlangıç ve bitiş konumlarını belirterek yardımcıdan DownloadRequest isteyebilir. Döndürülen DownloadRequest, çözümlenmiş bayt aralığını taşır. Bu aralıkla ProgressiveDownloader oluşturulabilir ve içerik buna göre indirilebilir.
    • Statik DownloadHelper.forMediaItem() yöntemlerinin yerine kullanılan DownloadHelper.Factory eklendi.
    • SegmentDownloader uygulamaları için Factory ekleyin.
    • Uyarlanabilir akışlar için kısmi indirme desteği eklendi. Uygulamalar, DownloadHelper ile uyarlanabilir bir akış hazırlayabilir ve indirme işleminin kapsaması gereken zamana dayalı medya başlangıç ve bitiş konumlarını belirterek yardımcıdan DownloadRequest isteyebilir. Döndürülen DownloadRequest, çözümlenmiş zaman aralığını taşır. Bu aralıkla somut bir SegmentDownloader oluşturulabilir ve içerik buna göre indirilebilir.
  • Cronet uzantısı:
    • Otomatik çerez işleme özelliği eklendi (#5975).
  • HLS uzantısı:
    • Arabellekte kullanılabilir parça yokken HlsSampleStreamWrapper arabelleğin içinde arama yapmaya çalıştığında oluşan hata düzeltildi #2598.
    • Düşük gecikmeli parçalar yüklendikten sonra parça seçiminin değişmesi ve önceden yükleme ipuçlarının oynatmanın takılmasına veya donmasına neden olması sorunu düzeltildi (#2299).
    • CAN-BLOCK-RELOAD=YES sunucu tarafından karşılanmadığında hedef sürenin yarısı kadar bekleyerek aşırı yeniden yüklemeleri önleme (#2317).
    • Bir ara rulo reklamdan önce geçiş reklamı yayını başlatıldığında oynatmanın duraklatılması ve yanlış reklam için öğe listesi çözünürlüğünün denenmesiyle ilgili hata düzeltildi (#2558).
    • Alıntılanmış dize özellik değerlerinde \f (form feed) kabul etmek için oynatma listesi ayrıştırma işlemi düzeltildi (#2420).
    • Aynı kimliğe sahip geçiş reklamlarının güncellenmesi desteklenir (#2427).
    • Canlı yayında yüklenecek segment kalmadığında oynatma listesi yükleme hatalarının bazen yayılmamasına neden olan hata düzeltildi (#2401https://github.com/androidx/media/issues/2401).
    • Altyazı yorumlarını, ses yorumlarının gruplandırılmasına benzer şekilde NAME etiketiyle gruplandırın (#1666).
    • X-ASSET-LIST ve HlsInterstitialsAdsLoader ile canlı yayınları destekleyin.
  • DASH uzantısı:
    • Hızlı oynatma uyarlama grubunun, geçersiz bir TrackGroup oluşturmak için ana uyarlama grubuyla birleştirildiği sorun düzeltildi (#2148).
    • Yeni sürenin ötesindeki örnekler oluşturma işlem hattı tarafından okunmuşsa DASH dönemi süresinin kısaltılmasının istisna oluşturmasına neden olan hata düzeltildi (#2440).
    • CMCD sorgu parametreleri kullanılırken yönlendirmenin takip edilmemesine neden olan hata düzeltildi (#2475).
  • RTSP uzantısı:
    • RFC 7798#4.4.2 uyarınca H265 için RTP Toplama Paketi desteği eklendi (#2413).
    • Bir HTTP 302 yanıtı işlenirken sağlanan konum URI'sinin kullanılması için RtspClient düzeltildi (#2398).
    • Sondaki boşluk karakterleri içeren satırların bulunduğu SessionDescription'lar için ayrıştırma desteği eklendi (#2357).
  • Kod çözücü uzantıları (FFmpeg, VP9, AV1 vb.):
    • Ses kod çözücü uzantıları için DefaultTrackSelector.setAllowInvalidateSelectionsOnRendererCapabilitiesChange işleminin etkili olmaması hatası düzeltildi (#2258).
  • Yayın uzantısı:
    • setVolume() ve getVolume() için destek eklendi (#2279).
    • Zaman çizelgesi boşken CastPlayer'ın STATE_BUFFERING durumuna girmesini önleyin.
    • getDeviceVolume(), setDeviceVolume(), getDeviceMuted() ve setDeviceMuted() için destek eklendi (#2089).
  • Test yardımcı programları:
    • Oyuncunun belirtilen bir konuma ulaşması için advance(player).untilPositionAtLeast ve untilMediaItemIndex öğelerini TestPlayerRunHelper öğesine ekleyin. Çoğu durumda bu yöntemler, mevcut untilPosition ve untilStartOfMediaItem yöntemlerinden daha güvenilirdir.
    • FakeDownloader öğesini diğer testlerde yeniden kullanmak için test-utils-robolectric modülüne taşıyın.
    • transformer.TestUtil.addAudioDecoders(String...), transformer.TestUtil.addAudioEncoders(String...) ve transformer.TestUtil.addAudioEncoders(ShadowMediaCodec.CodecConfig, String...) kaldırıldı. Bunun yerine, gölge kodlayıcıları ve kod çözücüleri yapılandırmak için ShadowMediaCodecConfig'yı kullanın.
    • ShadowMediaCodecConfig tarafından bildirilen codec adlarında "exotest" öneki "media3" ile değiştirildi.
  • Desteği sonlandırılan sembolleri kaldırın:
    • Kullanımdan kaldırılan SegmentDownloader oluşturucusu SegmentDownloader(MediaItem, Parser<M>, CacheDataSource.Factory, Executor) ve alt sınıflarındaki (DashDownloader, HlsDownloader ve SsDownloader) ilgili oluşturucular kaldırıldı.
    • Kullanımdan kaldırılan Player.hasNext(), Player.hasNextWindow() kaldırıldı. Bunun yerine Player.hasNextMediaItem() kullanın.
    • Kullanımdan kaldırılan Player.next() kaldırıldı. Bunun yerine Player.seekToNextMediaItem() kullanın.
    • Kullanımdan kaldırılan Player.seekToPreviousWindow() kaldırıldı. Bunun yerine Player.seekToPreviousMediaItem() kullanın.
    • Kullanımdan kaldırılan Player.seekToNextWindow() kaldırıldı. Bunun yerine Player.seekToNextMediaItem() kullanın.
    • exoplayer modülünde desteği sonlandırılan BaseAudioProcessor kaldırıldı. common modülünde BaseAudioProcessor özelliğini kullanın.
    • Desteği sonlandırılan MediaCodecVideoRenderer oluşturucusunu kaldırın MediaCodecVideoRenderer(Context, MediaCodecAdapter.Factor, MediaCodecSelector, long, boolean, @Nullable Handler, @Nullable VideoRendererEventListener, int, float, @Nullable VideoSinkProvider).

Sürüm 1.8.0-rc02

24 Temmuz 2025

1.8.0 kararlı sürümünü kullanın.

Sürüm 1.8.0-rc01

16 Temmuz 2025

1.8.0 kararlı sürümünü kullanın.

Sürüm 1.8.0-beta01

2 Temmuz 2025

1.8.0 kararlı sürümünü kullanın.

Sürüm 1.8.0-alpha01

19 Mayıs 2025

1.8.0 kararlı sürümünü kullanın.

Sürüm 1.7.0

Sürüm 1.7.1

16 Mayıs 2025

Bu sürüm, 1.6.1 sürümüyle aynı koda sahiptir ve yanlışlıkla kararlı olarak etiketlenen bir alfa sürümü olan 1.7.0'dan "daha yeni" bir sürüm olarak görünmesi için yayınlanmaktadır (aşağıya bakın).

Sürüm 1.7.0

16 Mayıs 2025

Bu sürüm 1.7.0-alpha01 olmalıydı ancak maven.google.com'da yanlışlıkla 1.7.0 (ör. kararlı) olarak etiketlendi. Lütfen kullanmayın. 1.6.1 sürümünde kalabilir veya 1.7.1 sürümüne (1.6.1 ile aynı koda sahiptir) yükseltebilirsiniz.

Sürüm 1.6.0

1.6.1

14 Nisan 2025

androidx.media3:media3-*:1.6.1 iptal edilir. 1.6.1 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • Yeni bir pitch değeriyle PlaybackParameters.withPitch(float) kolayca kopyalamak için PlaybackParameters.withPitch(float) yöntemi eklendi (#2257).PlaybackParameters
  • ExoPlayer:
    • Bir sonraki medya öğesinin başlatılması sırasında kurtarılabilir oluşturucu hatası nedeniyle medya öğesi geçişinin başarısız olmasına neden olan sorun düzeltildi (#2229).
    • ProgressiveMediaPeriod hazırlanmadan önce PreloadMediaSource kendi getBufferedDurationUs()'ünü çağırmaya çalıştığında IllegalStateException'nin ProgressiveMediaPeriod'ı atması sorunu düzeltildi (#2315).
    • DASH, HLS ve SmoothStreaming için manifest isteklerinde CmcdData gönderme sorunu düzeltildi (#2253).
    • Reklam grupları kaldırıldıktan sonra AdPlaybackState.withAdDurationsUs(long[][]) özelliğinin kullanılabildiğinden emin olun. Kullanıcının, kaldırılan reklam grupları için boş veya null olabilen bir süre dizisi iletmesi gerekir (#2267).
  • Ayıklayıcılar:
    • MP4: alternate_group öğesini tkhd kutusundan ayrıştırın ve her parçanın Format.metadata bölümünde Mp4AlternateGroupData girişi olarak gösterin (#2242).
  • Ses:
    • Kısa içeriklerden oluşan bir oynatma listesi oynatılırken konumun takılabildiği boşaltma sorunu düzeltildi (#1920).
  • Oturum:
    • Platform MediaSession geri çağırmaları için toplama zaman aşımını 500 milisaniyeden 100 milisaniyeye düşürün ve uygulamaların bu değeri yapılandırmasına olanak tanıyan deneysel bir ayarlayıcı ekleyin.
    • Kullanıcı tarafından kapatılan bildirimlerin yeniden görünmesine neden olan sorun düzeltildi (#2302).
    • Oturumun, sarmalanmış oynatıcı aslında boşken tek öğeli bir zaman çizelgesi döndürmesine neden olan hata düzeltildi. Bu durum, sarmalanmış oynatıcıda COMMAND_GET_CURRENT_MEDIA_ITEM kullanılabilirken COMMAND_GET_TIMELINE kullanılamadığında ve sarmalanmış oynatıcı boş olduğunda meydana gelir (#2320).
    • MediaSessionService.setMediaNotificationProvider çağrısının, hizmetle setForegroundServiceTimeoutMs gibi diğer etkileşimlerden sonra sessizce yoksayıldığı hata düzeltildi (#2305).
  • UI:
    • PlayerSurface özelliğinin ExoPlayer.setVideoEffects ve CompositionPlayer ile çalışmasını sağlayın.
    • PlayerSurface öğesinin yeni bir Player ile yeniden oluşturulamaması hatası düzeltildi.
  • HLS uzantısı:
    • HLS medyası için CmcdData'da parça süresinin ayarlanmaması nedeniyle şifrelenmiş medya segmentleri işlenirken onaylama hatasına neden olan sorun düzeltildi (#2312).
  • RTSP uzantısı:
    • RTSP oturumunu TCP kullanacak şekilde yapılandırmak için RTSPT şemalı URI desteği eklendi (#1484).
  • Yayın uzantısı:
    • Oynatma listesi meta verileri için destek eklendi (#2235).

1.6.0

26 Mart 2025

androidx.media3:media3-*:1.6.0 iptal edilir. 1.6.0 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • AudioManagerCompat ve AudioFocusRequestCompat değerlerini ekleyerek androidx.media'deki eşdeğer sınıfları değiştirin.
    • Kotlin'i 1.9.20'den 2.0.20'ye yükseltin ve Compose Compiler Gradle eklentisini kullanın. KotlinX Coroutines kitaplığı 1.8.1 sürümünden 1.9.0 sürümüne yükseltildi.
    • Format.toBundle(boolean excludeMetadata) yöntemini kaldırın, bunun yerine Format.toBundle() yöntemini kullanın.
    • SimpleBasePlayer'daki hatayı düzeltme: null ile setPlaylist'dan sonra State'da yeni bir currentMediaItemIndex ayarlamak meta verileri yeniden değerlendirmez (#1940).MediaMetadata
    • Diğer sınıflardaki güncellemeleri yönetmeyi kolaylaştırmak için SimpleBasePlayer.State erişimini korumalıdan herkese açık olarak değiştirin (#2128).
  • ExoPlayer:
    • MediaExtractorCompat platformuyla eşdeğer özellikler sağlayan yeni bir sınıf olan MediaExtractor'ı ekleyin.
    • MediaCodecVideoRenderer kullanılarak oynatma için deneysel "ExoPlayer" ön ısıtma desteği eklendi. DefaultRenderersFactory'yı experimentalSetEnableMediaCodecVideoRendererPrewarming üzerinden yapılandırarak ExoPlayer'e ikincil bir MediaCodecVideoRenderer sağlayabilirsiniz. Etkinleştirilirse ExoPlayer, medya öğesi geçiş gecikmesini azaltmak için oynatma sırasında ardışık medya öğelerinin videosunu önceden işler.
    • DefaultLoadControl'deki bufferForPlaybackMs ve bufferForPlaybackAfterRebufferMs için varsayılan değerleri sırasıyla 1.000 ve 2.000 ms olarak azaltın.
    • DeviceInfo ve cihaz sesini eşzamansız olarak başlatın (setDeviceVolumeControlEnabled kullanılarak etkinleştirilmişse). Bu değerler ExoPlayer.Builder.build() işleminden hemen sonra kullanılamaz ve Player.Listener, onDeviceInfoChanged ve onDeviceVolumeChanged aracılığıyla değişiklikleri bildirir.
    • İlk ses oturumu kimliği, oynatıcı oluşturulduktan sonra artık hemen kullanılamaz. Gerekirse ilk güncellemeyi dinlemek için AnalyticsListener.onAudioSessionIdChanged simgesini kullanabilirsiniz.
    • Video parçası seçerken dili göz önünde bulundurun. Varsayılan olarak, varsa seçilen ses parçasının diliyle eşleşen bir "ana" video parçası seçilir. Uygunsuz video dili tercihleri TrackSelectionParameters.Builder.setPreferredVideoLanguage(s) ile ifade edilebilir.
    • DefaultTrackSelector.selectVideoTrack() yöntemine selectedAudioLanguage parametresi eklendi.
    • MediaSourceEventListener.onLoadStarted ve ilgili MediaSourceEventListener.EventDispatcher yöntemlerine retryCount parametresi eklendi.
    • Çok dönemli DASH akışlarındaki oynatma listesi öğelerinin veya dönemlerin, gerçek içerikle eşleşmeyen süreleri nedeniyle öğenin sonunda karelerin donmasına neden olabilmesiyle ilgili hata düzeltildi (#1698).
    • BasePreloadManager.Listener öğesini üst düzey bir PreloadManagerListener'ye taşıyın.
    • RenderersFactory.createSecondaryRenderer, ön ısıtma için ikincil oluşturucular sağlamak üzere uygulanabilir. Ön ısıtma, oynatma sırasında medya öğeleri arasında daha hızlı geçiş yapılmasını sağlar.
    • DASH, HLS ve SmoothStreaming gibi uyarlanabilir akış biçimlerindeki manifest istekleri için CmcdData gönderimini etkinleştirin (#1951).
    • MediaCodecRenderer.onReadyToInitializeCodec içinde başlatılacak codec'in MediaCodecInfo değerini sağlayın MediaCodecRenderer.onReadyToInitializeCodec (#1963).
    • Reklam grupları ekleyerek AdPlaybackStates'ın büyümesine izin vermek için AdsMediaSource seçeneğini değiştirin. Geçersiz değişiklikler algılanır ve istisna oluşturulur.
    • Ara reklamdan sonra içerik medyasına geçiş yaparken yalnızca kod çözme işleminin yapıldığı ek karelerin hızlı bir şekilde gösterilmesiyle ilgili sorun düzeltildi.
    • Uygulamaların varsayılan olarak iki farklı meta veri şeması almasını sağlamak için DefaultRenderersFactory, iki MetadataRenderer örneği ekleyin.
    • Oynatma duraklatıldığında devam eden bir parçanın yüklenmesinin iptal edilip edilmeyeceğini yeniden değerlendirin (#1785).
    • ClippingMediaSource'ya, sarılamayan medyada kırpmaya izin verme seçeneği ekleyin.
    • Ön ısıtma ile arama yapmanın sonraki medya öğesi geçişini engellemesine neden olan hata düzeltildi.
    • ExoPlayer.isLoading(), STATE_IDLE veya STATE_ENDED'ye geçiş yapmasına rağmen true olarak kalmasına neden olan hata düzeltildi (#2133).
    • lastRebufferRealtimeMs öğesini LoadControl.Parameter'ye ekleme (#2113).
  • Dönüştürücü:
    • Geriye dönük uyumlu alternatif biçimlere transmuks etme desteği eklendi.
    • Dolby Vision (profil 8) biçiminin kod dönüştürülmesi ve yeniden kapsama alınması için destek eklendi.
    • VideoFrameProcessor.registerInputStream ve VideoFrameProcessor.Listener.onInputStreamRegistered parametrelerini Format kullanacak şekilde güncelleyin.
    • DefaultEncoderFactory kullanılırken HDR statik meta verileri oluşturulur.
    • MediaMetricsManager kullanarak Android platformu teşhisleri için desteği etkinleştirin. Dönüştürücü, düzenleme etkinliklerini ve performans verilerini platforma iletir. Bu sayede, cihazda sistem performansı ve hata ayıklama bilgileri sağlanır. Bu veriler, cihaz kullanıcısı kullanım ve teşhis verilerinin paylaşımını etkinleştirirse Google tarafından da toplanabilir. Uygulamalar, Transformer.Builder.setUsePlatformDiagnostics(false) ile Transformer için platform teşhislerine katkıda bulunmayı devre dışı bırakabilir.
    • InAppMuxer, InAppMp4Muxer ve InAppFragmentedMp4Muxer olarak bölündü. Parçalanmamış bir MP4 dosyası oluşturmak için InAppMp4Muxer, parçalanmış bir MP4 dosyası oluşturmak için ise InAppFragmentedMp4Muxer kullanılır.
    • Muxer arayüzünü media3-muxer konumundan media3-transformer konumuna taşıyın.
    • Ekran kaydı için MediaProjection kaynağından medya sağlayan MediaProjectionAssetLoader öğesini ekleyin ve Transformer demo uygulamasına ekran kaydı desteği ekleyin.
    • #getInputFormat() öğesini Codec arayüzüne ekleyin.
    • Mümkün olduğunda GlObjectsProvider cihazının kilidini açma sorumluluğunu DefaultVideoFrameProcessor ve DefaultVideoCompositor konumundaki arayana devredin.
  • Ayıklayıcılar:
    • AVI: Akış başlığının parça sayısı yerine bayt sayısını depoladığı, sabit bit hızlı sıkıştırılmış ses içeren dosyaların işlenmesi düzeltildi.
    • Uzunlukları 1 veya 2 bayt (4 bayt yerine) olarak ifade edilen NAL birimlerinin işlenmesiyle ilgili sorun düzeltildi.
    • Düzenleme listesi, senkronizasyon çerçevesi olmayan ve öncesinde senkronizasyon çerçevesi bulunmayan bir çerçeveyle başladığında MP4 düzenleme listelerindeki ArrayIndexOutOfBoundsException simgesini düzeltir (#2062).
    • TS akışlarının bazı cihazlarda takılması sorunu düzeltildi ( (#2069).
    • FLAC: 32 bit FLAC dosyaları için destek eklendi. Daha önce bu videolar IllegalStateException: Playback stuck buffering and not loading ile oynatılamıyordu (#2197).
  • Ses:
    • Oynatma devam ettiğinde onAudioPositionAdvancing işlevinin çağrılması düzeltildi (daha önce oynatma duraklatıldığında çağrılıyordu).
    • SpeedChangingAudioProcessor, varsayılan parametrelerle yapılandırıldığında SonicAudioProcessor'ı atlamayın.
    • Sonic#getOutputSize()'daki, DefaultAudioSink'nin durmasına neden olabilecek taşma sorunu düzeltildi.
    • Arama işlemlerinin sağlanan süreleri doğru şekilde sıfırlaması için MediaCodecAudioRenderer.getDurationToProgressUs() ve DecoderAudioRenderer.getDurationToProgressUs() sorunlarını düzeltin.
    • androidx.media3.common.audio.SonicAudioProcessor numaralı telefonu kalıcı yapın.
    • ChannelMappingAudioProcessor ve TrimmingAudioProcessor'a kayan nokta PCM desteği eklendi.
  • Video:
    • Uygulamaların yer tutucu yüzeylerin kullanımını engellemek için geçersiz kılabilmesi amacıyla MediaCodecVideoRenderer.shouldUsePlaceholderSurface değerini protected olarak değiştirin (#1905).
    • Arama işlemini hızlandırmak için deneysel ExoPlayer AV1 örnek bağımlılık ayrıştırması eklendi. Yeni DefaultRenderersFactory.experimentalSetParseAv1SampleDependencies API ile etkinleştirin.
    • Deneysel ExoPlayer API'sini, geç bırakılan MediaCodecVideoRenderer bağımlı olmayan kod çözücü giriş arabelleklerini bırakmak için ekleyin. DefaultRenderersFactory.experimentalSetLateThresholdToDropDecoderInputUs ile etkinleştirin. * Yüzeyi olmayan bir oynatıcının hemen hazır olması ve bekleyen karelerin çok yavaş çözülmesi sorunu düzeltildi (#1973).
    • Ekranın titremesini önlemek için Xiaomi ve OPPO cihazları ayrılmış yüzey modunun dışında tutun (#2059).
  • Metin:
    • VobSub altyazıları için destek eklendi (#8260).
    • MediaItem.Builder.setSubtitleConfigurations ile yapılandırılmış tüm altyazı dosyalarının önceden yüklenmesini durdurun ve bunun yerine, parça seçimiyle seçilirse yalnızca bir altyazı dosyasını yükleyin (#1721).
    • TTML: tts:origin ve tts:extent öğelerine style kullanılarak referans verilmesi için destek eklendi (#2953).
    • WebVTT ve SubRip zaman damgalarını tam olarak 3 ondalık basamakla sınırlayın. Daha önce, herhangi bir ondalık basamak sayısını yanlış ayrıştırıyor ancak her zaman değerin milisaniye cinsinden olduğunu varsayıyorduk. Bu durum, yanlış zaman damgalarına yol açıyordu (#1997).
    • Oynatma listesi, CEA-608 veya CEA-708 altyazılı kırpılmış öğeler içerdiğinde oynatmanın takılması sorunu düzeltildi.
    • Bir SSA dosyasında süresi sıfır olan bir ipucu (başlangıç ve bitiş zamanı eşit) olduğunda IllegalStateException düzeltildi (#2052).
    • Altyazılar ses ve video ile aynı kapsayıcıya yerleştirildiğinde altyazı ayrıştırma hatalarını bastırın (ve günlüğe kaydedin) (#2052).
    • CR satır sonları kullanılan WebVTT dosyalarındaki çok baytlı UTF-8 karakterlerinin işlenmesi düzeltildi (#2167).
  • DRM:
    • API < 27 olan cihazlarda ClearKey içeriği oynatılırken MediaCodec$CryptoException: Operation not supported in this configuration hatası düzeltildi (#1732).
  • Etki:
    • OverlaySettings işlevini StaticOverlaySettings'ye taşıdık. OverlaySettings, dinamik yer paylaşımı ayarlarına izin vermek için alt sınıflara ayrılabilir.
  • Muxers:
    • Tam nitelikli adın çok uzun olmasını önlemek için MuxerException, Muxer arayüzünden taşındı.
    • setSampleCopyEnabled() yöntemi, hem Mp4Muxer.Builder hem de FragmentedMp4Muxer.Builder'de setSampleCopyingEnabled() olarak yeniden adlandırıldı.
    • Mp4Muxer.addTrack() ve FragmentedMp4Muxer.addTrack() artık TrackToken yerine int parça kimliği döndürüyor.
    • Mp4Muxer ve FragmentedMp4Muxer artık Muxer arayüzünü uygulamıyor.
    • Varsayılan olarak Mp4Muxer örnek gruplandırma ve kopyalama işlemlerini devre dışı bırakın.
    • Yalnızca ses parçası yazıldığında çok sayıda parça oluşturan FragmentedMp4Muxer ile ilgili bir hata düzeltildi.
  • Oturum:
    • Oynatma duraklatıldığında, durdurulduğunda veya başarısız olduğunda ön plan hizmeti durumunu 10 dakika daha korur. Bu sayede kullanıcılar, çeşitli cihazlarda ön plan hizmeti kısıtlamaları riski olmadan bu zaman aşımı içinde oynatmaya devam edebilir. player.pause() işlevinin çağrılmasının artık stopSelf() işlevinin geçersiz kılınması durumunda ön plan hizmetini stopSelf() işlevinden önce durdurmak için kullanılamayacağını unutmayın. Bunun yerine onTaskRemoved işlevini kullanın.MediaSessionService.pauseAllPlayersAndStopSelf()
    • Oynatma hata durumuna girdiğinde veya durdurulduğunda bildirimi görünür tutun. Bildirim yalnızca oynatma listesi temizlendiğinde veya oyuncu serbest bırakıldığında kaldırılır.
    • Android platformundaki MediaSession işlemleri ACTION_PLAY ve ACTION_PAUSE'un işlenmesini iyileştirerek yalnızca kullanılabilir komutlara göre birini ayarlayın ve yalnızca biri ayarlanmışsa da kabul edin.
    • Context öğesini MediaButtonReceiver.shouldStartForegroundService öğesine parametre olarak ekleyin MediaButtonReceiver.shouldStartForegroundService (#1887).
    • Eski bir oturuma bağlı MediaController üzerinde Player yönteminin çağrılmasıyla bekleyen güncellemedeki değişikliklerin bırakılmasına neden olan hata düzeltildi.
    • MediaSession.setSessionActivity(PendingIntent) değerinin null değerini kabul etmesi sağlandı (#2109).
    • Oynatma listesi temizlendiğinde eski bir bildirimin görünür kalmasına neden olan hata düzeltildi (#2211).
  • UI:
    • PlayerSurface, PresentationState, PlayPauseButtonState, NextButtonState, PreviousButtonState, RepeatButtonState, ShuffleButtonState ve PlaybackSpeedState için media3-ui-compose modülüne durum tutucular ve composable'lar ekleyin.
  • İndirilenler:
    • Veri kaynağı IOException dışında bir Exception oluşturduğunda veri kaynaklarını açık ve önbellek alanlarını kilitli bırakan CacheWriter hatası düzeltildi (#9760).
  • HLS uzantısı:
    • HlsInterstitialsAdsLoader ile ilgili ilk sürümü ekleyin. Reklam yükleyici, bir HLS medya oynatma listesinin HLS geçiş reklamlarını okur ve bunları AdsMediaSource'ye iletilen AdPlaybackState ile eşler. Bu ilk sürüm yalnızca X-ASSET-URI özelliklerine sahip HLS VOD akışlarını destekler.
    • HlsInterstitialsAdsLoader.AdsMediaSourceFactory ekleyin. Uygulamalar, AdsMediaSource örnekleri oluşturmak için bunu kullanabilir. Bu örnekler, HlsInterstitialsAdsLoader'yi kolay ve güvenli bir şekilde kullanır.
    • Dolby Vision biçimlerini algılamak için HLS oynatma listesinden SUPPLEMENTAL-CODECS etiketini ayrıştırın (#1785).
    • HLS yayınında konumları senkronize etme koşulunu gevşetin (#2209).
  • DASH uzantısı:
    • DASH için AC-4 Seviye 4 biçim desteği eklendi ( (#1898).
    • Çok dönemli canlı yayınlarda reklam ekleme için güncelleme aralığı hesaplanırken oluşan sorun düzeltildi (#1698).
    • Dolby Vision biçimlerini algılamak için DASH manifestindeki scte214:supplementalCodecs özelliğini ayrıştırın (#1785).
    • Dönemin, belirtilen dönem süresinin ötesinde medya örnekleri içerdiği canlı yayınlarda dönem geçişlerinin işlenmesi iyileştirildi (#1698).
    • adaptation-set-switching ile işaretlenmiş ancak farklı diller veya rol işaretleri içeren uyarlama kümelerinin birlikte birleştirilmesi sorunu düzeltildi (#2222).
  • Kod çözücü uzantıları (FFmpeg, VP9, AV1 vb.):
    • MPEG-H sesin kodunu çözmek için yerleşik MPEG-H kod çözücüyü kullanan MPEG-H kod çözücü modülünü ekleyin (#1826).
  • MIDI uzantısı:
    • Özel AudioSink ve AudioRendererEventListener örneklerini MidiRenderer'ye bağlayın.
  • Yayın uzantısı:
    • Google Play Hizmetleri'nin yüklü ancak devre dışı olduğu cihazlarda API 34 ve sonraki sürümleri hedefleyen uygulamalarda play-services-cast-framework kilitlenmesini düzeltmek için FLAG_MUTABLE bağımlılığını 21.5.0'a yükseltin (#2178).
  • Demo uygulaması:
    • Ek düğmelerle demo-compose'ı genişletin ve ölçeklendirme ile deklanşör desteğiyle PlayerSurface entegrasyonunu geliştirin.
  • Desteği sonlandırılan sembolleri kaldırın:
    • Desteği sonlandırılan AudioMixer.create() yöntemi kaldırıldı. Bunun yerine DefaultAudioMixer.Factory().create() kullanın.
    • Aşağıdaki desteği sonlandırılan Transformer.Builder yöntemleri kaldırın:
      • setTransformationRequest(), bunun yerine setAudioMimeType(), setVideoMimeType() ve setHdrMode() kullanın.
      • setAudioProcessors(), ses işlemcisini bir EditedMediaItem.Builder.setEffects() içine yerleştirin ve bunun yerine Transformer.start() öğesine iletin.
      • setVideoEffects(), video efektini EditedMediaItem.Builder.setEffects() içinde ayarlayın ve Transformer.start() öğesine aktarın.
      • setRemoveAudio(), bunun yerine EditedMediaItem öğesinden Transformer.start() öğesine iletilen sesi kaldırmak için EditedMediaItem.Builder.setRemoveAudio() öğesini kullanın.
      • setRemoveVideo(), videoyu EditedMediaItem iletilen Transformer.start() öğesinden kaldırmak için EditedMediaItem.Builder.setRemoveVideo() kullanın.
      • setFlattenForSlowMotion(), Transformer.start()'a iletilen EditedMediaItem'yi düzleştirmek için EditedMediaItem.Builder.setFlattenForSlowMotion()'yi kullanın.
      • setListener(), addListener(), removeListener() veya removeAllListeners() kullanın.
    • Aşağıdaki desteği sonlandırılan Transformer.Listener yöntemleri kaldırın:
      • onTransformationCompleted(MediaItem), use onCompleted(Composition, ExportResult) instead.
      • onTransformationCompleted(MediaItem, TransformationResult), use onCompleted(Composition, ExportResult) instead.
      • onTransformationError(MediaItem, Exception), use onError(Composition, ExportResult, ExportException) instead.
      • onTransformationError(MediaItem, TransformationException), use onError(Composition, ExportResult, ExportException) instead.
      • onTransformationError(MediaItem, TransformationResult, TransformationException) yerine onError(Composition, ExportResult, ExportException) kullanın.
      • onFallbackApplied(MediaItem, TransformationRequest, TransformationRequest) yerine onFallbackApplied(Composition, TransformationRequest, TransformationRequest) kullanın.
    • Desteği sonlandırılan TransformationResult sınıfını kaldırın. Bunun yerine ExportResult kullanın.
    • Desteği sonlandırılan TransformationException sınıfını kaldırın. Bunun yerine ExportException kullanın.
    • Kullanımdan kaldırılan Transformer.PROGRESS_STATE_NO_TRANSFORMATION öğesini kaldırın. Bunun yerine Transformer.PROGRESS_STATE_NOT_STARTED kullanın.
    • Kullanımdan kaldırılan Transformer.setListener() öğesini kaldırın. Bunun yerine Transformer.addListener(), Transformer.removeListener() veya Transformer.removeAllListeners() kullanın.
    • Kullanımdan kaldırılan Transformer.startTransformation() öğesini kaldırın. Bunun yerine Transformer.start(MediaItem, String) kullanın.
    • Kullanımdan kaldırılan SingleFrameGlShaderProgram öğesini kaldırın. Bunun yerine BaseGlShaderProgram kullanın.
    • Transformer.flattenForSlowMotion öğesini kaldırın. Bunun yerine EditedMediaItem.flattenForSlowMotion kullanın.
    • ExoPlayer.VideoComponent, ExoPlayer.AudioComponent, ExoPlayer.TextComponent ve ExoPlayer.DeviceComponent kaldırıldı.
    • androidx.media3.exoplayer.audio.SonicAudioProcessor kaldırıldı.
    • Aşağıdaki desteği sonlandırılan DownloadHelper yöntemleri kaldırıldı:
      • Constructor DownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilities[]), use DownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilitiesList) instead.
      • getRendererCapabilities(RenderersFactory), eşdeğer işlevsellik RenderersFactory ile DefaultRendererCapabilitiesList oluşturularak ve DefaultRendererCapabilitiesList.getRendererCapabilities() çağrılarak elde edilebilir.
      • PlayerNotificationManager.setMediaSessionToken(MediaSessionCompat) yöntemi kaldırıldı. PlayerNotificationManager.setMediaSessionToken(MediaSession.Token) kullanın ve bunun yerine (MediaSession.Token) compatToken.getToken() iletin.

1.6.0-rc02

19 Mart 2025

1.6.0 kararlı sürümünü kullanın.

1.6.0-rc01

12 Mart 2025

1.6.0 kararlı sürümünü kullanın.

1.6.0-beta01

26 Şubat 2025

1.6.0 kararlı sürümünü kullanın.

Sürüm 1.6.0-alpha03

6 Şubat 2025

1.6.0 kararlı sürümünü kullanın.

Sürüm 1.6.0-alpha02

30 Ocak 2025

1.6.0 kararlı sürümünü kullanın.

Sürüm 1.6.0-alpha01

20 Aralık 2024

1.6.0 kararlı sürümünü kullanın.

Sürüm 1.5

Sürüm 1.5.1

19 Aralık 2024

androidx.media3:media3-*:1.5.1 iptal edilir. 1.5.1 sürümü bu commit'leri içerir.

  • ExoPlayer:
    • Bu platform API'siyle ilgili bildirilen codec zaman aşımı sorunlarını önlemek için MediaCodec'te eşzamansız şifre çözme kullanımını devre dışı bırakın (#1641).
  • Ayıklayıcılar:
    • MP3: Bir VBRI çerçevesinin içerik tablosu, bir dosyadaki tüm MP3 verilerini kapsamıyorsa oynatmayı erken durdurmayın (#1904).
  • Video:
    • MediaCodecAdapter sağlanan piksel en boy oranı değerlerinin, onOutputFormatChanged işlenirken sağlandığında kullanılmasının geri alınması (#1371).
  • Metin:
    • ReplacingCuesResolver.discardCuesBeforeTimeUs'da, timeUs konumunda etkin olan (daha önce başlatılmış ancak henüz sona ermemiş) ipucunun yanlışlıkla silinmesine neden olan hata düzeltildi (#1939).
  • Meta veri:
    • Vorbis yorumlarındaki disk/parça numaralandırmasını ve türü MediaMetadata (#1958) içine ayıklayın.

Sürüm 1.5.0

27 Kasım 2024

androidx.media3:media3-*:1.5.0 iptal edilir. 1.5.0 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • Tam tutarlılık ve dinleyici işleme sağlarken küçük ayarlamalarla başka bir oynatıcıya yönlendirmeye olanak tanıyan ForwardingSimpleBasePlayer işlevi eklendi (#1183).
    • SimpleBasePlayer.State.playlist yerine getPlaylist() yöntemini kullanın.
    • Oynatma listesi yapısı oluşturmak yerine doğrudan Timeline ve geçerli Tracks ile Metadata belirtmek için SimpleBasePlayer.State.Builder.setPlaylist() öğesine geçersiz kılma ekleyin.
    • minSdk değerini 21'e (Android Lollipop) yükseltin. Bu, diğer tüm AndroidX kitaplıklarıyla uyumludur.
    • Common kitaplığının üzerine kurulu Kotlin'e özgü işlevler sağlayan androidx.media3:media3-common-ktx yapısını ekleyin.
    • Player.listen askıya alma uzantısı işlevini, Player.Events dinlemek için bir ortak yordam döndürmek üzere media3-common-ktx kitaplığına ekleyin.
    • Çalışma zamanı sınıfı doğrulama hatalarını önlemek için tasarlanmış, manuel olarak satır dışı bırakılmış iç sınıflardan @DoNotInline ek açıklamalarını kaldırın. R8'in son sürümleri, çalışma zamanı hatalarını önlemek için artık bu tür satır dışı çağrıları otomatik olarak satır dışı hale getiriyor (bu nedenle, manuel satır dışı hale getirme artık gerekli değil). Kitaplığın tüm Gradle kullanıcıları, compileSdk = 35 nedeniyle bunu yapan bir R8 sürümünü kullanan Android Gradle eklentisinin bir sürümünü zaten kullanıyor olmalıdır. Gradle dışı derleme sistemlerine sahip kitaplık kullanıcılarının, çalışma zamanı sınıfı doğrulama hatalarını önlemek için R8'e eşdeğer küçültme/karartma adımının benzer bir otomatik satır dışı işlem gerçekleştirdiğinden emin olması gerekir. Bu değişiklik diğer AndroidX kitaplıklarında zaten yapıldı.
  • ExoPlayer:
    • MediaCodecRenderer.onProcessedStreamChange() artık her medya öğesi için aranabilir. Daha önce ilk için bu işlem gerekmiyordu. Bu özelliği etkinleştirmek için MediaCodecRenderer.experimentalEnableProcessedStreamChangedAtStart() kısayolunu kullanın.
    • Hata oluştuğunda PreloadMediaSource.PreloadControl.onPreloadError uygulamalarının işlem yapmasına izin vermek için PreloadMediaSource.PreloadControl ekleyin.
    • Önceden yükleme etkinliklerini uygulamalara yaymak için BasePreloadManager.Listener ekleyin.
    • Zaman aşımında SNTP istemci zaman aşımının değiştirilmesine ve alternatif adreslerin yeniden denenmesine izin verin (#1540).
    • Alan her zaman sıfır olduğu için MediaCodecAdapter.Configuration.flags değerini kaldırın.
    • Kullanıcının, Wear OS 35 ve sonraki sürümlerde (cihazın bu desteği duyurduğu yerlerde) oynatma için yerleşik hoparlörü seçmesine izin verin.
    • Ses odağı işleme etkinleştirilene kadar Context.getSystemService(Context.AUDIO_SERVICE) numarasına yapılan engelleme çağrısını erteleyin. Bu, ses odak işleme etkinleştirilmemişse engelleme işleminin yapılmamasını sağlar (#1616).
    • Yükleme başarısız olduğunda arabelleğe alınan süreye bakılmaksızın oynatmaya izin verilir (#1571).
    • Tek tek oluşturucular oynatmaya hazır olduğunda AnalyticsListener.onRendererReadyChanged() simgesini ekleyin.
    • MediaCodec.CryptoException, eşzamansız modda (API 31 ve sonraki sürümlerdeki varsayılan davranış) çalıştırıldığında bazen "beklenmeyen çalışma zamanı hatası" olarak bildirilen MediaCodec sorunu düzeltildi.
    • PreloadMediaSource.PreloadControl.onContinueLoadingRequested() ile bufferedPositionUs yerine bufferedDurationUs kart geçişi. Ayrıca, DefaultPreloadManager.Status.STAGE_LOADED_TO_POSITION_MS değerini DefaultPreloadManager.Status.STAGE_LOADED_FOR_DURATION_MS olarak değiştirir. Uygulamaların, konum yerine, karşılık gelen medya kaynağının bu IntDef ile önceden yüklenmesi gereken varsayılan başlangıç konumundan itibaren belirli bir süreyi temsil eden bir değer iletmesi gerekir.
    • Tüm yöntem çağrılarını başka bir oluşturucuya yönlendiren ForwardingRenderer uygulaması ekleyin (1703).
    • Oynatma listesindeki bir sonraki öğe için oynatma listesi önceden yükleme özelliğini ekleyin. Uygulamalar, ExoPlayer.setPreloadConfiguration(PreloadConfiguration) işlevini uygun şekilde çağırarak önceden yüklemeyi etkinleştirebilir. Önceden yükleme varsayılan olarak devre dışıdır. Bu özellik etkinleştirildiğinde ve oynatmayı engellememek için DefaultLoadControl, ön yüklemeyi yalnızca oynatıcı oynatma için yüklenmediğinde başlatıp devam ettirecek şekilde kısıtlar. Uygulamalar, LoadControl.shouldContinuePreloading()'ı uygun şekilde uygulayarak (ör. DefaultLoadControl'da bu yöntemi geçersiz kılarken) bu davranışı değiştirebilir. LoadControl'ın varsayılan uygulaması, bir uygulama LoadControl'ın özel bir uygulamasını kullanıyorsa ön yüklemeyi devre dışı bırakır.
    • Alt sınıf işleyicilerinin etkinliklerinin çağrılmasına izin vermek için MediaSourceEventListener.EventDispatcher.dispatchEvent() yöntemi eklendi ( 1736).
    • DefaultPreloadManager.Builder ekleyin. Bu, DefaultPreloadManager ve ExoPlayer örneklerini tutarlı bir şekilde paylaşılan yapılandırmalarla oluşturur.
    • DefaultLoadControl uygulaması, akış türlerini ExoTrackSelection[] öğesinden alabileceğinden Renderer[] parametresini LoadControl.onTracksSelected() öğesinden kaldırın.
    • Kullanımdan kaldırılan DefaultLoadControl.calculateTargetBufferBytes(Renderer[], ExoTrackSelection[]) ve geçersiz kılmayı önlemek için yöntem nihai olarak işaretlendi. Bunun yerine yeni DefaultLoadControl.calculateTargetBufferBytes(ExoTrackSelection[]) kullanılmalıdır.
    • MediaSourceEventListener içindeki ikincil kaynaklardan MediaSourceEventListener etkinliklerini raporlayın.MergingMediaSource Bu durum, yan yüklenen altyazılar (MediaItem.LocalConfiguration.subtitleConfigurations ile eklenenler) için yükleme başlatma/hata/iptal edildi/tamamlandı etkinliklerinin raporlanmasına neden olur. Bu etkinlikler, AnalyticsListener tarafından yayınlanan yinelenen yükleme etkinlikleri olarak görünebilir.
    • Altyazı ve meta veri hatalarının oynatmayı tamamen durdurmasını önleme Bunun yerine, sorunlu parça devre dışı bırakılır ve kalan parçaların oynatılmasına devam edilir (#1722).
      • Yeni altyazı işleme sürecinde (çıkarma sırasında), ilişkili ayrıştırma (ör. geçersiz altyazı verileri) ve yükleme hataları (ör. HTTP 404) onLoadError geri çağırmaları aracılığıyla yayınlanır.
      • Eski altyazı işleme yönteminde (oluşturma sırasında), yalnızca ilişkili yükleme hataları onLoadError geri çağırmaları aracılığıyla verilirken ayrıştırma hataları sessizce yoksayılır (bu, önceden var olan bir davranıştır).
    • Çok dönemli DASH akışlarındaki oynatma listesi öğelerinin veya dönemlerin, gerçek içerikle eşleşmeyen süreleri nedeniyle öğenin sonunda karelerin donmasına neden olabilmesiyle ilgili hata düzeltildi (#1698).
    • Müşterinin yeniden başlatılacağı son güncellemeden bu yana geçen maksimum süreyi ayarlamak için SntpClient öğesine bir ayarlayıcı ekleyin (#1794).
  • Dönüştürücü:
    • SurfaceAssetLoader ekleyin. Bu, Surface aracılığıyla video verilerinin Transformer'a sıraya alınmasını destekler.
    • ImageAssetLoader, IllegalStateException oluşturmak yerine AssetLoader.onError üzerinden desteklenmeyen girişleri bildirir.
    • Resim dışa aktarma için MediaItem.Builder.setImageDurationMs kullanılarak resim süresinin ayarlanmasını zorunlu kılın.
    • Ses EditedMediaItem'larının sıralarındaki boşluklar için dışa aktarma desteği eklendi.
  • Parça Seçimi:
    • DefaultTrackSelector: Diğer faktörler eşit olduğunda nesne tabanlı sesi kanal tabanlı sese tercih edin.
  • Ayıklayıcılar:
    • Mp4Extractor ve FragmentedMp4Extractor seçeneklerinin, sonraki örnekler tarafından referans olarak kullanılmayan H264 örneklerini tanımlamasına izin verin.
    • AmrExtractor içinde dizine dayalı arama özelliğini etkinleştirme seçeneği eklendi.
    • Geçerli kareler arasında 128 kB'tan fazla alan bulunan MP3 dosyaları, geçersiz yerine kısaltılmış olarak kabul edilir. Bu nedenle, sonunda MP3 olmayan veriler bulunan ve MP3 baytlarının uzunluğunu belirten başka meta verisi olmayan dosyalar artık ParserException: Searched too many bytes.{contentIsMalformed=true, dataType=1} (#1563) hatası vermek yerine MP3 verilerinin sonunda oynatmayı durduruyor.
    • MP4 dosyalarındaki düzenleme listeleri işlenirken, anahtar kare olmayan medya başlangıç konumları için ön rulo örneği işleme hatası düzeltildi (#1659).
    • mdhd box in Mp4Extractor ve FragmentedMp4Extractor (#1531) öğesindeki medya süresini kullanarak kare hızı hesaplaması iyileştirildi.
    • MP4 düzenleme listelerinde media_time öğesinin yanlış ölçeklendirilmesi düzeltildi. segment_duration, film zaman ölçeği kullanılarak zaten doğru şekilde ölçeklendirilmişken media_time, MP4 biçim standardında belirtildiği gibi parça zaman ölçeği kullanılarak artık düzgün şekilde ölçeklendiriliyor (#1792).
    • MP4'te düzenleme listesiyle endIndices hesaplamasında sırası bozuk kareleri işleme (#1797).
    • MP4 dosyalarının mdhd kutusundaki medya süresi ayrıştırma işlemini, -1 değerlerini işleyecek şekilde düzeltin (#1819).
    • H.263 video için MP4 dosyalarında h263 kutusunu tanımlama desteği eklendi ( (#1821)).
    • AC-4 Level-4 ISO temel medya dosyası biçimi desteği eklendi (#1265).
  • DataSource:
    • HttpEngineDataSource, API düzeyi 34 yerine S extension 7 sürümünden itibaren kullanıma izin verecek şekilde güncellendi (#1262).
    • DataSourceContractTest: DataSource.getUri()'nin, çözümlenmiş URI'yi (belgelendiği gibi) döndürdüğünü onaylayın. Bu durum, istenen URI'den farklı olduğunda testler yeni DataSourceContractTest.TestResource.Builder.setResolvedUri() yöntemiyle bunu belirtebilir.
    • DataSourceContractTest: DataSource.getUri() ve getResponseHeaders(), open() için başarısız bir çağrıdan (kaynak bulunamadığı için) sonra ve sonraki bir close() çağrısından önce "açık" değerini döndürür.
      • DataSourceContractTest.getNotFoundResources()'ı geçersiz kılmak, test alt sınıflarının birden fazla "bulunamadı" kaynağı ve beklenen başlıkları sağlamasına olanak tanır. Bu sayede HTTP 404 (başlıklarla) ile "sunucu bulunamadı" (başlık yok) arasında ayrım yapılabilir.
  • Ses:
    • Medya içeriğinde varsa codec'te CTA-2075 ses yüksekliği meta verilerini otomatik olarak yapılandırın.
    • Arama sırasında sesin sorunsuz bir şekilde azaltılmasını sağlar.
    • Arama sırasında oluşabilecek patlama seslerini düzeltir.
    • Sonic'in zamanı uzatma/perde değiştirme algoritması için kesme hatası birikimini düzeltir.
    • SpeedChangingAudioProcessor'da çıkış karelerinin düşmesine neden olan hata düzeltildi.
  • Video:
    • MediaCodecVideoRenderer, ne oluşturulan ne de diğer örnekler tarafından referans olarak kullanılan örneklerin kodunu çözmekten kaçınır.
    • API 35 ve sonraki sürümlerde, MediaCodecAdapter artık configure içinde null alabilir ve codec destekliyorsa daha önce ayarlanan Surface öğesini kaldırmak için yeni bir detachOutputSurface yöntemine çağrı yapabilir (MediaCodecInfo.detachedSurfaceSupported).Surface
    • MediaCodecAdapter işlenirken sağlanan piksel en boy oranı değerlerini kullanın onOutputFormatChanged (#1371).
    • Galaxy Tab S7 FE'de 60 fps'lik güvenli H264 akışlarının desteklenmiyor olarak işaretlenmesine neden olan cihaz sorunu için geçici çözüm eklendi (#1619).
    • Son örnekten sonra akış sonu sinyali döndürmeden takılan codec'ler için geçici çözüm eklendi.
  • Metin:
    • Özel bir VoiceSpan ekleyin ve bunu WebVTT ses aralıkları için doldurun (#1632).
    • Mikrosaniye olarak gösterilip long MPEG zaman tabanıyla çarpıldığında 64 bitlik 90,000 değeri aşan çok büyük altyazı zaman damgalarına sahip HLS'deki WebVTT'nin gösterildiğinden emin olun (#1763).
    • Dolby Vision içeriklerinde CEA-608 altyazılarını destekleme (#1820).
    • CEA-608 altyazıları etkinleştirildiğinde DASH çok dönemli akışlarda oynatmanın takılması sorunu düzeltildi (#1863).
  • Meta veri:
    • icy veya vnd.dvb.ait içerik barındıran parçalara C.TRACK_TYPE_METADATA türünü atayın.
  • Resim:
    • Glide veya Coil gibi harici resim yükleme kitaplıklarıyla entegrasyonu basitleştirmek için ExternallyLoadedImageDecoder ekleyin.
  • DataSource:
    • FileDescriptorDataSource işlevini ekleyin. Bu yeni DataSource, FileDescriptor öğesinden okumak için kullanılabilir (#3757).
  • Etki:
    • Küçük DefaultVideoFrameProcessor ölçeklendirme için SurfaceTexture geçici çözümü eklendi. SurfaceTexture, kırpılmış bir arabelleğin kenarındaki 1 teksel sınırını kesen küçük bir ölçeklendirme içerebilir. Bu durum artık çıktının beklenene daha yakın olması için ele alınmaktadır.
    • Hızlandırma DefaultVideoFrameProcessor.queueInputBitmap(). Bu sayede, Transformer ile görüntüleri videolara aktarma işlemi daha hızlı gerçekleşir.
  • IMA uzantısı:
    • Oynatma listesinin temizlenmesinin ArrayIndexOutOfBoundsException içinde ImaServerSideAdInsertionMediaSource'ye neden olabileceği hata düzeltildi.
    • Sunucu tarafında eklenen ve ön rulosuz DAI akışlarının, son videonun ortasında gösterilen reklamdan sonra oynatıldığında ArrayIndexOutOfBoundsException ile sonuçlanabildiği hata düzeltildi (#1741).
  • Oturum:
    • Uygulamaların, bu yöntemi geçersiz kılarak oynatmaya devam etme için gelen oynatma komutunu bastırmasına izin vermek üzere MediaButtonReceiver.shouldStartForegroundService(Intent) ekleyin. Hizmet varsayılan olarak her zaman başlatılır ve sistem, hizmeti ForegroundServiceDidNotStartInTimeException ile kilitlenmeden oynatma durdurulamaz (#1528).
    • Eski bir hizmete bağlanıldığında MediaBrowser cihazından gönderilen özel komutların, yöntemin MediaBrowserServiceCompat varyantı yerine MediaSessionCompat.Callback cihazına gönderilmesine neden olan hata düzeltildi. Bu durum, MediaBrowser öğesinin eski hizmet tarafından geri gönderilen gerçek dönüş değerini almasını engelliyordu (#1474).
    • Medya düğmesi amaçları için yayın alıcısı ayarlanırken belirli üreticilerin cihazları tarafından oluşturulan IllegalArgumentException işlenir (#1730).
    • Medya öğeleri için komut düğmeleri ekleyin. Bu, Custom browse actions olarak bilinenler için Media3 API'yi MediaBrowserCompat ile eski kitaplıkla birlikte ekler. Medya öğeleri için Media3 komut düğmelerinin hem MediaBrowser hem de MediaController için kullanılabildiğini unutmayın. Özel göz atma işlemlerini uygulama başlıklı makaleyi inceleyin. * Media3 denetleyicisinin bazen bir oturum uygulamasının play() isteğinde bulunduktan sonra ön plan hizmeti başlatmasına izin verememesine neden olan hata düzeltildi.
    • CommandButton.Builder.setIconUri'nın yalnızca içerik URI'lerini kabul etmesini sağlayın.
    • Eski bir MediaBrowserCompat öğesine bağlanırken Media3 tarayıcısının bağlantı ipuçlarını ilk MediaBrowserCompat öğesine iletin. Hizmet, onGetRoot() için yapılan ilk çağrıyla kök ipuçları olarak iletilen bağlantı ipuçlarını alabilir.
    • Eski bir tarayıcı hizmetine bağlı MediaBrowser sunucusunun, tarayıcı bir parentid aboneliği oluşturduktan sonra hizmet tarafından gönderilen hatayı almamasına neden olan hata düzeltildi.
    • Böylece, eski bir MediaBrowserService öğesine bağlı olan bir Media3 tarayıcısı, bir üst öğeye abone olurken parentId öğesinin alt öğelerini iki kez istemez.
  • UI:
    • XML tabanlı paylaşılan geçişlerle ilgili sorunlar nedeniyle, PlayerView-in-Compose-AndroidView geçici çözümünde uzatılmış/kırpılmış video oluşturma özelliği etkinleştirildi. PlayerView kullanan uygulamaların AndroidView etkinleştirmek için PlayerView.setEnableComposeSurfaceSyncWorkaround çağrısı yapması gerekir (#1237, #1594).
    • Tam ekran düğmesinin simgesinin isteğe bağlı olarak (ör. bant dışı ve tıklama etkileşimine tepki vermeden) güncellenmesine izin vermek için setFullscreenButtonState, PlayerView'ye eklendi (#1590, #184).
    • Uygulama tarafından tanımlanan metin parçası seçimi tercihleri varsa metin seçiminde "Yok" seçeneğinin çalışmaması hatası düzeltildi.
  • DASH uzantısı:
    • Bir segmentin ortasında başlayan dönemler için destek eklendi (#1440).
  • Smooth Streaming Uzantısı:
    • Metin parçaları içeren SmoothStreaming akışları oynatılırken oluşan Bad magic number for Bundle hatası düzeltildi ( #1779).
  • RTSP Uzantısı:
    • Kodlanmış @ karakterleri içeren URL'lerde kullanıcı bilgilerinin kaldırılmasıyla ilgili sorun düzeltildi (#1138).
    • Başlık uzantıları içeren RTP paketleri ayrıştırılırken kilitlenme sorununu düzeltme (#1225).
  • Kod Çözücü Uzantıları (FFmpeg, VP9, AV1 vb.):
    • Ses sentezlemek için libiamf yerel kitaplığını kullanarak IAMF parçaları içeren MP4 dosyalarının oynatılmasını destekleyen IAMF kod çözücü modülünü ekleyin.
      • Oynatma, stereo düzenin yanı sıra isteğe bağlı kafa hareketi izleme özelliği etkinleştirilmiş olarak uzamsallaştırma ile 5.1 şeklinde de etkinleştirilir ancak şu anda binaural oynatma desteği sunulmamaktadır.
    • Android 15'te kod çözücü uzantıları için 16 KB sayfa desteği eklendi (#1685).
  • Cast Uzantısı:
    • CastSession bağlantısı kesildikten sonra zaman çizelgesini temizlemeyi durdurur. Bu sayede gönderen uygulama, bağlantı kesildikten sonra oynatmaya yerel olarak devam edebilir.
    • Context sağlandığında CastPlayer'ın DeviceInfo özelliğini doldurun. Bu, MediaSession öğesinin RoutingSession öğesine bağlanmasını sağlar. Bu, Çıkış Anahtarı'nın entegrasyonu için gereklidir (#1056).
  • Test yardımcı programları:
    • DataSourceContractTest artık aşağıdakileri doğrulamak için testler içerir:
      • Giriş akışı read position güncellendi.
      • Çıkış arabelleği offset doğru şekilde uygulanır.
  • Demo uygulaması
    • Kısa biçimli demo uygulamasındaki bellek sızıntılarını düzeltin (#1839).
  • Desteği sonlandırılan sembolleri kaldırın:
    • Kullanımdan kaldırılan Player.hasPrevious, Player.hasPreviousWindow() öğelerini kaldırın. Bunun yerine Player.hasPreviousMediaItem() politikasını kullanın.
    • Desteği sonlandırılan Player.previous() yöntemi kaldırıldı. Bunun yerine Player.seekToPreviousMediaItem() kullanın.
    • Desteği sonlandırılan DrmSessionEventListener.onDrmSessionAcquired yöntemi kaldırıldı.
    • Desteği sonlandırılan DefaultEncoderFactory oluşturucularını kaldırın. Bunun yerine DefaultEncoderFactory.Builder kullanın.

Sürüm 1.5.0-rc02

19 Kasım 2024

1.5.0 kararlı sürümünü kullanın.

Sürüm 1.5.0-rc01

13 Kasım 2024

1.5.0 kararlı sürümünü kullanın.

Sürüm 1.5.0-beta01

30 Ekim 2024

1.5.0 kararlı sürümünü kullanın.

Sürüm 1.5.0-alpha01

10 Eylül 2024

1.5.0 kararlı sürümünü kullanın.

Sürüm 1.4.0

Sürüm 1.4.1

27 Ağustos 2024

androidx.media3:media3-*:1.4.1 iptal edilir. 1.4.1 sürümü bu commit'leri içerir.

  • ExoPlayer:
    • Önceden yükleme geri çağırmalarını PreloadMediaSource içinde eşzamansız olarak işleme (#1568).
    • Yükleme başarısız olduğunda arabelleğe alınan süreye bakılmaksızın oynatmaya izin verilir (#1571).
  • Ayıklayıcılar:
    • MP3: Searched too many bytes hatasını, Info çerçevesindeki uzunluk alanına göre sondaki MP3 dışı verileri doğru şekilde yoksayarak düzeltin (#1480).
  • Metin:
    • TTML: Yüzde tts:fontSize değerlerinin, yüzde tts:fontSize değerlerine sahip üst düğümlerden doğru şekilde devralınmasını sağlamak için yüzde tts:fontSize değerlerinin işlenmesi düzeltildi.
    • İstenen çıkış başlangıç zamanının Subtitle'daki son etkinlik zamanından büyük veya ona eşit olması durumunun yanlış işlenmesi nedeniyle LegacySubtitleUtil içinde IndexOutOfBoundsException düzeltildi (#1516).
  • DRM:
    • API 31 ve sonraki sürümlerdeki cihazlarda android.media.MediaCodec$CryptoException: Operation not supported in this configuration: ERROR_DRM_CANNOT_HANDLE hatasını düzeltme L1 Widevine içeriği oynatılırken Bu hata, MediaDrm.requiresSecureDecoder yönteminin (#1603) eksik uygulanmasından kaynaklanır.
  • Etki:
    • GlObjectsProvider öğesine release() yöntemi ekleyin.
  • Oturum:
    • KEYCODE_HEADSETHOOK simgesine iki kez dokunma işlemini, belgelendirildiği gibi "sonrakine git" işlemine dönüştürür (#1493).
    • KEYCODE_HEADSETHOOK öğesini, ForegroundServiceDidNotStartInTimeException (#1581) hatasını önlemek için yoksayılıp yoksayılmayacağına karar verirken MediaButtonReceiver içinde "oynat" komutu olarak ele alın.
  • RTSP Uzantısı:
    • SDP ayrıştırmasında geçersiz medya açıklamalarını atlayın (#1087).

Sürüm 1.4.0

25 Temmuz 2024

androidx.media3:media3-*:1.4.0 iptal edilir. 1.4.0 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • İşlem yapmayan arama çağrıları olduğu varsayılanları yok saymak yerine korumalı BasePlayer.seekTo() ve SimpleBasePlayer.handleSeek() yöntemlerine yönlendirin. Bu yöntemleri özel bir oynatıcıda uyguluyorsanız bu ek çağrıları mediaItemIndex == C.INDEX_UNSET ile işlemeniz gerekebilir.
    • Gelişmiş Java 8 desugaring'e yönelik derleme bağımlılığını kaldırın (#1312).
    • MediaItem.Builder.setImageDurationMs() öğesine iletilen sürenin, resim olmayan bir MediaItem için yoksayıldığından (belgelendiği gibi) emin olun.
    • Format örnekleriyle ilgili uygulama tarafından sağlanan özel bilgileri depolamak için Format.customData ekleyin.
  • ExoPlayer:
    • BasePreloadManager ekleyin. Bu, rankingData tarafından tanımlanan önceliklere göre birden fazla kaynak için önceden yüklemeyi koordine eder. Bu sınıf genişletilerek özelleştirme yapılabilir. Kaynakların medya örneklerini belleğe önceden yüklemek için PreloadMediaSource kullanan ve kullanıcı arayüzündeki bir öğenin dizinini belirten bir tam sayı rankingData kullanan DefaultPreloadManager öğesini ekleyin.
    • PlayerId, LoadControl uygulamalarının birden fazla oyuncuyu desteklemesini sağlamak için çoğu LoadControl yöntemine eklenir.
    • Buffer.isDecodeOnly() ve C.BUFFER_FLAG_DECODE_ONLY araçlarını kaldırın. Bu işaretin ayarlanmasına gerek yoktur. Oluşturucular ve kod çözücüler, zaman damgasına göre arabellekleri atlamaya karar verir. Özel Renderer uygulamaları, bir örneğin gösterilip gösterilmeyeceğine karar vermek için arabellek süresinin en az BaseRenderer.getLastResetPositionUs() olup olmadığını kontrol etmelidir. Özel SimpleDecoder uygulamaları gerekirse isAtLeastOutputStartTimeUs() işaretini kullanarak kontrol edebilir veya diğer arabellekleri DecoderOutputBuffer.shouldBeSkipped işaretiyle işaretleyerek atlayabilir.
    • TargetPreloadStatusControl.getTargetPreloadStatus(T) tarafından boş değer döndürülmesine izin vererek MediaSource öğesinin verilen rankingData ile önceden yüklenmemesi gerektiğini belirtin.
    • remove(MediaSource) öğesini BasePreloadManager öğesine ekleyin.
    • Önceden yükleme yöneticisi örneğini korurken tüm bekletme kaynaklarını serbest bırakmak için reset() öğesini BasePreloadManager öğesine ekleyin.
    • ExoPlayer.setPriority() (ve Builder.setPriority()) ekleyerek PriorityTaskManager içinde kullanılan öncelik değerini ve API 35'ten itibaren MediaCodec önemini tanımlayın.
    • Son yeniden arabelleğe alma zamanının güncellenmesiyle ilgili sorun düzeltildi. Bu sorun, CMCD'de yanlış bs (arabellek yetersizliği) anahtarına neden oluyordu (#1124).
    • Kaynağın sonuna kadar yüklendiğini belirtmek için PreloadMediaSource.PreloadControl.onLoadedToTheEndOfSource(PreloadMediaSource) ekleyin. Bu, DefaultPreloadManager ve özel PreloadMediaSource.PreloadControl uygulamalarının bir sonraki kaynağı önceden yüklemesine veya başka işlemler yapmasına olanak tanır.
    • Öğelerin sonundaki sessizliği atlamanın oynatma istisnasına neden olabilmesi hatası düzeltildi.
    • Önceden yükleme dönemini iptal etmek için clear öğesini PreloadMediaSource öğesine ekleyin.
    • Codec kaynakları daha yüksek öncelikli görevler için geri kazanıldığında kullanılan yeni hata kodu PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMED eklendi.
    • AdsMediaSource, ilk içerik medyası hazırlığı tamamlanmadan önce videodan önce gösterilen reklamları yükleyebilir (#1358).
    • Orijinal dönem manifestten kaldırıldıktan sonra çok dönemli bir DASH canlı yayını yeniden hazırlanırken oynatmanın STATE_ENDED'e geçmesine neden olan hata düzeltildi.
    • onTimelineRefreshed() öğesini onSourcePrepared(), onPrepared() öğesini ise onTracksSelected() olarak yeniden adlandırın. PreloadMediaSource.PreloadControl içinde. Ayrıca, DefaultPreloadManager.Stage içindeki IntDefs'leri de uygun şekilde yeniden adlandırın.
    • Çalışmayı CPU uyandırma döngüleriyle daha iyi uyumlu hale getirmek ve oluşturucular ilerleyebilene kadar uyandırmayı geciktirmek için deneysel dinamik planlama desteği eklendi. ExoPlayer örneğinizi oluştururken experimentalSetDynamicSchedulingEnabled() kullanarak bu özelliği etkinleştirebilirsiniz.
    • Renderer.getDurationToProgressUs() ekleyin. Bir Renderer, oynatıcının ilerlemesi için oynatmanın ne kadar süre ilerlemesi gerektiğini ExoPlayer'a döndürmek üzere bu yöntemi uygulayabilir. ExoPlayer, experimentalSetDynamicSchedulingEnabled() ile ayarlanmışsa ExoPlayer, iş görevini planlama süresini hesaplarken bu yöntemi çağırır.
    • MediaCodecAdapter#OnBufferAvailableListener giriş ve çıkış arabellekleri MediaCodecRenderer tarafından kullanılmaya hazır olduğunda uyarı vermek için MediaCodecAdapter#OnBufferAvailableListener ekleyin. MediaCodecRenderer, bu geri çağırmaları aldığında ExoPlayer sinyalini verir ve ExoPlayer, experimentalSetDynamicSchedulingEnabled() ile ayarlanırsa ExoPlayer, oluşturucular ilerleme kaydedebildiğinden çalışma döngüsünü planlar.
    • Ayrı parametreler yerine LoadControl yöntemleri için veri sınıfını kullanın.
    • ExoPlayer.isReleased() işlevinin çağrılıp çağrılmadığını kontrol etmek için Exoplayer.release() işlevini ekleyin.
    • ExoPlayer.Builder.setMaxSeekToPreviousPositionMs(), seekToPrevious() öğesinin önceki öğeyi aradığı maksimum konumu yapılandırmak için eklenir (#1425).
    • Bazı ses odağı tutarsızlıklarını düzeltme (ör. oynatıcı duraklatıldığında tam veya geçici odak kaybının bildirilmemesi) (#1436).
    • Ayıklayıcıların ilk hazırlık adımından sonra ek parçalar bildirmesinden kaynaklanan olası IndexOutOfBoundsException sorunları düzeltildi (#1476).
    • Effects içindeki ExoPlayer.setVideoEffect(), oluşturucu farkı kaldırılmış zaman damgalarını alır (#1098).
    • Başka bir oynatma listesi öğesi önceden okunurken oluşan oynatıcı hatası işlenirken olası IllegalArgumentException düzeltildi (#1483).
  • Dönüştürücü:
    • Çıkış dosyasındaki ilgili parçanın nasıl oluşturulduğunu belirtmek için audioConversionProcess ve videoConversionProcess simgelerini ekleyin. ExportResult
    • H.264 seviyesi kontrollerinde kırpma optimizasyonunu gevşetin.
    • Bir dizide SDR ve HDR giriş medyası arasında geçiş yapma desteği eklendi.
    • Beste düzeyinde ses efektleri için destek eklendi.
    • Ultra HDR görüntülerin HDR videolara dönüştürülmesi için destek eklendi.
    • DefaultAudioMixer sıfırlanıp yeniden kullanıldıktan sonra doğru miktarda bayt çıkışı vermemesine neden olan sorun düzeltildi.
    • PCM girişi işlenirken ses kanalı sayısının stereo ile sınırlandırıldığı bir kod çözücü hatası giderildi.
    • ExoPlayerAssetLoader bölümünde parça seçerken yalnızca oynatma için geçerli olduklarından ses kanalı sayısı kısıtlamalarını dikkate almayın.
    • androidx.media3.transformer.Muxer arayüzünü androidx.media3.muxer.Muxer ile değiştirin ve androidx.media3.transformer.Muxer öğesini kaldırın.
    • İçerik URI şemalarından HEIC resim yükleme sorunu düzeltildi. (#1373).
    • AV senkronizasyonunu iyileştirmek için AudioGraphInput bölümünde ses parçası süresini ayarlayın.
    • ExportResult.processedInputs alanını kaldırın. Bu alanı codec ayrıntıları için kullanıyorsanız bunun yerine DefaultDecoderFactory.listener kullanın. Codec istisnası durumunda codec ayrıntıları ExportException.codecInfo bölümünde yer alır.
  • Ayıklayıcılar:
    • MPEG-TS: Değişikliği, son erişim birimini örnek sırasına ileterek son karenin oluşturulmasını sağlayacak şekilde ileriye taşıyın (#7909). Yalnızca I-frame HLS akışlarında(#1150) ve H.262 HLS akışlarında (#1126) ortaya çıkan sorunları gidermek için düzeltmeler yapıldı.
    • MP3: Temel akış tarafından bildirilen boyuta (ör. dosya boyutu veya HTTP Content-Length başlığı) kıyasla Info çerçevesindeki veri boyutu tercih edilir. Bu, oynatılamayan fragman verilerinin (ör. albüm kapakları) sabit bit hızı arama hesaplamalarından hariç tutulmasına yardımcı olarak aramaları daha doğru hale getirir (#1376).
    • MP3: Sabit bit hızlı arama için ortalama bir bit hızı hesaplamak üzere Info çerçevesindeki (varsa) çerçeve sayısı ve diğer verileri kullanın. Info çerçevesinden sonraki çerçevenin bit hızından ekstrapolasyon yapmayın. Bu, yapay olarak küçük olabilir (ör. PCUT çerçevesi (#1376)).
    • AVI kapsayıcılarda PCM ses biçimi ayıklama sorununu düzeltir.
  • Ses:
    • Geçiş oynatma için DTS:X Profile 2 kodlama özelliklerini düzeltin (#1299).
    • Boşaltılmış oynatma için, AudioTrack.stop() çağrılmadan önce DefaultAudioSink içinde akış tamamlama için izleme alanını sıfırlayın. Böylece AudioTrack.StreamEventCallback#onPresentationEnded, bekleyen tüm verilerin ne zaman oynatıldığını doğru şekilde tanımlar.
    • Farklı ses biçimleri (ör. stereo'dan mono'ya) arasındaki geçişlerin işlemcinin istisna oluşturmasına neden olabildiği SilenceSkippingAudioProcessor bölümündeki hata düzeltildi (#1352).
    • MediaCodecAudioRenderer.getDurationToProgressUs() uygulayın. Böylece ExoPlayer, ana iş döngüsünü MediaCodecAudioRenderer'ın ilerleyebileceği zamana göre dinamik olarak planlar.
  • Video:
    • Oynatma sırasında yüzey değiştirildiğinde Listener.onRenderedFirstFrame() simgesinin çok erken gelmesi sorunu düzeltildi.
    • Gerekirse uyumlu bir AV1 kod çözücü kullanmak için Dolby Vision'daki kod çözücü yedek mantığını düzeltin (#1389).
    • Video oluşturucunun oynatma sırasında etkinleştirilmesinden kaynaklanabilecek codec istisnası düzeltildi.
  • Metin:
    • Arama konumundan önce başlayan altyazıların atlanmasına neden olan sorun düzeltildi. Bu sorun yalnızca Media3 1.4.0-alpha01 sürümünde ortaya çıkmıştır.
    • Varsayılan altyazı ayrıştırma davranışını, oluşturma sırasında değil, çıkarma sırasında gerçekleşecek şekilde değiştirin (çıkarma ve oluşturma arasındaki fark için ExoPlayer'ın mimari şemasını inceleyin).
      • Bu değişiklik, hem MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(false) hem de TextRenderer.experimentalSetLegacyDecodingEnabled(true) çağrılarak geçersiz kılınabilir. Bu bileşenleri bir ExoPlayer örneğine nasıl bağlayacağınızla ilgili bilgileri özelleştirme belgelerinde bulabilirsiniz. Bu yöntemler (ve eski altyazı kod çözme desteği) gelecekteki bir sürümde kaldırılacaktır.
      • Özel SubtitleDecoder uygulamaları olan uygulamaların, SubtitleDecoder yerine SubtitleParser'yi (ve SubtitleDecoderFactory yerine SubtitleParser.Factory) uygulamak için güncellenmesi gerekir.
    • PGS: 0 öğesini sabit renk değeri (#1367) yerine renk dizini olarak çözmek için uzunluk kod çözme sorununu düzeltin.
    • CEA-708: rowLock değerini yoksayın. CEA-708-E S-2023 spesifikasyonu, akışta bulunan değerlerden bağımsız olarak hem rowLock hem de columnLock değerlerinin doğru kabul edilmesi gerektiğini belirtir (columnLock desteği uygulanmadığından her zaman yanlış olduğu varsayılır).
      • Bu değişiklik başlangıçta 1.3.0-alpha01 sürüm notlarına dahil edilmişti ancak 1.3.0-rc01 sürümünden önce yanlışlıkla geri alınmıştı. Bu sorun düzeltildi ve değişiklik tekrar gösteriliyor.
    • CEA-708: ExoPlayer'ın "kalem konumunu ayarla" komutunu basit bir şekilde işlemesi nedeniyle eklenen yinelenen yeni satırları önleyin (#1315).
    • Bir WebVTT altyazı örneği ipucu içermediğinde (ör. DASH akışının bir parçası olarak) IllegalArgumentException LegacySubtitleUtil sorununu düzeltin (#1516).
  • Meta veri:
    • MP4'ün ID3 sıralama etiketleriyle eşlenmesi düzeltildi. Daha önce "albüm sıralama" (soal), "sanatçı sıralama" (soar) ve "albüm sanatçısı sıralama" (soaa) MP4 etiketleri, TSO2, TSOA ve TSOP ID3 etiketleriyle yanlış şekilde eşleniyordu (#1302).
    • Değer birden fazla bayt uzunluğunda olduğunda MP4 (/iTunes) sayısal gnre (tür) ve tmpo (tempo) etiketlerinin okunmasıyla ilgili sorun düzeltildi.
    • ID3 TCON çerçevesini MediaMetadata.genre konumuna yayınlayın (#1305).
  • Resim:
    • Kare olmayan DASH küçük resim ızgaraları için destek eklendi (#1300).
    • API 34 ve sonraki sürümlerde AVIF desteği eklendi.
    • Daha önce ayarlanmış bir ImageOutput değerini temizlemek için ExoPlayer.setImageOutput() parametresi olarak null değerine izin verin.
  • DataSource:
    • android.resource://package/id ham kaynak URI'leri için destek uygulayın. Burada package, mevcut uygulamanın paketinden farklıdır. Bu yöntem daha önce çalışır şekilde belgelenmemişti ancak başka bir paketteki kaynaklara ada göre erişmekten daha verimli bir yöntemdir.
    • url'nın DataSpec oluşturucularında null olmayan bir değer olup olmadığını kontrol edin. Bu parametre zaten null olmayan olarak açıklama eklenmiş.
    • ByteArrayDataSource, bir URI'yi oluşturma sırasında sabit kodlanmak yerine open() sırasında bir bayt dizisine çözebilir (#1405).
  • DRM:
    • DefaultDrmSessionManagerProvider üzerinde LoadErrorHandlingPolicy ayarlanmasına izin verin DefaultDrmSessionManagerProvider (#1271).
  • Etki:
    • SpeedChangeEffect içinde aynı EditedMediaItem veya Composition içinde birden fazla hız değişikliği desteği.
    • Ultra HDR bit eşlem girişinden HLG ve PQ çıkışı desteği.
    • EGL_GL_COLORSPACE_BT2020_HLG_EXT desteği eklendi. Bu destek, ExoPlayer.setVideoEffect ve Transformer'ın DebugSurfaceView'da HLG yüzey çıkışını iyileştirir.
    • setOverlayFrameAnchor() içinde uygulanan x ve y değerlerini ters çevirerek yer paylaşımı matrisi uygulamasını dokümanlarla tutarlı olacak şekilde güncelleyin. OverlaySettings.Builder.setOverlayFrameAnchor() kullanılıyorsa x ve y değerlerini -1 ile çarparak ters çevirin.
    • TimestampWrapper, ExoPlayer#setVideoEffects ile kullanıldığında kilitlenmesine neden olan hata düzeltildi ExoPlayer#setVideoEffects (#821).
    • Varsayılan SDR renk çalışma alanını doğrusal renklerden elektriksel BT 709 SDR videosuna değiştirin. Ayrıca orijinal renk alanını korumak için üçüncü bir seçenek sunun.
    • EditedMediaItemSequences'ın belirsiz z-sırasının tanımlanmasına izin verilir (#1055).
    • Farklı HDR içeriklerinde tutarlı bir parlaklık aralığı korur (HLG aralığını kullanır).
    • HDR içeriklerde Ultra HDR (bitmap) katmanları için destek eklendi.
    • SeparableConvolution efektlerinin API 26'dan önce kullanılmasına izin verin.
    • Yer paylaşımı ve çerçevenin dinamik aralığı eşleşmelidir. Bu nedenle, kullanılmayan OverlaySettings.useHdr kaldırılmalıdır.
    • TextOverlay için HDR desteği eklendi. Metin yer paylaşımının parlaklığı OverlaySettings.Builder.setHdrLuminanceMultiplier() ile ayarlanabilir.
  • IMA uzantısı:
    • Uygulamaların DAI reklam akışlarını oynatması için gereken Promote API'yi kararlı sürüme yükseltin.
    • Reklam etiketi parametrelerinin çalışma zamanında değiştirilmesine olanak tanıyan replaceAdTagParameters(Map <String, String>) işlevi eklendi.ImaServerSideAdInsertionMediaSource.AdLoader
    • Reklam oynatma sırasında oynatıcı hatası oluştuğunda VideoAdPlayer.VideoAdPlayerCallback.onError() işlevinin çağrılmamasına neden olan hata düzeltildi (#1334).
    • data:// reklam etiketi URI'leri kullanılırken NullPointerException hatasını düzeltmek için IMA SDK sürümünü 3.33.0'a yükseltin (#700).
  • Oturum:
    • CommandButton.enabled varsayılanını true olarak değiştirin ve ilişkili komut kullanılabilir olsa bile değerin denetleyiciler için yanlış kalmasını sağlayın.
    • Özel simge kaynakları yerine kullanılması gereken CommandButton için simge sabitleri ekleyin.
    • Uygulamaların, hizmetin onTaskRemoved() içinde durdurulması gerekip gerekmediğini sorgulamasına izin vermek için MediaSessionService.isPlaybackOngoing() ekleyin (#1219).
    • Tüm oturumların oynatılmasını kolayca duraklatmaya olanak tanıyan MediaSessionService.pauseAllPlayersAndStopSelf() işlevini ekleyin ve MediaSessionService yaşam döngüsünü sonlandırmak için stopSelf() işlevini çağırın.
    • MediaSessionService.onTaskRemoved(Intent) işlevini geçersiz kılarak güvenli bir varsayılan uygulama sağlayın. Bu uygulama, oynatma devam ediyorsa hizmeti ön planda çalışır durumda tutar, aksi takdirde hizmeti durdurur.
    • Süreyi platform oturumu meta verilerine ayarlamayarak canlı yayınlar için medya bildiriminde arama çubuğunu gizleyin (#1256).
    • Meta veri özelliklerini seçerken media1'dekiyle aynı tercih edilen sırayı ve mantığı kullanmak için MediaMetadata dönüşümünü MediaDescriptionCompat ile hizalayın.
    • MediaSession.sendError() ekleyin. Bu, önemli olmayan hataların Media3 denetleyicisine gönderilmesine olanak tanır. Bildirim denetleyicisi (bkz. MediaSession.getMediaNotificationControllerInfo()) kullanılırken özel hata, platform oturumunun PlaybackState değerini verilen hata bilgileriyle birlikte hata durumuna güncellemek için kullanılır ( #543).
    • Belirli bir kumandadan gelen bir dizi oynatıcı etkileşimi sona erdiğinde oturumları bilgilendirmek için MediaSession.Callback.onPlayerInteractionFinished() ekleyin.
    • SessionError ekleyin ve hata hakkında daha fazla bilgi sağlamak için hata kodu yerine SessionResult ve LibraryResult içinde kullanın. Mümkünse hatanın nasıl çözüleceği hakkında da bilgi verin.
    • Medya oturumu yayınlayan uygulamalarla etkileşimleri test etmek için kullanılabilecek media3 denetleyici test uygulamasının kodunu yayınlayın.
    • media3'ün MediaSession[Builder].setSessionExtras() öğesine iletilen ekstraları, media1 denetleyicisinin MediaSession[Builder].setSessionExtras() öğesine yayma.PlaybackStateCompat.getExtras()
    • Önemli ve önemsiz hataları platform oturumuna ve platform oturumundan eşleyin. PlaybackException, PlaybackStateCompat öğesinin kritik hata durumuna eşlenir. MediaSession.sendError(ControllerInfo, SessionError) ile medya bildirimi denetleyicisine gönderilen SessionError, PlaybackStateCompat içinde ölümcül olmayan bir hatayla eşlenir. Bu, hata kodu ve mesajının ayarlandığı ancak platform oturumunun durumunun STATE_ERROR'den farklı kaldığı anlamına gelir.
    • Genel oturum etkinliğini geçersiz kılmak için oturum etkinliğinin kontrol cihazı başına ayarlanmasına izin verin. Oturum etkinliği, bağlantı sırasında ConnectionResult oluşturularak bir denetleyici için tanımlanabilir.AcceptedResultBuilder.setSessionActivivty(PendingIntent) Bağlantı kurulduktan sonra oturum etkinliği MediaSession.setSessionActivity(ControllerInfo, PendingIntent) ile güncellenebilir.
    • MediaLibrarySession.Callback'a yapılan çağrıların hata tekrarını iyileştirin. Hata çoğaltma özelliği, hata türünü seçmek için MediaLibrarySession.Builder.setLibraryErrorReplicationMode() kullanılarak yapılandırılabilir veya varsayılan olarak etkin olan hata çoğaltma özelliği devre dışı bırakılabilir.
  • UI:
    • ExoPlayer cihazına bağlandığında PlayerView cihazına görüntüleme desteği ekleyin (#1144).
    • PlayerControlView örneği başına farklı çizilebilir öğelere izin vermek için xml özellikleriyle PlayerControlView'deki çeşitli simgelerin özelleştirilmesini ekleyin (#1200).PlayerView
    • API 34'te Compose AndroidView içinde SurfaceView kullanılırken videonun uzamasına/kırpılmasına neden olan platform hatası düzeltildi (#1237).
  • İndirilenler:
    • DownloadHelper'nın yayınlanmamış Renderer örneklerini sızdırmadığından emin olun. Bu durum, uygulamanın IllegalStateException: Too many receivers, total of 1000, registered for pid ile kilitlenmesine neden olabilir (#1224).
  • Cronet Uzantısı:
    • SocketTimeoutException ile ilgili sorunu CronetDataSource içinde düzeltin. Cronet'in bazı sürümlerinde geri çağırma tarafından sağlanan istek her zaman aynı değildir. Bu durum, geri aramanın tamamlanmamasına ve isteğin zaman aşımına uğramasına neden olur (https://issuetracker.google.com/328442628).
  • HLS Uzantısı:
    • Kesintiyi bekleyen bekleyen EMSG örneklerinin HlsSampleStreamWrapper içinde yanlış bir ofsetle temsil edilerek IndexOutOfBoundsException veya IllegalArgumentException'ye neden olduğu hata düzeltildi (#1002).
    • LL-HLS yayınlarında birincil olmayan oynatma listelerinin sürekli yeniden yüklenmesine neden olan hata düzeltildi (#1240).
    • Başlatma segmentleriyle HLS için CMCD'nin etkinleştirilmesinin Source Error ve IllegalArgumentException ile sonuçlandığı hata düzeltildi.
    • Birincil oynatma listesi olmayan oynatma listelerinin canlı oynatma sırasında yenilenmemesi hatası düzeltildi (#1240).
    • HLS canlı yayınlarında CMCD'nin etkinleştirilmesinin neden olduğu hatayı düzeltildi ArrayIndexOutOfBoundsException (#1395).
  • DASH Uzantısı:
    • Çok dönemli bir canlı yayının yeniden hazırlanmasının IndexOutOfBoundsException (#1329) hatasına neden olduğu hata düzeltildi.
    • dashif:Laurl lisans URL'leri için destek eklendi (#1345).
  • Cast Uzantısı:
    • Media3 medya öğesindeki MediaQueueItem albüm başlığını sanatçıya dönüştüren hata düzeltildi (#1255).
  • Test yardımcı programları:
    • FakeRenderer içinde onInit() ve onRelease() işaretlemelerini uygulayın.
    • TestPlayerRunHelper.runUntil()/playUntil() yöntemlerini, önemli olmayan hatalarda (ör. AnalyticsListener.onVideoCodecError()'a bildirilenler) başarısız olacak şekilde değiştirin. Bu davranışı devre dışı bırakmak için yeni TestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX() yöntem zincirini kullanın.
  • Demo uygulaması:
    • Kısa form demo uygulamasında DefaultPreloadManager kullanın.
    • Komut satırından Intent bağımsız değişkenleriyle tekrar modunun ayarlanmasına izin verin (#1266).
    • Cihaz tarafından desteklendiğinde HttpEngineDataSource adresini HttpDataSource olarak kullanın.
  • Desteği sonlandırılan sembolleri kaldırın:
    • CronetDataSourceFactory öğesini kaldırın. Bunun yerine CronetDataSource.Factory kullanın.
    • Bazı DataSpec oluşturucuları kaldırın. Bunun yerine DataSpec.Builder politikasını kullanın.
    • setContentTypePredicate(Predicate) yöntemi, DefaultHttpDataSource, OkHttpDataSource ve CronetDataSource öğelerinden kaldırıldı. Bunun yerine her XXXDataSource.Factory için eşdeğer yöntemi kullanın.
    • OkHttpDataSource oluşturucularını ve OkHttpDataSourceFactory'yi kaldırın. Bunun yerine OkHttpDataSource.Factory politikasını kullanın.
    • PlayerMessage.setHandler(Handler) öğesini kaldırın. Bunun yerine setLooper(Looper) kullanın.
    • Timeline.Window.isLive alanını kaldırın. Bunun yerine isLive() yöntemini kullanın.
    • DefaultHttpDataSource yapılandırıcılarını kaldırın. Bunun yerine DefaultHttpDataSource.Factory kullanın.
    • DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS öğesini kaldırın. Bunun yerine DashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MS kullanın.
    • MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean) öğesini kaldırın. Bunun yerine MediaCodecInfo.canReuseCodec(Format, Format) politikasını kullanın.
    • DrmSessionManager.DUMMY ve getDummyDrmSessionManager() yöntemini kaldırın. Bunun yerine DrmSessionManager.DRM_UNSUPPORTED politikasını kullanın.
    • AnalyticsListener.onAudioInputFormatChanged(EventTime, Format), AnalyticsListener.onVideoInputFormatChanged(EventTime, Format), AudioRendererEventListener.onAudioInputFormatChanged(Format), VideoRendererEventListener.onVideoInputFormatChanged(Format) öğelerini kaldırın. Bunun yerine DecoderReuseEvaluation alanını kullanan aşırı yüklemeleri kullanın.
    • RendererSupport.FormatSupport IntDef ve FORMAT_HANDLED, FORMAT_EXCEEDS_CAPABILITIES, FORMAT_UNSUPPORTED_DRM, FORMAT_UNSUPPORTED_SUBTYPE, FORMAT_UNSUPPORTED_TYPE sabitlerini kaldırın. Bunun yerine androidx.media3.common.C içindeki eşdeğer IntDef ve sabitleri (ör. C.FORMAT_HANDLED) kullanın.
    • Bundleable arayüzünü kaldırın. Buna, tüm Bundleable.Creator<Foo> CREATOR sabit alanlarının kaldırılması dahildir. Arayanlar bunun yerine her türde Bundle toBundle() ve static Foo fromBundle(Bundle) yöntemlerini kullanmalıdır.

Sürüm 1.4.0-rc01

10 Temmuz 2024

1.4.0 kararlı sürümünü kullanın.

Sürüm 1.4.0-beta01

26 Haziran 2024

1.4.0 kararlı sürümünü kullanın.

Sürüm 1.4.0-alpha02

7 Haziran 2024

1.4.0 kararlı sürümünü kullanın.

Sürüm 1.4.0-alpha01

17 Nisan 2024

1.4.0 kararlı sürümünü kullanın.

Sürüm 1.3.0

Sürüm 1.3.1

11 Nisan 2024

androidx.media3:media3-*:1.3.1 iptal edilir. 1.3.1 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • Yerelleştirilmiş veya diğer alternatif etiketlere izin vermek için Format.labels ekleyin.
  • ExoPlayer:
    • PreloadMediaPeriod'nın önceden yüklenmesi durumunda akışları koruyamaması sorunu düzeltildi.
    • Parça yeniden seçilirken doğru TrackSelectionResult değerini oynatma süresine uygulayın.
    • Medya öğeleri arasında geçiş yaparken oynatma süresini ilerlettikten sonra erken etkinleştirilmiş oluşturucuları başlatın (#1017).
    • Proguard -keepclasseswithmembers kuralına eksik dönüş türü eklendi DefaultVideoFrameProcessor.Factory.Builder.build() (#1187).
  • Dönüştürücü:
    • API 30'dan önce MediaMuxer negatif sunum zaman damgalarını desteklemediği için oluşturulan istisna için geçici çözüm eklendi.
  • Parça Seçimi:
    • DefaultTrackSelector: Daha düşük veya ayarlanmamış kare hızına sahip video parçaları yerine "makul" bir kare hızına (>=10 fps) sahip video parçalarını tercih edin. Bu sayede oynatıcı, hareketli fotoğraflardan çıkarılan MP4'lerdeki "gerçek" video parçasını seçer. Bu MP4'lerde, biri daha yüksek çözünürlüklü ancak çok az sayıda kareye sahip iki HEVC parçası bulunabilir (#1051).
  • Ayıklayıcılar:
    • WAV dosyalarından tek boyutlu parçalar okunurken dolgunun atlanmamasına neden olan sorun düzeltildi (#1117).
    • MP3: Format.averageBitrate ve VBRI gibi meta veri çerçevelerinden XING alanını doldurun.
    • MPEG-TS: Bir akışın son erişim birimini örnek sırasına ileterek son karenin oluşturulmasını sağlamayı amaçlayan bir değişikliği geri alın (#7909). Bunun nedeni, yalnızca I-frame HLS yayınlarında (#1150) ve H.262 HLS yayınlarında (#1126) yeni sorunlara yol açan değişikliktir.
  • Ses:
    • Ses parçası, yükü boşaltma modunda başlatılamazsa yükü boşaltmayı devre dışı bırakarak oluşturucu kurtarmaya izin verin.
  • Video:
    • Galaxy Tab S7 FE, Google TV'li Chromecast ve Lenovo M10 FHD Plus'ta 60 FPS H265 yayınlarının desteklenmiyor olarak işaretlenmesine neden olan cihaz sorununa geçici çözüm eklendi.
    • Cihaz, API'nin gerektirdiği şekilde bunu otomatik olarak yapmasa bile tünel oluşturma sırasında ilk karenin her zaman oluşturulmasını sağlayan geçici çözüm eklendi (#1169). (#966).
    • HDR renk bilgisi işleme nedeniyle codec'in hatalı davranışına yol açan ve SDR video parçaları için uyarlanabilir biçim geçişlerini engelleyen sorun düzeltildi (#1158).
  • Metin:
    • WebVTT: Doğrudan ardışık ipuçlarının CuesWithTiming öğesinden sahte ek WebvttParser.parse örnekleri oluşturmasını önleme (#1177).
  • DRM:
    • Bazı Android 14 cihazlarda ResourceBusyException veya NotProvisionedException yerine MediaDrm çerçevesi tarafından oluşturulabilen NoSuchMethodError sorununu çözün (#1145).
  • Etki:
    • Renk alanları dönüştürülerek PQ'dan SDR'ye ton eşleme iyileştirildi.
  • Oturum:
    • Denetleyici, mevcut öğenin yerini aldığında mevcut konumun geri atlaması sorunu düzeltildi (#951).
    • Yalnızca boş olmayan extras içeren MediaMetadata öğesinin medya denetleyicileri ve oturumları arasında iletilmemesine neden olan sorun düzeltildi (#1176).
  • UI:
    • Locale, görünen adı tanımlayamıyorsa ses parçası dilinin adını ekleyin (#988).
  • DASH uzantısı:
    • Manifest dosyasındaki tüm Label öğelerini Format.labels ile doldurun (#1054).
  • RTSP Uzantısı:
    • SDP ayrıştırmasında boş oturum bilgisi değerlerini (i-etiketleri) atlayın (#1087).
  • Kod Çözücü Uzantıları (FFmpeg, VP9, AV1, MIDI vb.):
    • MIDI uzantısı, ek bir Maven deposunun yapılandırılmasını gerektirdiğinden varsayılan olarak yerel bağımlılık şeklinde devre dışı bırakılır. Yerel bağımlılıktan bu modüle ihtiyacı olan kullanıcılar modülü yeniden etkinleştirebilir.

Sürüm 1.3.0

6 Mart 2024

androidx.media3:media3-*:1.3.0 iptal edilir. 1.3.0 sürümü bu commit'leri içerir.

  • Ortak kitaplık:
    • android.resource://package/[type/]name ham kaynak URI'leri için destek uygulayın. Burada package, mevcut uygulamanın paketinden farklıdır. Bu özellik her zaman çalışacak şekilde belgelenmiş olsa da şimdiye kadar doğru şekilde uygulanmamıştı.
    • Uygulama kodu tarafından ayarlanan veya medyadan okunan MIME türlerini tamamen küçük harf olacak şekilde normalleştirin.
    • AdPlaybackState içinde tek bir Uri yerine tam bir MediaItem ile reklam tanımlayın.
    • minSdk değerini 19'a (Android KitKat) yükseltin. Bu değişiklik, diğer tüm AndroidX kitaplıklarıyla uyumludur ve AndroidX bağımlılıklarımızın en son sürümlerine yükseltmemiz için gereklidir.
    • artworkUri ve artworkData özelliklerinden en az biri boş değilse (null değilse) MediaMetadata.Builder.populate(MediaMetadata) içinde her ikisini de doldurun (#964).
  • ExoPlayer:
    • Uygulamaların, oynatmadan önce belirli bir başlangıç konumunda içerik medya kaynağını önceden yüklemesine olanak tanıyan PreloadMediaSource ve PreloadMediaPeriod öğelerini ekleyin. PreloadMediaSource, Timeline almak için içerik medya kaynağını hazırlama, dönemi verilen başlangıç konumunda hazırlayıp önbelleğe alma, parçaları seçme ve döneme ait medya verilerini yükleme işlemlerini yapar. Uygulamalar, PreloadMediaSource.PreloadControl uygulayarak önceden yükleme ilerleme durumunu kontrol eder ve önceden yüklenen kaynağı oynatma için oynatıcıya ayarlar.
    • Uygulamaların ExoPlayer.setImageOutput ayarlamasına izin veren ImageRenderer.ImageOutput ekleyin.
    • DefaultRenderersFactory artık varsayılan olarak oyuncuya boş ImageOutput ve ImageDecoder.Factory.DEFAULT ile ImageRenderer sağlıyor.
    • Sessizlik atlandığında Player.Listener.onPositionDiscontinuity etkinliğini yayınlayın (#765).
    • Ayıklama sırasında altyazı ayrıştırma için deneysel destek eklendi. Bu özelliği MediaSource.Factory.experimentalParseSubtitlesDuringExtraction() kullanarak etkinleştirebilirsiniz.
    • PreloadMediaSource ile uyarlanabilir medya kaynaklarını destekleyin.
    • HttpEngine API'sini kullanarak HttpEngineDataSource HttpDataSource uygulayın.
    • Alt sınıfları önleme CompositeSequenceableLoader. Bu bileşen daha önce genişletilebilir hale getirilmiş ancak kitaplıkta hiçbir zaman alt sınıfa ayrılmamıştır. Özelleştirmeler, decorator pattern kullanılarak bir örneği sarmalayarak ve özel bir CompositeSequenceableLoaderFactory uygulayarak yapılabilir.
    • Aynı saatin tekrar edilmesi durumunda bu öğenin meta verilerinin temizlenmesine neden olan sorun düzeltildi (#1007).
    • experimentalSetSubtitleParserFactory yöntemlerini BundledChunkExtractor.Factory ve DefaultHlsExtractorFactory üzerinde setSubtitleParserFactory olarak yeniden adlandırın ve null iletilmesine izin vermeyin. Ayrıştırma davranışını kontrol etmek için yeni experimentalParseSubtitlesDuringExtraction(boolean) yöntemlerini kullanın.
    • Ayıklama sırasında kullanılan SubtitleParser.Factory karakterini özelleştirme desteği eklendi. Bu, MediaSource.Factory.setSubtitleParserFactory() ile yapılabilir.
    • MergingMediaSource kaynağından oluşturulan tüm Format.id alanlarına kaynak öneki ekleyin. Bu, hangi kaynağın Format oluşturduğunu belirlemeye yardımcı olur (#883).
    • Özel Common Media Client Data (CMCD) anahtar adlarını doğrulamak için kullanılan normal ifadeyi yalnızca kısa çizgi kontrolü yapacak şekilde değiştirerek düzeltin (#1028).
    • CMCD sorgu parametrelerinin çift kodlanmasını durdurma (#1075).
  • Dönüştürücü:
    • H.265/HEVC SEF yavaş çekim videolarının düzleştirilmesi için destek eklendi.
    • Özellikle "videoyu kaldırma" düzenlemelerinde transmuks hızını artırır.
    • Çıkış dosyasının bir video karesinde başlamasını sağlamak için API ekleyin. Bu, kırpma işlemlerinin çıkışını, ilk video karesini sunum zaman damgasına (#829) kadar göstermeyen oynatıcı uygulamalarıyla daha uyumlu hale getirebilir.
    • Tek öğeli MP4 kırpma işlemlerini optimize etme desteği eklendi.
    • Bir video karesinin çıkış dosyasında ilk zaman damgasına sahip olmasını sağlamak için destek ekleyin. iOS tabanlı oynatıcılarda siyah kareyle başlayan çıkış dosyaları düzeltildi (#829).
  • Parça Seçimi:
    • Resim parçası seçimini etkinleştirmek için DefaultTrackSelector.selectImageTrack ekleyin.
    • Hem resim parçası hem de video parçası varsa resim parçasının seçilip seçilmeyeceğini belirlemek için TrackSelectionParameters.isPrioritizeImageOverVideoEnabled ekleyin. Varsayılan değer false'dır. Bu değer, video parçasının seçilmesine öncelik verildiği anlamına gelir.
  • Ayıklayıcılar:
    • ColorInfo.colorSpace, ColorInfo.colorTransfer ve ColorInfo.colorRange değerlerini almak için MP4 çıkarıcıya ek AV1C ayrıştırma işlemi eklendi (#692).
    • MP3: Info üstbilgisine sahip dosyalar için sabit bit hızı (CBR) arama kullanın (Xing üstbilgisinin CBR eşdeğeri). Daha önce Info üstbilgisindeki seek table'ı kullanıyorduk ancak bu, seek table'ı yok sayıp dosyanın CBR olduğunu varsaydığımızda elde ettiğimizden daha az hassas bir arama sağlıyordu.
    • MPEG2-TS: DTS, DTS-LBR ve DTS:X Profile2 desteği eklendi (#275).
    • TS tanımlayıcılarından ses türlerini ayıklayıp rol işaretleriyle eşleyerek kullanıcıların daha bilinçli ses parçası seçimleri yapmasına olanak tanır (#973).
  • Ses:
    • Sessizliği atlama algoritması, ses düzeyinde yumuşak geçişle iyileştirildi. Minimum sessizlik korundu ve daha doğal sessizlik süreleri sağlandı (#7423).
    • Atlanan sessizliği daha kesin bir şekilde bildirme (#1035).
  • Video:
    • VideoFrameProcessor.Factory bağımsız değişkenini alan MediaCodecVideoRenderer oluşturucuyu değiştirin ve VideoSinkProvider bağımsız değişkenini alan bir oluşturucuyla değiştirin. Özel VideoFrameProcessor.Factory eklemek isteyen uygulamalar, özel CompositingVideoSinkProvider kullanan bir VideoFrameProcessor.Factory oluşturabilir ve video sink sağlayıcıyı MediaCodecVideoRenderer öğesine iletebilir.
  • Metin:
    • DefaultExtractorsFactory.setTextTrackTranscodingEnabled kullanırken Tried to marshall a Parcel that contained Binder objects hatasını düzeltmek için bit eşlem ipuçlarının serileştirilmesini düzeltin DefaultExtractorsFactory.setTextTrackTranscodingEnabled (#836).
    • CEA-708: rowLock değerini yoksayın. CEA-708-E S-2023 spesifikasyonu, akışta bulunan değerlerden bağımsız olarak hem rowLock hem de columnLock değerlerinin doğru kabul edilmesi gerektiğini belirtir (columnLock desteği uygulanmadığından her zaman yanlış olduğu varsayılır).
  • Resim:
    • DASH küçük resimleri için destek eklendi. Izgara resimleri kırpılır ve sunum zamanlarına yakın ImageOutput için ayrı küçük resimler sağlanır.
  • DRM:
    • DRM içeriğindeki "net lider" şifrelenmemiş örnekleri, sonraki şifrelenmiş örneklerin anahtarları henüz hazır olmasa bile varsayılan olarak hemen oynatın. Oynatma konumu şifrelenmiş örneklere ulaştığında anahtarlar hâlâ hazır değilse bu durum, oynatma sırasında duraklamalara neden olabilir (ancak daha önce oynatma bu noktada hiç başlamazdı). Bu davranış, MediaItem.DrmConfiguration.Builder.setPlayClearContentWithoutKey veya DefaultDrmSessionManager.Builder.setPlayClearSamplesWithoutKeys ile devre dışı bırakılabilir.
      • IMA uzantısı:
    • Uygun dosya uzantısına sahip olmayan DASH ve HLS reklamlarının oynatılamaması sorunu düzeltildi.
  • Oturum:
    • TV uygulamalarında çift tıklama algılamayı devre dışı bırakma (#962).
    • Yalnızca boş olmayan ekstralar içeren MediaItem.RequestMetadata öğesinin medya denetleyicileri ve oturumlar arasında iletilmemesi sorunu düzeltildi.
    • MediaLibrarySession.Builder öğesine MediaLibraryService yerine yalnızca Context alan bir oluşturucu ekleyin.
  • HLS Uzantısı:
    • HlsMediaPeriod öğesini paket içi görünürlük olarak ayarlayın. Bu tür, HLS paketi dışından doğrudan kullanılmamalıdır.
    • Çözüm, bir segmentin başlangıcına daha verimli bir şekilde ulaşmayı amaçlar (#1031).
  • Kod Çözücü Uzantıları (FFmpeg, VP9, AV1, MIDI vb.):
    • MIDI kod çözücü: SysEx etkinlik mesajlarını yoksayma (#710).
  • Test yardımcı programları:
    • TestPlayerRunHelper.playUntilPosition uygulamasında oynatmayı duraklatmayın. Test, oynatmayı oynatma durumunda tutar ancak test, onaylamalar ve başka işlemler ekleyene kadar ilerlemeyi askıya alır.
  • Demo uygulaması:
    • PreloadMediaSource kullanımını kısa formatlı içerik kullanım alanıyla birlikte tanıtmak için kısa formatlı bir demo modülü ekleyin.

Sürüm 1.3.0-rc01

22 Şubat 2024

1.3.0 kararlı sürümünü kullanın.

Sürüm 1.3.0-beta01

7 Şubat 2024

1.3.0 kararlı sürümünü kullanın.

Sürüm 1.3.0-alpha01

15 Ocak 2024

1.3.0 kararlı sürümünü kullanın.

Sürüm 1.2.0

Sürüm 1.2.1

9 Ocak 2024

  • ExoPlayer:
    • LiveConfiguration.min/maxOffset aralığı dışındaki manuel aramalarda, ofsetin tekrar min/maxOffset olarak ayarlanmaya devam etmesi sorunu düzeltildi.
    • OPUS ve VORBIS kanal düzenlerinin 3, 5, 6, 7 ve 8 kanallar için yanlış olmasına neden olan sorun düzeltildi (#8396).
    • Canlı yayında sıfıra gitme işleminden sonra parça seçimlerinin, yayının varsayılan konumdan başlamasına yanlışlıkla izin vermesi sorunu düzeltildi (#9347).
    • CmcdData.Factory öğesinin yeni örneklerinin, parça kaynaklarından bufferedDurationUs için negatif değerler alarak IllegalArgumentException (#888) ile sonuçlanmasına neden olan sorun düzeltildi.
  • Dönüştürücü:
    • Yüksek çalışma hızı ayarlandığı için kodlayıcının yapılandırma sırasında hata vermesine neden olan sorun giderildi.
  • Ayıklayıcılar:
    • Daha yüksek çözünürlüklü oldukları için oynatma amacıyla otomatik olarak seçilmelerini önlemek için JPEG hareketli fotoğraflardaki ikincil (oynatılamayan) HEVC parçalarını ROLE_FLAG_ALTERNATE olarak işaretleyin.
    • TS H264 akışlarında yanlış animasyon karesi algılamayı düzeltme (#864).
    • 47.721 saniyeden uzun TS akışlarının süre tahminini düzeltme (#855).
  • Ses:
    • SilenceSkippingAudioProcessor için EOS'un birden çok kez çağrıldığında işlenmesiyle ilgili sorun düzeltildi (#712).
  • Video:
    • Galaxy Tab S7 FE, Google TV'li Chromecast ve Lenovo M10 FHD Plus'ta 60 fps AVC akışlarının desteklenmiyor olarak işaretlenmesine neden olan cihaz sorununa yönelik geçici çözüm eklendi (#693).
  • Meta veri:
    • MediaMetadata öğesinin yalnızca büyük harfli anahtarlara sahip Vorbis yorumlarından doldurulduğu hata düzeltildi (#876).
    • Çok büyük ID3 çerçeveleri ayrıştırılırken OutOfMemoryError hatası oluştuğunda oynatma tamamen başarısız olmak yerine etiket bilgisi olmadan devam edebilir.
  • DRM:
    • Sahte ClearKey https://default.url lisans URL'si için geçici çözümü API 33 ve sonraki sürümlere genişletme (geçici çözüm daha önce yalnızca API 33'te geçerliydi) (#837).
    • Oynatıcıya bağlı yüzey olmadan şifrelenmiş içerikten şifrelenmemiş içeriğe geçiş yaparken ERROR_DRM_SESSION_NOT_OPENED düzeltildi. Hata, şifrelenmemiş içeriği oynatmak için güvenli kod çözücünün yanlış kullanılmasından kaynaklanıyordu.
  • Oturum:
    • Özel anahtarları ve değerleri MediaMetadataCompat ile MediaMetadata.extras ve MediaMetadata.extras ile MediaMetadataCompat arasına yerleştirin (#756, #802).
    • Eski kontrol cihazları için yayın sorunları notifyChildrenChanged düzeltildi (#644).
    • Bildirimin devre dışı bırakılmış setWhen zamanlayıcısı için negatif bir süre ayarlandığında bazı cihazlarda kilitlenmeye neden olan hata düzeltildi (#903).
    • İlk bildirim güncellemesi istendiğinde medya bildirimi denetleyicisi bağlantı oluşturmayı tamamlamadığında IllegalStateException sorunu düzeltildi (#917).
  • UI:
    • BottomSheetDialogFragment'te Material Design ile kullanıldığında ileri ve geri sarma düğmelerinin görünmemesi sorunu düzeltildi (#511).
    • PlayerControlView hızlı ileri sarma düğmesindeki sayıların yanlış hizalanmasıyla ilgili sorun düzeltildi (#547).
  • DASH uzantısı:
    • DASH manifestinde Dolby için "f800"ü 5 kanal sayısı olarak ayrıştırın (#688).
  • Kod Çözücü Uzantıları (FFmpeg, VP9, AV1, MIDI vb.):
    • MIDI: İleri sarma sırasında Program Değiştirme etkinliklerinin atlandığı sorun düzeltildi (#704).
    • FFmpeg 6.0'a geçiş yapıldı ve desteklenen NDK, r26b olarak güncellendi (#707, #867).
  • Cast Uzantısı:
    • Yayın cihazında medya yükleme işlemi başarısız olduğunda uygulamanın kilitlenmemesi için Timeline oluşturma işlemi temizlendi (#708).

Sürüm 1.2.0

15 Kasım 2023

  • Ortak kitaplık:
    • Log.Logger arayüzündeki yöntemlere @Nullable Throwable parametresi ekleyin. Bu yöntemlerdeki message parametresi artık Log.{d,i,w,e}() yöntemlerine iletilen Throwable hakkında herhangi bir bilgi içermiyor. Bu nedenle, istenirse uygulamaların bu bilgiyi manuel olarak eklemesi gerekir (muhtemelen Logger.appendThrowableString(String, Throwable) kullanılarak).
    • Boş değer atanabilir genel tür parametrelerinin ve boş değer atanabilir dizi öğesi türlerinin boş değer atanabilir olarak algılanmadığı Kotlin uyumluluğu sorunu düzeltildi. Örnekler arasında TrackSelectorResult ve SimpleDecoder yöntemi parametreleri yer alır (#6792).
    • Oynatma geçici olarak bastırılırken (ör. geçici ses odağı kaybı nedeniyle) "oynat" düğmesini göstermek için Util.shouldShowPlayButton bölümünde varsayılan kullanıcı arayüzü ve bildirim davranışını değiştirin. Eski davranış, PlayerView.setShowPlayButtonIfPlaybackIsSuppressed(false) veya MediaSession.Builder.setShowPlayButtonIfPlaybackIsSuppressed(false) kullanılarak korunabilir (#11213).
    • https://issuetracker.google.com/251172715 adresindeki sorunu düzeltmek için androidx.annotation:annotation-experimental sürümünü 1.3.1 sürümüne yükseltin.
    • ExoPlayer.setAudioAttributes öğesini Player arayüzüne taşıyın.
  • ExoPlayer:
    • Yalnızca kod çözme örneklerinin doğru şekilde tanımlanmamasından kaynaklanan AC4 akışlarındaki arama sorunları düzeltildi (#11000).
    • Bu özellik ExoPlayer.Builder.setSuppressPlaybackOnUnsuitableOutput üzerinden etkinleştirildiğinde uygun olmayan ses çıkışı cihazlarında (ör. Wear OS cihazlardaki yerleşik hoparlör) oynatmanın engellenmesi eklendi. Oynatma sırasında uygun ses çıkışı yoksa veya tüm uygun çıkışlar bağlantısı kesilmişse oynatma engelleme nedeni Player.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT olarak güncellenir. Uygun bir çıkış bağlandığında bastırma nedeni kaldırılır.
    • MediaSource.canUpdateMediaItem ve MediaSource.updateMediaItem öğelerini ekleyerek MediaItem güncellemelerini oluşturulduktan sonra Player.replaceMediaItem(s) üzerinden kabul edin.
    • Player.replaceMediaItem(s) üzerinden kitaplık tarafından sağlanan tüm MediaSource sınıfları için MediaItem güncellemelerine izin verin (#33, #9978).
    • MimeTypes.TEXT_EXOPLAYER_CUES öğesini MimeTypes.APPLICATION_MEDIA3_CUES olarak yeniden adlandırın.
    • PngExtractor öğesini ekleyin. Bu öğe, örnek olarak TrackOutput içine tam bir PNG dosyası gönderir ve okur.
    • SequenceableLoader arayüzündeki SequenceableLoader.continueLoading(long) yöntemi SequenceableLoader.continueLoading(LoadingInfo loadingInfo) olarak geliştirildi. LoadingInfo, mevcut playbackPositionUs'e ek olarak playbackSpeed ve lastRebufferRealtimeMs dahil olmak üzere ek parametreler içeriyor.
    • ChunkSource arayüzündeki ChunkSource.getNextChunk(long, long, List, ChunkHolder) yöntemi ChunkSource.getNextChunk(LoadingInfo, long, List, ChunkHolder) olarak geliştirildi.
    • Ortak Medya İstemcisi Verileri (CMCD) günlüğüne ek alanlar ekleyin: arabellek yetersizliği (bs), son tarih (dl), oynatma hızı (pr) ve başlatma (su) (#8699).
    • ColorInfo öğesine parlaklık ve renk bit derinliği eklendi (#491).
    • Ortak Medya İstemcisi Verileri (CMCD) günlüğüne ek alanlar ekleyin: sonraki nesne isteği (nor) ve sonraki aralık isteği (nrr) (#8699).
    • Sorgu parametrelerini (#553) kullanarak Common Media Client Data (CMCD) verilerini iletme işlevi ekleyin.
    • ConcurrentModificationException ile ilgili sorunu ExperimentalBandwidthMeter içinde düzeltin (#612).
    • MediaPeriodId parametresini CompositeMediaSource.getMediaTimeForChildMediaTime öğesine ekleyin.
    • ClippingMediaSource (ve dönem/pencere zamanı kaymaları olan diğer kaynaklar) ConcatenatingMediaSource2'da desteklenir (#11226).
    • BaseRenderer.onStreamChanged() değerini, MediaPeriodId bağımsız değişkenini de alacak şekilde değiştirin.
  • Dönüştürücü:
    • Görüntü girişleri için EXIF döndürme verilerini ayrıştırın.
    • TransformationRequest.HdrMode açıklama türünü ve ilişkili sabitlerini kaldırın. Bunun yerine Composition.HdrMode ve ilişkili sabitlerini kullanın.
    • Döndürme sorunlarını düzeltmek için OverlaySettings öğesini basitleştirin.
    • SampleConsumer.queueInputBitmap öğesinin frameRate ve durationUs parametreleri TimestampIterator olarak değiştirildi.
  • Parça Seçimi:
    • Kesintisiz olmayan uyarlamaya açıkça izin vermek veya izin vermemek için DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness ekleyin. Varsayılan değer, mevcut true davranışında kalır.
  • Ayıklayıcılar:
    • MPEG-TS: Bir akışın son erişim birimini örnek kuyruğuna ileterek son karenin oluşturulduğundan emin olun (#7909).
    • rotationDegrees belirlenirken yazım hatasını düzeltin. projectionPosePitch, projectionPoseRoll olarak değiştirildi (#461).
    • Extractor örneklerinin doğrudan instanceof ile incelenebileceği varsayımını kaldırın. Bir Extractor uygulamasının uygulama ayrıntılarına çalışma zamanı erişimi istiyorsanız önce Extractor.getUnderlyingInstance uygulamasını çağırmanız gerekir.
    • BmpExtractor ekleyin.
    • WebpExtractor ekleyin.
    • HeifExtractor ekleyin.
    • Mp4Extractor'ye QuickTime classic desteği ekleyin.
  • Ses:
    • MP4 ve Matroska'da 24/32 bit büyük endian PCM desteği ekleyin ve MP4'te lpcm için PCM kodlamasını ayrıştırın.
    • MP4'te Vorbis sesinin çıkarılması için destek eklendi.
    • AudioSink.getFormatOffloadSupport(Format) ekleyin. Bu işlev, DefaultAudioOffloadSupportProvider aracılığıyla biçim için alıcının sağlayabileceği boşaltma desteği düzeyini alır. isFormatSupported, isGaplessSupported ve isSpeedChangeSupported içeren yeni AudioOffloadSupport değerini döndürür.
    • Ses alıcısındaki boşaltma yapılandırmasının yapılandırıldığı AudioSink.setOffloadMode() öğesini ekleyin. Varsayılan değer: AudioSink.OFFLOAD_MODE_DISABLED.
    • Uygulama kaldırma, TrackSelectionParameters içindeki setAudioOffloadPreference üzerinden etkinleştirilebilir. Tercih etkinleştirme yönündeyse, cihaz biçim için boşaltmayı destekliyorsa ve parça seçimi tek bir ses parçasıysa ses boşaltma etkinleştirilir.
    • audioOffloadModePreference, AUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED olarak ayarlanırsa DefaultTrackSelector yalnızca bir ses parçası seçer ve yalnızca bu parçanın biçimi boşaltma işleminde destekleniyorsa seçer. Boşaltma işleminde ses parçası desteklenmiyorsa parça seçilmez.
    • Parça geçişinden sonra oynatma konumu sorunu nedeniyle API düzeyi 33'ten önceki sürümlerde boşluksuz oynatma desteği devre dışı bırakıldı.
    • enableOffload parametresini DefaultRenderersFactory.buildAudioSink yöntem imzasından kaldırın.
    • DefaultAudioSink.Builder.setOffloadMode yöntemini kaldırın.
    • Intdef değerini kaldırın DefaultAudioSink.OffloadMode.OFFLOAD_MODE_ENABLED_GAPLESS_DISABLED.
    • Boşluksuz Opus meta verileri için boşaltma oynatma sırasında destek ekleyin.
    • İlk yazma işleminde başarısız olunursa boşaltma devre dışı bırakılarak oluşturucu kurtarmaya izin verilir (#627).
    • Yalnızca sesli indirilen içeriklerin oynatılması için varsayılan olarak indirme planlamayı etkinleştirin.
    • ExoPlayer.experimentalSetOffloadSchedulingEnabled ve AudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged öğelerini silin.
    • onExperimentalSleepingForOffloadChanged, onSleepingForOffloadChanged olarak, onExperimentalOffloadedPlayback ise onOffloadedPlayback olarak yeniden adlandırıldı.
    • Ses boşaltma moduyla ilgili TrackSelectionParameters arayüzlerini ve tanımlarını AudioOffloadPreferences sınıfına taşıyın.
    • AnalyticsListener, AudioRendererEventListener ve AudioSink.Listener öğelerine onAudioTrackInitialized ve onAudioTrackReleased geri çağırmalarını ekleyin.
    • DTS Express'teki ses arabelleği taşması sorununu düzeltme (#650).
    • E-AC3-JOC için özellik kontrolünün IllegalArgumentException (#677) hatası vermesine neden olan hata düzeltildi.
  • Video:
    • MediaCodecVideoRenderer uygulamasının özel VideoFrameProcessor.Factory kullanmasına izin verin.
    • Ses akışı negatif zaman damgalarıyla başladığında ilk karenin oluşturulamaması hatası düzeltildi (#291).
  • Metin:
    • ExoplayerCuesDecoder öğesini kaldırın. sampleMimeType = application/x-media3-cues simgesiyle gösterilen metin parçaları artık SubtitleDecoder örneğine gerek kalmadan doğrudan TextRenderer tarafından işleniyor.
  • Meta veri:
    • Uygulama yine de null döndürmesi gerektiğinden, "yalnızca kod çözme" örnekleri için MetadataDecoder.decode artık çağrılmayacak.
  • Etki:
    • VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>) Zaman damgasına göre bitmap girişini sıraya ekleyin.
    • VideoFrameProcessor.registerInputStream() değerini engellemeyen olarak değiştirin. Uygulamalar, VideoFrameProcessor.Listener#onInputStreamRegistered() özelliğini uygulamalıdır.
    • VideoFrameProcessor.queueInputBitmap öğesinin frameRate ve durationUs parametreleri TimestampIterator olarak değiştirildi.
  • IMA uzantısı:
    • Oynatma listesindeki ilk öğe olmayan çok dönemli bir DASH canlı yayınının istisna oluşturmasına neden olan hata düzeltildi (#571).
    • AdsLoader.destroy() numarası aranmadan önce StreamManager'ı serbest bırakın.
    • IMA SDK sürümünü 3.31.0'a yükseltin.
  • Oturum:
    • DefaultMediaNotificationProvider bölümünde bildirimlerin ön plan hizmeti davranışını FOREGROUND_SERVICE_IMMEDIATE olarak ayarlayın (#167).
    • Samsung cihazlarda kullanımdan kaldırılan API ile ilgili sorunları önlemek için yalnızca android.media.session.MediaSession.setMediaButtonBroadcastReceiver() API 31 ve üzeri sürümleri kullanın (#167).
    • Kullanılabilir komutları ve bildirimi ve platform oturumunu doldurmak için kullanılan özel düzeni ayarlamak üzere medya bildirimi denetleyicisini proxy olarak kullanın.
    • Medya düğmesi etkinliklerini, platform oturumuna yönlendirmek ve tekrar Media3'e yönlendirmek yerine MediaSessionService.onStartCommand() içinde Media3 tarafından alınan etkinliklere dönüştürün. Bu sayede, arayan denetleyici her zaman medya bildirimi denetleyicisi olur ve uygulamalar, desteklenen tüm API düzeylerinde bildirimden gelen aramaları aynı şekilde kolayca tanıyabilir.
    • Eski bir MediaSessionCompat cihazına bağlandığında MediaController.getCurrentPosition() öğesinin ilerlememesine neden olan hata düzeltildi.
    • Kolaylık için MediaLibrarySession.getSubscribedControllers(mediaId) ekleyin.
    • Denetleyicinin abone olduğu üst kimliğin kullanılabilirliğini onaylamak için MediaLibrarySession.Callback.onSubscribe() değerini geçersiz kılın. Başarılı olursa abonelik kabul edilir ve tarayıcıyı bilgilendirmek için hemen notifyChildrenChanged() çağrılır (#561).
    • Otomotiv OS için oturum tanıtım modülü ekleyin ve Android Auto için oturum tanıtımını etkinleştirin.
    • Medya bildirimi denetleyicisi için COMMAND_GET_TIMELINE kullanılamadığında çerçeve oturumunun sırasını ayarlamayın. Android Auto, çerçeve oturumundan okuma yapan istemci denetleyicisi olduğunda Android Auto'nun kullanıcı arayüzündeki queue düğmesi gösterilmez (#339).
    • Varsayılan olarak SimpleBitmapLoader yerine DataSourceBitmapLoader kullanın (#271, #327).
    • Uygulamaların varsayılan medya düğmesi etkinlik işleme özelliğini geçersiz kılmasına olanak tanıyan MediaSession.Callback.onMediaButtonEvent(Intent) eklendi.
  • UI:
    • Kullanıcının uygun bir ses çıkışı (ör. Bluetooth kulaklık) bağlamasına izin vermek için bir sistem iletişim kutusu başlatarak Player.Listener nedeniyle Player.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT kaynaklı oynatma bastırmayı işleyen Wear OS cihazları için bir Player.Listener uygulaması ekleyin. Dinleyici, yapılandırılabilir bir zaman aşımı içinde (varsayılan olarak 5 dakika) uygun bir cihaz bağlanırsa oynatmayı otomatik olarak devam ettirir.
  • İndirilenler:
    • Android 14 ile uyumluluk için DownloadService için "veri senkronizasyonu" ön plan hizmeti türünü bildirin. Bu hizmeti kullanırken uygulamanın manifest dosyasına dataSync öğesini foregroundServiceType olarak eklemesi ve FOREGROUND_SERVICE_DATA_SYNC iznini (#11239) eklemesi de gerekir.
  • HLS Uzantısı:
    • HLS canlı oynatma listesini, son yükleme tamamlanma zamanı yerine son yükleme başlangıç zamanından hesaplanan bir aralıkla yenileyin (#663).
  • DASH uzantısı:
    • Segment şablonu URL'sinde aynı DASH tanımlayıcının birden fazla kez kullanılmasına izin verilir.
    • Ayıklama sırasında altyazı ayrıştırma için deneysel destek eklendi. Bu sürüm, altyazı segmentleri arasında geçiş yaparken titremeyi giderme de dahil olmak üzere, çakışan altyazıları birleştirme konusunda daha iyi destek sunar. Bu özelliği DashMediaSource.Factory.experimentalParseSubtitlesDuringExtraction() (#288) kullanarak etkinleştirebilirsiniz.
  • RTSP Uzantısı:
    • TCP'ye geri dönüldüğünde IndexOutOfBoundsException hatasına veya bazı durumlarda oynatmanın askıya alınmasına neden olabilecek yarışma durumu düzeltildi.
    • RtspMediaPeriod (#577) yükleme durumunu döndürürken RTSP kurulumundaki durumu kontrol edin.
    • Seçenekler yanıtı genel üst bilgisinde özel Rtsp istek yöntemlerini yoksayma (#613).
    • RTSP Setup Response zaman aşımı değerini, etkin tutma RTSP Options isteklerinin gönderilme zaman aralığında kullanın (#662).
  • Kod Çözücü Uzantıları (FFmpeg, VP9, AV1, MIDI vb.):
    • Ses sentezlemek için Jsyn kitaplığını kullanarak standart MIDI dosyalarının oynatılmasını destekleyen MIDI kod çözücü modülünü yayınlayın.
    • Gösterilmesi gerekmeyen çıkış arabelleklerini doğrudan işaretlemek için DecoderOutputBuffer.shouldBeSkipped ekleyin. Bu yöntem, desteği sonlandırılacak olan C.BUFFER_FLAG_DECODE_ONLY yöntemine göre tercih edilir.
    • Kod çözücülerin, başlangıç zamanından önce yalnızca kod çözme örneklerini bırakmasına izin vermek için Decoder.setOutputStartTimeUs ve SimpleDecoder.isAtLeastOutputStartTimeUs ekleyin. Bu, desteği sonlandırılacak olan Buffer.isDecodeOnly yerine tercih edilmelidir.
    • MIDI kod çözücü yapıtının Maven deposunda yayınlanmasıyla ilgili hata düzeltildi. Yapılandırma media3-exoplayer-midi olarak yeniden adlandırıldı (#734).
  • Leanback uzantısı:
    • Bir yüzeyin devre dışı bırakılmasının Leanback kodunda ArithmeticException'ya neden olabildiği hata düzeltildi (#617).
  • Test yardımcı programları:
    • TestExoPlayerBuilder ve FakeClock'ı Espresso kullanıcı arayüzü testleri ve Compose kullanıcı arayüzü testleriyle uyumlu hale getirin. Bu düzeltme, Espresso veya Compose görünümü etkileşimleri sırasında oynatmanın nondeterministik olarak ilerlemesine neden olan hatayı düzeltir.
  • Desteği sonlandırılan sembolleri kaldırın:
    • TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean) ve TransformationRequest.Builder.experimental_setEnableHdrEditing(boolean) öğelerini kaldırın. Composition.Builder.setHdrMode(int) özelliğini kullanın ve Composition değerini Transformer.start(Composition, String) öğesine iletin.
    • Desteği sonlandırılan DownloadNotificationHelper.buildProgressNotification yöntemini kaldırın. Bunun yerine notMetRequirements parametresini alan, desteği sonlandırılmamış bir yöntem kullanın.

Sürüm 1.2.0-rc01

1 Kasım 2023

1.2.0 kararlı sürümünü kullanın.

Sürüm 1.2.0-beta01

19 Ekim 2023

1.2.0 kararlı sürümünü kullanın.

Sürüm 1.2.0-alpha02

29 Eylül 2023

1.2.0 kararlı sürümünü kullanın.

Sürüm 1.2.0-alpha01

17 Ağustos 2023

1.2.0 kararlı sürümünü kullanın.

Sürüm 1.1.0

Sürüm 1.1.1

16 Ağustos 2023

  • Ortak kitaplık:
    • Yanlışlıkla eklenen multidex bağımlılığını tüm modüllerden kaldırın (#499).
  • ExoPlayer:
    • Oynatma listesi temizlendikten sonra PlaybackStatsListener bölümünde sahte PlaybackStats oluşturulması sorunu düzeltildi.
    • Ortak Medya İstemcisi Verileri (CMCD) günlüğüne ek alanlar ekleyin: akış biçimi (sf), akış türü (st), sürüm (v), en yüksek bit hızı (tb), nesne süresi (d), ölçülen işleme hızı (mtp) ve nesne türü (ot) (#8699).
  • Ses:
    • Çok kısa dosyalar oynatılırken Player.getState() simgesinin hiçbir zaman STATE_ENDED simgesine geçmemesine neden olan hata düzeltildi (#538).
  • Ses boşaltma:
    • RFC 7845 uyarınca, Ogg kimliği üstbilgisi ve yorum üstbilgisi sayfalarını, Opus'un yükü kaldırılmış oynatılması için bit akışına ekleyin.
  • Video:
    • H.265/HEVC: SPS kısa ve uzun vadeli referans resim bilgilerinin ayrıştırılmasıyla ilgili sorun düzeltildi.
  • Metin:
    • CEA-608: İpucu kesme mantığını yalnızca görünür metni dikkate alacak şekilde değiştirin. Daha önce, ipucu uzunluğu 32 karakterle sınırlandırılırken girinti ve sekme uzaklığı dahil ediliyordu (bu, teknik olarak spesifikasyona göre doğruydu) (#11019).
  • IMA uzantısı:
    • IMA SDK sürümünü 3.30.3'e yükseltin.
  • Oturum:
    • Denetleyicinin durumuna özel düzen ekleyin ve erişmek için bir alıcı sağlayın. Özel düzen değiştiğinde MediaController.Listener.onCustomLayoutChanged çağrılır. Farklı Media3 denetleyicilerine farklı özel düzenler göndermek isteyen uygulamalar, bağlantı tamamlandığında özel düzenin denetleyiciye sunulmasını sağlamak için MediaSession.Callback.onConnect içinde AcceptedResultBuilder kullanarak bunu yapabilir.
    • MediaLibraryServiceLegacyStub, bunu desteklemeyen bir Result öğesine hata gönderdiğinde UnsupportedOperationException (#78) oluşturulmasına neden olan durumlar düzeltildi.
    • PlayerWrapper'nın VolumeProviderCompat oluşturma şeklini, hem eski komutlar (COMMAND_ADJUST_DEVICE_VOLUME ve COMMAND_SET_DEVICE_VOLUME) hem de yeni komutlar (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS ve COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS) aracılığıyla volumeControlType'ı belirleyerek düzeltin (#554).

Sürüm 1.1.0

5 Temmuz 2023

  • Ortak kitaplık:
    • Uygun olmayan ses rotası için bastırma nedeni ekleyin ve hazır olduğunda oynatın. Çok uzun süre bastırılanlar için nedeni değiştirin. (#15).
    • Oynatıcı'ya komut ekleme:
      • COMMAND_GET_METADATA
      • COMMAND_SET_PLAYLIST_METADATA
      • COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS
      • COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
    • Kullanıcıların ses düzeyi işaretlerini belirtmesine olanak tanıyan, aşırı yüklenmiş yöntemleri Player'a ekleyin:
      • void setDeviceVolume(int, int)
      • void increaseDeviceVolume(int)
      • void decreaseDeviceVolume(int)
      • void setDeviceMuted(boolean, int)
    • DeviceInfo için Builder ekleyin ve mevcut oluşturucuyu kullanımdan kaldırın.
    • Uzak oynatmalar için yönlendirme denetleyicisi kimliğini belirtmek üzere DeviceInfo.routingControllerId ekleyin.
    • Aynı konumdaki öğeleri eklemek ve kaldırmak için Player.replaceMediaItem(s) kısayolunu ekleyin (#8046).
  • ExoPlayer:
    • Yalnızca açıkça etkinleştirilmişse ExoPlayer'ın cihaz ses yöntemlerini kontrol etmesine izin verilir. Aşağıdakilere erişmek için ExoPlayer.Builder.setDeviceVolumeControlEnabled kullanın:
      • getDeviceVolume()
      • isDeviceMuted()
      • setDeviceVolume(int) ve setDeviceVolume(int, int)
      • increaseDeviceVolume(int) ve increaseDeviceVolume(int, int)
      • decreaseDeviceVolume(int) ve decreaseDeviceVolume(int, int)
    • FilteringMediaSource öğesi ekleyin. Bu öğe, MediaSource içindeki mevcut parça türlerini filtrelemenizi sağlar.
    • Uyarlanabilir akış biçimleri DASH, HLS ve SmoothStreaming'in giden isteklerine Common Media Client Data (CMCD) ekleme desteği eklendi. br, bl, cid, rtp ve sid alanları dahil edildi (#8699). API yapısı ve API yöntemleri:
      • CMCD günlüğe kaydetme özelliği varsayılan olarak devre dışıdır. Bu özelliği etkinleştirmek için MediaSource.Factory.setCmcdConfigurationFactory(CmcdConfiguration.Factory cmcdConfigurationFactory) kullanın.
      • Tüm anahtarlar varsayılan olarak etkindir. Hangi anahtarların günlüğe kaydedileceğini filtrelemek için CmcdConfiguration.RequestConfig.isKeyAllowed(String key) geçersiz kılın.
      • Özel anahtar günlük kaydını etkinleştirmek için CmcdConfiguration.RequestConfig.getCustomData() değerini geçersiz kılın.
    • Ana demo manifestine ek işlem ekleyerek demo uygulamasını özel bir *.exolist.json dosyasıyla başlatmayı kolaylaştırın (#439).
    • Video oynatma sırasında Effect kullanmak için ExoPlayer.setVideoEffects() ekleyin.
    • sourceId dosyasını int yerine long olarak depolamak için SampleQueue uygulamasını güncelleyin. Bu işlem, SampleQueue.sourceId ve SampleQueue.peekSourceId herkese açık yöntemlerinin imzalarını değiştirir.
    • LoadControl yöntemlerine shouldStartPlayback ve onTracksSelected parametreleri ekleyin. Bu parametreler, söz konusu yöntemlerin ilgili MediaPeriod ile ilişkilendirilmesine olanak tanır.
    • ServerSideAdInsertionMediaSource.setAdPlaybackStates(Map<Object, AdPlaybackState>) işlevinin imzasını, haritada anahtar olarak kullanılan UID'leri içeren dönemleri içeren bir zaman çizelgesi parametresi ekleyerek değiştirin. Bu, çok dönemli canlı yayınlarda eşzamanlılık sorunlarını önlemek için gereklidir.
    • EventDispatcher.withParameters(int windowIndex, @Nullable MediaPeriodId mediaPeriodId, long mediaTimeOffsetMs) ve BaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs) öğelerini kullanımdan kaldırın. mediaTimeOffsetUs içermeyen yöntem varyantı bunun yerine çağrılabilir. Desteği sonlandırılan varyantlar için bile, gönderici tarafından gönderilen MediaLoadData nesnelerinin startTimeUs ve endTimeUs değerlerine artık ofset eklenmediğini unutmayın.
    • ExoTrackSelection.blacklist öğesini excludeTrack, isBlacklisted öğesini ise isTrackExcluded olarak yeniden adlandırın.
    • Boş bir oynatma listesinde çağrıldığında ExoPlayer.setMediaItem(s) ve addMediaItem(s) arasındaki tutarsız davranış düzeltildi.
  • Dönüştürücü:
    • Transformer.Builder.setMediaSourceFactory(MediaSource.Factory) öğesini kaldırın. Bunun yerine ExoPlayerAssetLoader.Factory(MediaSource.Factory) ve Transformer.Builder.setAssetLoaderFactory(AssetLoader.Factory) politikalarını kullanın.
    • Transformer.startTransformation(MediaItem, ParcelFileDescriptor) öğesini kaldırın.
    • Giriş karesinin işlenmesi beklenirken video akışının sonu işaretlendiğinde dönüşümün takılmasına (çoklayıcı zaman aşımına neden olan) yol açan hata düzeltildi.
    • Desteği genişletmek için findDecoder/EncoderForFormat yardımcı programlarını kullanmak yerine MediaCodecList üzerinden codec'leri sorgulayın.
    • Bazı cihazlarda çalışmadığı için DefaultEncoderFactory'da B çerçevesi yapılandırmasını kaldırın.
  • Parça seçimi:
    • Ekleme DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange varsayılan olarak devre dışıdır. Etkinleştirildiğinde, DefaultTrackSelector oluşturucu özellikleri değiştiğinde yeni bir parça seçimi tetiklenir.
  • Ayıklayıcılar:
    • Ogg: Uzun süreli dosyalarda arama yaparken oluşan hata düzeltildi (#391).
    • FMP4: TimestampAdjuster, emsg atomundan meta veri örnekleme zamanıyla yanlış bir zaman damgası uzaklığı başlatıyor sorununu düzeltin (#356).
  • Ses:
    • Tünel oluşturma etkinleştirildiğinde ve AudioProcessors etkin olduğunda bazı oynatmaların başarısız olmasına neden olan hata düzeltildi. Örneğin, boşluksuz kırpma için AudioProcessors etkin olduğunda oynatma başarısız oluyordu (#10847).
    • Doğrudan oynatmalarda (yük boşaltma) Opus karelerini Ogg paketleri içinde kapsar.
    • Uyku sırasında mevcut konumu, boşaltma planlamasıyla tahmin edin.
    • Kaynakları oyuncunun yaşam döngüsünün sonunda serbest bırakmak için Renderer.release() ve AudioSink.release() ekleyin.
    • DefaultAudioSink'daki ses özellikleriyle ilgili değişiklikleri dinleyin. DefaultAudioSink oluşturucusuna DefaultAudioSink için gerekli bir parametre context ekleyin. Bu parametreyle DefaultAudioSink, AudioCapabilitiesReceiver için dinleyici olarak kaydedilir ve özellik değişikliği hakkında bilgilendirildiğinde audioCapabilities özelliğini günceller.
    • onAudioCapabilitiesChanged arayüzündeki yeni bir etkinlik AudioSink.Listener ve onRendererCapabilitiesChanged etkinliklerini tetikleyen yeni bir arayüz RendererCapabilities.Listener aracılığıyla ses özelliklerindeki değişiklikleri yayma.
    • Ses kanallarına ölçeklendirme/karıştırma uygulamak için ChannelMixingAudioProcessor ekleyin.
    • Ses özellikleri değiştiğinde atlama modu mümkünse ses kod çözücüyü atmak için DISCARD_REASON_AUDIO_BYPASS_POSSIBLE yeni int değerini DecoderDiscardReasons öğesine ekleyin.
    • DTS Express ve DTS:X için doğrudan oynatma desteği eklendi (#335).
  • Video:
    • Oluşturucu devre dışı olduğunda MediaCodecVideoRenderer, genişliği ve yüksekliği 0 olan bir VideoSize raporlasın. Player.Listener.onVideoSizeChanged, Player.getVideoSize() değiştiğinde buna göre adlandırılır. Bu değişiklikle birlikte, MediaCodecVideoRenderer ile ExoPlayer'ın video boyutu, Player.getCurrentTracks video desteklemediğinde veya desteklenen video parçasının boyutu henüz belirlenmediğinde 0 genişliğe ve yüksekliğe sahip olur.
  • DRM:
    • DRM paketinin dışından çağrılması beklenmeyen DefaultDrmSession üzerindeki yalnızca dahili kullanıma yönelik çeşitli yöntemlerin görünürlüğünü azaltın:
      • void onMediaDrmEvent(int)
      • void provision()
      • void onProvisionCompleted()
      • onProvisionError(Exception, boolean)
  • Muxer:
    • MP4 kapsayıcı dosyası oluşturmak için kullanılabilecek yeni bir muxer kitaplığı eklendi.
  • IMA uzantısı:
    • DAI için çok dönemli canlı DASH yayınlarını etkinleştirin. Mevcut uygulamanın canlı yayınlarda arama özelliğini henüz desteklemediğini lütfen unutmayın (#10912).
    • Ardışık zaman çizelgelerindeki hesaplanmış içerik konumu biraz farklılık gösterdiğinden canlı yayınlara yeni bir reklam grubunun eklenmesine neden olan hata düzeltildi.
  • Oturum:
    • Şu anda bir MediaSession.getControllerForCurrentRequest yöntemini çağıran denetleyici hakkında bilgi edinmek için yardımcı yöntem Player ekleyin.
    • Uygulamaların, örneğin Bluetooth kulaklık tarafından gönderilen medya düğmesi etkinlikleriyle oynatmaya devam etme özelliğini uygulamasına olanak tanımak için androidx.media3.session.MediaButtonReceiver ekleyin (#167).
    • İstenen MediaItems öğesinin LocalConfiguration (ör. URI) varsa MediaSession.Callback.onAddMediaItems öğesine varsayılan uygulama ekleyerek Player öğesine iletilmesine izin verin (#282).
    • Android 12 ve önceki sürümlerde, kompakt medya bildirimi görünümüne varsayılan olarak "önceki öğeye git" ve "sonraki öğeye git" komut düğmeleri eklendi (#410).
    • İstenen MediaItems öğesinin LocalConfiguration (ör. URI) varsa MediaSession.Callback.onAddMediaItems öğesine varsayılan uygulama ekleyerek Player öğesine iletilmesine izin verin (#282).
    • Android 12 ve önceki sürümlerde, kompakt medya bildirimi görünümüne varsayılan olarak "önceki öğeye git" ve "sonraki öğeye git" komut düğmeleri eklendi (#410).
  • UI:
    • Oynat/duraklat düğmesi içeren özel kullanıcı arayüzü öğeleri yazmak için Util yöntemleri shouldShowPlayButton ve handlePlayPauseButtonAction'yi ekleyin.
  • RTSP Uzantısı:
    • MPEG4-LATM için, DescribeResponse SDP mesajında yoksa varsayılan profile-level-id değerini kullanın (#302).
    • DESCRIBE yanıt üstbilgisinde varsa RTSP oturumundan göreli yol çözümü için temel URI'yi kullanın (#11160).
  • DASH uzantısı:
    • Çok dönemli DASH akışları için MediaLoadData.startTimeMs ve MediaLoadData.endTimeMs öğelerinden medya zamanı farkını kaldırın.
    • Çok dönemli bir canlı Dash medya kaynağının yeniden hazırlanmasının IndexOutOfBoundsException (#10838) hatasına neden olduğu sorun düzeltildi.
  • HLS Uzantısı:
    • HlsMediaSource.Factory.setTimestampAdjusterInitializationTimeoutMs(long) yükleme iş parçacığının, TimestampAdjuster öğesinin başlatılmasını beklemesi için bir zaman aşımı ayarlamak üzere ekleyin. Başlatma işlemi zaman aşımı süresi dolmadan tamamlanmazsa oynatmanın sonsuza kadar duraklatılmasını önlemek için PlaybackException istisnası oluşturulur. Zaman aşımı varsayılan olarak sıfıra ayarlanır (#323).
  • Test yardımcı programları:
    • DataSourceContractTest içinde URI şeması büyük/küçük harf duyarsızlığını kontrol edin.
  • Desteği sonlandırılan sembolleri kaldırın:
    • DefaultAudioSink oluşturucularını kaldırın, bunun yerine DefaultAudioSink.Builder kullanın.
    • HlsMasterPlaylist işlemini kaldırın, bunun yerine HlsMultivariantPlaylist işlemini kullanın.
    • Player.stop(boolean) öğesini kaldırın. Bunun yerine Player.stop() ve Player.clearMediaItems() (reset true ise) kullanın.
    • Desteği sonlandırılan iki SimpleCache oluşturucuyu kaldırın. Daha iyi performans için bunun yerine DatabaseProvider alan, desteği sonlandırılmamış bir oluşturucu kullanın.
    • DefaultBandwidthMeter oluşturucusunu kaldırın, bunun yerine DefaultBandwidthMeter.Builder kullanın.
    • DefaultDrmSessionManager oluşturucularını kaldırın, bunun yerine DefaultDrmSessionManager.Builder kullanın.
    • Kullanımdan kaldırılan iki HttpDataSource.InvalidResponseCodeException oluşturucuyu kaldırın, hata günlüğünü iyileştirmek için ek alanları(cause, responseBody) kabul eden, kullanılmayan bir oluşturucu kullanın.
    • DownloadHelper.forProgressive, DownloadHelper.forHls, DownloadHelper.forDash ve DownloadHelper.forSmoothStreaming özelliklerini kaldırıp bunun yerine DownloadHelper.forMediaItem özelliğini kullanın.
    • Desteği sonlandırılan DownloadService oluşturucuyu kaldırın, channelDescriptionResourceId parametresi sağlama seçeneğini içeren, desteği sonlandırılmamış bir oluşturucu kullanın.
    • Charsets için desteği sonlandırılan String sabitlerini (ASCII_NAME, UTF8_NAME, ISO88591_NAME, UTF16_NAME ve UTF16LE_NAME) kaldırın. Bunun yerine kotlin.text paketindeki Kotlin Charsets'i, java.nio.charset.StandardCharsets veya com.google.common.base.Charsets kullanın.
    • Desteği sonlandırılan WorkManagerScheduler oluşturucuyu kaldırın. Bunun yerine, Context parametresi sağlama seçeneğini içeren, desteği sonlandırılmamış bir oluşturucu kullanın.
    • Format sınıfını oluşturmak için kullanılan, desteği sonlandırılan createVideoSampleFormat, createAudioSampleFormat, createContainerFormat ve createSampleFormat yöntemlerini kaldırın. Bunun yerine Format örnekleri oluşturmak için Format.Builder kullanın.
    • Desteği sonlandırılan copyWithMaxInputSize, copyWithSubsampleOffsetUs, copyWithLabel, copyWithManifestFormatInfo, copyWithGaplessInfo, copyWithFrameRate, copyWithDrmInitData, copyWithMetadata, copyWithBitrate ve copyWithVideoSize yöntemlerini kaldırın. Bunun yerine Format.buildUpon() ve ayarlayıcı yöntemlerini kullanın.
    • Desteği sonlandırılan ExoPlayer.retry() işlevini kaldırın, bunun yerine prepare() işlevini kullanın.
    • Desteği sonlandırılan sıfır bağımsız değişkenli DefaultTrackSelector oluşturucuyu kaldırın, bunun yerine DefaultTrackSelector(Context) kullanın.
    • Desteği sonlandırılan OfflineLicenseHelper oluşturucusunu kaldırın, bunun yerine OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) kullanın.
    • Desteği sonlandırılan DownloadManager oluşturucuyu kaldırın. Bunun yerine Executor alanını alan oluşturucuyu kullanın.
    • Desteği sonlandırılan Cue oluşturucularını kaldırın ve bunun yerine Cue.Builder oluşturucularını kullanın.
    • Desteği sonlandırılan OfflineLicenseHelper oluşturucusunu kaldırın, bunun yerine OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) kullanın.
    • Desteği sonlandırılan dört AnalyticsListener yöntemi kaldırıldı:
      • onDecoderEnabled, bunun yerine onAudioEnabled ve/veya onVideoEnabled kullanın.
      • onDecoderInitialized, bunun yerine onAudioDecoderInitialized ve/veya onVideoDecoderInitialized kullanın.
      • onDecoderInputFormatChanged, bunun yerine onAudioInputFormatChanged ve/veya onVideoInputFormatChanged kullanın.
      • onDecoderDisabled, bunun yerine onAudioDisabled ve/veya onVideoDisabled kullanın.
    • Desteği sonlandırılan Player.Listener.onSeekProcessed ve AnalyticsListener.onSeekProcessed işlemlerini kaldırın, bunun yerine onPositionDiscontinuity ile DISCONTINUITY_REASON_SEEK işlemlerini kullanın.
    • ExoPlayer.setHandleWakeLock(boolean) öğesini kaldırın, bunun yerine setWakeMode(int) öğesini kullanın.
    • Desteği sonlandırılan DefaultLoadControl.Builder.createDefaultLoadControl() öğesini kaldırın, bunun yerine build() öğesini kullanın.
    • Desteği sonlandırılan MediaItem.PlaybackProperties öğesini kaldırın, bunun yerine MediaItem.LocalConfiguration öğesini kullanın. Kullanımdan kaldırılan alan MediaItem.playbackProperties artık MediaItem.LocalConfiguration türünde.

Sürüm 1.1.0-rc01

21 Haziran 2023

1.1.0 kararlı sürümünü kullanın.

Sürüm 1.1.0-beta01

7 Haziran 2023

1.1.0 kararlı sürümünü kullanın.

Sürüm 1.1.0-alpha01

10 Mayıs 2023

1.1.0 kararlı sürümünü kullanın.

Sürüm 1.0.0

Sürüm 1.0.2

18 Mayıs 2023

androidx.media3:media3-*:1.0.2 iptal edilir. 1.0.2 sürümü şu commit'leri içerir.

Bu sürüm, ExoPlayer 2.18.7 sürümüne karşılık gelir.

Bu sürüm, 1.0.1 sürümünden bu yana aşağıdaki değişiklikleri içerir:

  • Core kitaplığı:
    • Buffer.isLastSample() ekleyin. Bu, Buffer öğesinin işaret içerip içermediğini gösterir C.BUFFER_FLAG_LAST_SAMPLE.
    • Kare içeren son örnek, "akışın sonu" örneği okunmadan kuyruktan çıkarılırsa son karenin oluşturulamamasına neden olan sorun düzeltildi. (#11079).
  • Ayıklayıcılar:
    • RTSP ve MP4 çıkarıcılar tarafından kullanılan ayrıştırma mantığını yeniden kullanarak MPEG-TS dosyalarındaki H.265 SPS'nin ayrıştırılmasıyla ilgili sorunu düzeltin (#303).
  • Metin:
    • SSA: Bayt sırası işaretiyle başlayan UTF-16 dosyaları için destek eklendi (#319).
  • Oturum:
    • MediaController, işlemlerini güncelleyen eski bir MediaSessionCompat'ye bağlandığında kullanılabilir komutlarını güncellememesine neden olan sorun düzeltildi.
    • API 30'da MediaLibraryService öğesinin, Sistem Kullanıcı Arayüzü'nden params.isRecent == true ile Callback.onGetLibraryRoot öğesine yapılan bir çağrı için null döndürmesini engelleyen hata düzeltildi (#355).
    • MediaSessionService veya MediaLibraryService bellek sızıntısı düzeltildi (#346).
    • Timeline ve MediaSession içinde birleştirilmiş konum güncellemesinin MediaController öğesinin IllegalStateException oluşturmasına neden olabileceği hata düzeltildi.

Sürüm 1.0.1

18 Nisan 2023

androidx.media3:media3-*:1.0.1 iptal edilir. 1.0.1 sürümü şu commit'leri içerir.

Bu sürüm, ExoPlayer 2.18.6 sürümüne karşılık gelir.

  • Core kitaplığı:
    • Varsayılan konuma gitmek için arama yaparken hedef canlı yayın geçersiz kılmasını sıfırlayın (#11051).
    • Medyadaki boş örnek akışların oynatmanın takılmasına neden olabildiği hata düzeltildi.
  • Oturum:
    • Eski bir MediaSessionCompat tarafından yayınlanan birden fazla aynı kuyruk öğesinin MediaController içinde istisnaya neden olduğu hata düzeltildi (#290).
    • MediaSession.broadcastCustomCommand öğesinin eski MediaControllerCompat.Callback.onSessionEvent öğesine yönlendirilmesiyle ilgili eksiklik giderildi (#293).
    • MediaSession.setPlayer işlevinin çağrılmasının, kullanılabilir komutları güncellememesine yol açan hata düzeltildi.
    • TrackSelectionOverride örnekleri bir MediaController adresinden gönderildiğinde Format.metadata içeren bir gruba referans veriyorsa yoksayılması sorunu düzeltildi (#296).
    • Player.COMMAND_GET_CURRENT_MEDIA_ITEM, eski MediaSessionCompat üzerinden meta verilere erişmek için kullanılabilir olmalıdır.
    • Arka plandaki bir iş parçacığında MediaSession örneklerinin MediaSessionService içinde kullanıldığında kilitlenmelere neden olduğu sorun düzeltildi (#318).
    • Kitaplık tarafından, uygulamanın amaçlamadığı şekilde bir medya düğmesi alıcısının bildirilmesi sorunu düzeltildi (#314).
  • DASH:
    • Boş segment zaman çizelgelerinin işlenmesi düzeltildi (#11014).
  • RTSP:
    • UDP ile RTSP kurulumu, RTSP Error 461 UnsupportedTransport (#11069) ile başarısız olursa TCP ile yeniden deneyin.

Sürüm 1.0.0

22 Mart 2023

androidx.media3:media3-*:1.0.0 iptal edilir. Version 1.0.0 contains these commits.

Bu sürüm, ExoPlayer 2.18.5 sürümüne karşılık gelir.

1.0.0-rc02 sürümünden bu yana herhangi bir değişiklik yapılmadı.

Sürüm 1.0.0-rc02

2 Mart 2023

androidx.media3:media3-*:1.0.0-rc02 iptal edilir. Version 1.0.0-rc02 contains these commits.

Bu sürüm, ExoPlayer 2.18.4 sürümüne karşılık gelir.

  • Core kitaplığı:
    • API 33'te ağ türü algılama sorunu düzeltildi (#10970).
    • ExoPlayer.isTunnelingEnabled'ı ararken NullPointerException sorununu düzeltin (#10977).
  • İndirilenler:
    • Birleştirilecek iki segmentin başlangıç zamanı arasındaki maksimum farkın SegmentDownloader ve alt sınıflarda yapılandırılabilir olması sağlandı (#248).
  • Ses:
    • Samsung cihazlarda kesintisiz MP3 oynatma özelliğinin çalışmaması sorununu düzeltme (#8594).
    • Ses devre dışı bırakıldıktan hemen sonra ayarlanan oynatma hızlarının önceki bir hız değişikliğiyle geçersiz kılınmasına neden olan hata düzeltildi (#10882).
  • Video:
    • HEVC HDR10 biçimini HEVCProfileMain10 yerine HEVCProfileMain10HDR10 ile eşleyin.
    • Google TV'li Chromecast ve Lenovo M10 FHD Plus'ta 60 fps AVC akışlarının desteklenmiyor olarak işaretlenmesine neden olan cihaz sorununa yönelik geçici çözüm eklendi (#10898).
    • Ekran yenileme hızından çok daha yüksek bir kare hızına sahip medyayı oynatırken kare yayınlama performansıyla ilgili sorunları düzeltir.
  • Yayınlama:
    • Medya öğeleri arasında geçiş yaparken oluşan geçici STATE_IDLE sorunu düzeltildi ( #245).
  • RTSP:
    • Geçersiz RTSP Describe yanıt mesajlarının ayrıştırılmasında oluşturulan IllegalArgumentException'ı yakalayın (#10971).
  • Oturum:
    • Bildirimdeki oynatma/duraklatma düğmesinin oynatıcı durumuyla güncellenmemesine neden olan hata düzeltildi (#192).
  • IMA uzantısı:
    • İlk (ve reklamsız durumda tek) LOADED etkinliği alınmadığı için reklamsız DAI akışlarının başlatılmasını engelleyen hata düzeltildi.

Sürüm 1.0.0-rc01

16 Şubat 2023

androidx.media3:media3-*:1.0.0-rc01 iptal edilir. Version 1.0.0-rc01 contains these commits.

Bu sürüm, ExoPlayer 2.18.3 sürümüne karşılık gelir.

  • Core kitaplığı:
    • Kod çözücü, medyayı performanslı bir şekilde oynatamayacağını bildirse bile MediaCodecSelector'nın tercihlerini korumak için oluşturucunun kod çözücü sıralama mantığını ayarlayın. Örneğin, varsayılan seçiciyle, yalnızca işlevsel destek sunan donanım kod çözücü, biçimi tam olarak destekleyen yazılım kod çözücüye tercih edilir (#10604).
    • Yeni bir ExoPlayer örneği için önceden var olan bir oynatma iş parçacığını ayarlayan ExoPlayer.Builder.setPlaybackLooper ekleyin.
    • İndirme yöneticisi yardımcılarının temizlenmesine izin verilir (#10776).
    • Arama için kullanılan komutu da belirtmek üzere BasePlayer.seekTo öğesine parametre ekleyin.
    • API 21 ve sonraki sürümlerde çizilebilir öğeler yüklenirken tema kullanma (#220).
    • Birden fazla medya öğesinin tek bir pencerede birleştirilmesine olanak tanıyan ConcatenatingMediaSource2 eklendi (#247).
  • Ayıklayıcılar:
    • Trak atomları ayrıştırılırken örnek tablosunda (stbl) gerekli bir örnek açıklaması (stsd) eksikse NullPointerException yerine ParserException atın.
    • fMP4'te doğrudan bir senkronizasyon karesine giderken örnekleri doğru şekilde atlayın (#10941).
  • Ses:
    • Doğrudan oynatmalarda (geçiş) AudioTrack için minimum arabellek boyutunu hesaplamak üzere sıkıştırılmış ses biçimi bit hızını kullanın.
  • Metin:
    • Altyazı dosyasında ipucu yoksa TextRenderer öğesinin Subtitle.getEventTime öğesine geçersiz (negatif) bir dizin iletmesi düzeltildi.
    • SubRip: Bayt sırası işaretiyle başlayan UTF-16 dosyaları için destek eklendi.
  • Meta veri:
    • ID3 v2.4'ün izin verdiği şekilde, ID3 çerçevelerinden birden fazla boş değerle ayrılmış değeri ayrıştırın.
    • Meta verilerle açıklanan içerik türünü veya klasör türünü belirtmek için MediaMetadata.mediaType simgesini ekleyin.
    • MediaMetadata.isBrowsable öğesini MediaMetadata.folderType yerine ekleyin. Klasör türünün desteği bir sonraki sürümde sonlandırılacak.
  • DASH:
    • Kutu sayıları da dahil olmak üzere, resim uyarlama kümeleri için tam ayrıştırma eklendi (#3752).
  • UI:
    • Görünürlük değişikliklerinin kayıtlı dinleyiciye iletilmesini sağlamak için kullanımdan kaldırılan PlayerView.setControllerVisibilityListener(PlayerControlView.VisibilityListener) #229) düzeltin.
    • Sağdan sola (RTL) düzen kullanılırken PlayerView içindeki orta oynatıcı kontrollerinin sıralaması düzeltildi (#227).
  • Oturum:
    • Özel oynatıcılar için Player arayüzünün uygulanmasına yardımcı olmak üzere soyut SimpleBasePlayer ekleyin.
    • Platform oturum jetonunu Media3'e dönüştürmek için yardımcı yöntem ekleyin SessionToken (#171).
    • Platform medya oturumunun güncellemelerini tetiklemek için onMediaMetadataChanged kullanın (#219).
    • Medya oturumunu getMediaButtons() öğesinin bağımsız değişkeni olarak ekleyin DefaultMediaNotificationProvider ve netlik için değişmez listeler kullanın (#216).
    • onSetMediaItems geri çağırma işleyicisi ekleyin. Bu işleyici, oynatıcıya ayarlanmadan önce oturuma göre MediaItem listesini, başlangıç dizinini ve konumunu değiştirme/ayarlama olanağı sağlar (#156).
    • Bluetooth olmayan medya düğmesi etkinliklerinde çift dokunma algılamasını önleme (#233).
    • Şüpheli bir eski oturum durumu olması durumunda QueueTimeline daha sağlam hale getirildi (#241).
  • Meta veri:
    • ID3 v2.4'ün izin verdiği şekilde, ID3 çerçevelerinden birden fazla boş değerle ayrılmış değeri ayrıştırın.
    • Meta verilerle açıklanan içerik türünü veya klasör türünü belirtmek için MediaMetadata.mediaType simgesini ekleyin.
    • MediaMetadata.isBrowsable öğesini MediaMetadata.folderType yerine ekleyin. Klasör türünün desteği bir sonraki sürümde sonlandırılacak.
  • Yayın uzantısı:
    • Cast SDK sürümünü 21.2.0'a yükseltti.
  • IMA uzantısı:
    • İş parçacığı sorunlarını önlemek için uygulama iş parçacığında ImaServerSideAdInsertionMediaSource öğesinin oynatıcı işleyicisini kaldırın.
    • TV cihazlarında atla düğmesine odaklanılmasını istemek ve bunu varsayılan olarak doğru olacak şekilde ayarlamak için focusSkipButtonWhenAvailable özelliğini ImaServerSideAdInsertionMediaSource.AdsLoader.Builder öğesine ekleyin.
    • Programatik olarak atla düğmesine odaklanma isteğinde bulunmak için ImaServerSideAdInsertionMediaSource.AdsLoader öğesine focusSkipButton() yöntemi ekleyin.
    • IMA SDK sürümünü 3.29.0'a yükseltin.
  • Demo uygulaması:
    • Çalışma zamanında indirme bildirimleri için bildirim izni isteyin (#10884).

Sürüm 1.0.0-beta03

22 Kasım 2022

androidx.media3:media3-*:1.0.0-beta03 iptal edilir. Version 1.0.0-beta03 contains these commits.

Bu sürüm, ExoPlayer 2.18.2 sürümüne karşılık gelir.

  • Core kitaplığı:
    • Tünel oluşturma özelliğinin şu anda seçili parçalarda etkin olup olmadığını kontrol etmek için ExoPlayer.isTunnelingEnabled simgesini ekleyin (#2518).
    • Tek bir MediaSource sarmalamayı basitleştirmek için WrappingMediaSource eklendi (#7279).
    • Yeterli bellek olmadığından oynatma takılmadan önce arka arabelleği silin.
    • Offload etkinleştirildiğinde "doSomeWork" izleme bloğunu kapatın.
    • PlaybackStatsListener'da hızlı ileri sarma ile ilgili oturum izleme sorunu düzeltildi (#180).
    • Tek öğeli bir oynatma listesinde seekToNext veya seekToPrevious çağrılırken eksik onMediaItemTransition geri arama işlevini gönderin (#10667).
    • Videonun oluşturulduğu yüzeyin boyutunu döndüren Player.getSurfaceSize işlevini ekleyin.
    • Oyuncu yayınlanırken dinleyicilerin kaldırılmasının IllegalStateException (#10758) hatasına neden olabildiği hata düzeltildi.
  • Derleme:
    • Derleme hatalarını önlemek için minimum compileSdkVersion değerini zorunlu kılın (#10684).
    • Başka bir Gradle derlemesine dahil edildiğinde yayınlamayı engelleme
  • Parça seçimi:
    • Ekran Dolby Vision'ı desteklemiyorsa Dolby Vision yerine diğer parçalar tercih edilir. (#8944).
  • İndirilenler:
    • Aynı PriorityTaskManager ile eşzamanlı indirme ve oynatmanın neden olduğu ProgressiveDownloader içindeki olası sonsuz döngü düzeltildi (#10570).
    • İndirme bildiriminin hemen görünmesini sağlama (#183).
    • Aşırı iş parçacığı oluşturmayı önlemek için paralel indirme kaldırma işlemlerini 1 ile sınırlayın (#10458).
  • Video:
    • Ekran Dolby Vision'ı desteklemiyorsa Dolby Vision için alternatif bir kod çözücü deneyin. (#9794).
  • Ses:
    • Aynı anda birden fazla oynatıcıyı serbest bırakırken OutOfMemory hatalarını önlemek için AudioTrack örneklerini serbest bırakırken SingleThreadExecutor kullanın (#10057).
    • AudioTrack'in yük boşaltma durumu için AudioOffloadListener.onExperimentalOffloadedPlayback ekler. (#134).
    • AudioTrackBufferSizeProvider öğesini herkese açık bir arayüz haline getirin.
    • Tercih edilen ses çıkışı cihazını ayarlamak için ExoPlayer.setPreferredAudioDevice ekleyin (#135).
    • androidx.media3.exoplayer.audio.AudioProcessor öğesini androidx.media3.common.audio.AudioProcessor olarak yeniden adlandırın.
    • Tüm Android sürümlerinde 8 kanallı ve 12 kanallı sesleri sırasıyla 7.1 ve 7.1.4 kanallı maskelere eşleme (#10701).
  • Meta veri:
    • MetadataRenderer artık meta veriler kullanılabilir hale gelir gelmez oluşturacak şekilde yapılandırılabilir. Oluşturucu, meta verileri erken mi yoksa oynatıcı konumuyla senkronize olarak mı çıkışa vereceğini belirtmek için MetadataRenderer(MetadataOutput, Looper, MetadataDecoderFactory, boolean) ile bir örnek oluşturun.
  • DRM:
    • Android 13 ClearKey uygulamasında boş olmayan ancak geçersiz bir lisans URL'si döndüren bir hatayı geçici olarak çözün.
    • Oynatma listesinde DRM şemaları (ör. Widevine'dan ClearKey'e) arasında geçiş yaparken karşılaşılan setMediaDrmSession failed: session not opened hatası düzeltildi.
  • Metin:
    • CEA-608: Alan 2'deki hizmet anahtarı komutlarının doğru şekilde işlendiğinden emin olun (#10666).
  • DASH:
    • Manifestlerden EventStream.presentationTimeOffset ayrıştırın (#10460).
  • UI:
    • Oynatıcının mevcut geçersiz kılmalarını TrackSelectionDialogBuilder içinde önceden ayarlanmış olarak kullanın TrackSelectionDialogBuilder (#10429).
  • Oturum:
    • Bazıları eşzamansız çözümleme gerektirse bile komutların her zaman doğru sırada yürütüldüğünden emin olun (#85).
    • DefaultMediaNotificationProvider.Builder oluşturmak için DefaultMediaNotificationProvider.Builder ekleyin.DefaultMediaNotificationProvider Oluşturucu, sağlayıcı tarafından kullanılan bildirim kimliğini, bildirim kanalı kimliğini ve bildirim kanalı adını yapılandırabilir. Ayrıca, bildirimlerin küçük simgesini ayarlamak için method DefaultMediaNotificationProvider.setSmallIcon(int) öğesini ekleyin. (#104).
    • MediaController.release() tarihinden önce gönderilen komutların bırakılmadığından emin olun (#99).
    • SimpleBitmapLoader, file:// URI'lerinden bit eşlem yükleyebilir (#108).
    • MediaController'nın bir dönemdeki reklamda arama yapmasını engelleyen onaylamayı düzeltin (#122).
    • Oynatma sona erdiğinde MediaSessionService ön planda durdurulur ve son oynatılan medya öğesinin oynatılmasını yeniden başlatmak için bir bildirim gösterilir (#112).
    • Duraklatma için bekleyen bir amaçla ön plan hizmeti başlatmayın (#167).
    • API 26 ve API 27'de DefaultNotificationProvider tarafından oluşturulan bildirimle ilişkili "rozet"i manuel olarak gizleyin (rozet, API 28 ve sonraki sürümlerde otomatik olarak gizlenir) ( (#131).
    • Eski bir MediaSession'dan Media3 MediaController'a yapılan ikinci bir bağlayıcı bağlantısının IllegalStateExceptions'a neden olduğu hata düzeltildi (#49).
  • RTSP:
    • H263 parçalanmış paket işleme özelliği eklendi (#119).
    • MP4A-LATM için destek eklendi (#162).
  • IMA:
    • IMA SDK'nın reklam yüklerken takıldığı durumları ele almak için reklam bilgilerinin yüklenmesiyle ilgili zaman aşımı eklendi (#10510).
    • İçeriğin sonuna gidilirken videonun ortasında gösterilen reklamların atlanmasını önleme (#10685).
    • Sunucu tarafında eklenen reklamların bulunduğu canlı yayınlarda aralık süresini doğru şekilde hesaplayın (ör. IMA DAI) (#10764).
  • FFmpeg uzantısı:
    • FFmpeg kitaplıklarını NDK 23.1.7779620 ve sonraki sürümlerle bağlamak için yeni zorunlu işaretleri ekleyin (#9933).
  • AV1 uzantısı:
    • En yeni Android Studio sürümleriyle uyumsuzlukları önlemek için CMake sürümünü güncelleyin (#9933).
  • Yayın uzantısı:
    • getDeviceInfo() uygulayarak MediaController ile oynatmayı kontrol ederken CastPlayer öğesini tanımlayabilirsiniz (#142).
  • Dönüştürücü:
    • Çıkış örneği oluşturma işleminin çok yavaş olduğunu algılamak için muxer watchdog zamanlayıcısı eklendi.
  • Desteği sonlandırılan sembolleri kaldırın:
    • Transformer.Builder.setOutputMimeType(String) öğesini kaldırın. Bu özellik kaldırıldı. Varsayılan muxer kullanıldığında MIME türü her zaman MP4 olur.

Sürüm 1.0.0-beta02

21 Temmuz 2022

androidx.media3:media3-*:1.0.0-beta02 iptal edilir. 1.0.0-beta02 sürümü aşağıdaki commit'leri içerir.

Bu sürüm, ExoPlayer 2.18.1 sürümüne karşılık gelir.

  • Core kitaplığı:
    • ShuffleOrder yerine ExoPlayer.setShuffleOrder yazıldığında Player.Listener#onTimelineChanged'nin reason=Player.TIMELINE_CHANGE_REASON_PLAYLIST_CHANGED ile aranacağından emin olun (#9889).
    • Aşamalı medya için yalnızca arabelleğe alınmış konumdaki seçili parçaları ekleyin (#10361).
    • Tüm ExoPlayer günlük çıkışı için özel günlükçüye izin verin (#9752).
    • Bazı durumlarda işlevsel olmayan setDataSourceFactory öğesinin DefaultMediaSourceFactory içinde uygulanması düzeltildi (#116).
  • Ayıklayıcılar:
    • H265 kısa vadeli referans resim kümelerinin ayrıştırılmasıyla ilgili sorun düzeltildi (#10316).
    • esds kutularından bit hızlarının ayrıştırılması düzeltildi (#10381).
  • DASH:
    • Manifestlerden ClearKey lisans URL'sini ayrıştırma (#10246).
  • UI:
    • TalkBack'in, oynatma kontrolleri menüsünde etkin olan hız seçeneğini duyurduğundan emin olun (#10298).
  • RTSP:
    • VP8 parçalanmış paket işleme özelliği eklendi (#110).
  • Leanback uzantısı:
    • LeanbackAdapter'teki playWhenReady değişikliklerini dinleyin (10420).
  • Yayınlama:
    • Oynatma listesi yöntemlerine iletilen MediaItem değerini CastTimeline içinde Window.mediaItem olarak kullanın (#25, #8212).
    • Player.getMetadata() ve Listener.onMediaMetadataChanged()CastPlayer (#25) ile destekleyin.

Sürüm 1.0.0-beta01

16 Haziran 2022

androidx.media3:media3-*:1.0.0-beta01 iptal edilir. 1.0.0-beta01 sürümü aşağıdaki commit'leri içerir.

Bu, ExoPlayer 2.18.0 sürümüne karşılık gelir.

  • Core kitaplığı:
    • MediaMetricsManager üzerinden Android platform teşhisleri desteğini etkinleştirin. ExoPlayer, oynatma etkinliklerini ve performans verilerini platforma yönlendirir. Bu sayede cihazda sistem performansı ve hata ayıklama bilgileri sağlanır. Bu veriler, cihaz kullanıcısı kullanım ve teşhis verilerinin paylaşımını etkinleştirirse Google tarafından da toplanabilir. Uygulamalar, ExoPlayer.Builder.setUsePlatformDiagnostics(false) ile ExoPlayer için platform teşhislerine katkıda bulunmayı devre dışı bırakabilir.
    • MergingMediaSource kullanılırken parçaların çok sık sıfırlanmasıyla ilgili hata düzeltildi. Örneğin, altyazılar yan yüklenirken ve oynatma sırasında seçili altyazı değiştirilirken bu hata oluşuyordu (#10248).
    • API 29 ve 30'da 5G-NSA ağ türünün algılanması durduruldu. Bu oynatmalarda 4G ağı varsayılır.
    • null'nın MediaSource.Factory.setDrmSessionManagerProvider ve MediaSource.Factory.setLoadErrorHandlingPolicy'a aktarılmasına izin vermeyin. Gerekirse DefaultDrmSessionManagerProvider ve DefaultLoadErrorHandlingPolicy örnekleri açıkça iletilebilir.
    • Tam LocalConfiguration bilinmediğinde medyayı oynatmak için gereken meta verileri temsil etmek üzere MediaItem.RequestMetadata ekleyin. MediaMetadata.mediaUrl artık RequestMetadata'ye dahil edildiğinden bu alanı da kaldırın.
    • Oyuncuların tek bir öğe ayarlamasına izin vermek için Player.Command.COMMAND_SET_MEDIA_ITEM ekleyin.
  • Parça seçimi:
    • TrackSelectionOverrides sınıfını TrackSelectionParameters sınıfına düzleştirin ve TrackSelectionOverride sınıfını üst düzey bir sınıfa yükseltin.
    • TracksInfo öğesini Tracks, TracksInfo.TrackGroupInfo öğesini ise Tracks.Group olarak yeniden adlandırın. Player.getCurrentTracksInfo ve Player.Listener.onTracksInfoChanged da Player.getCurrentTracks ve Player.Listener.onTracksChanged olarak yeniden adlandırıldı. Bu, Player.Listener.onTracksChanged yöntem adının farklı parametre türleriyle "kullanımdan kaldırılmasını geri alma" işlemini içerir.
    • Kullanımdan kaldırılan DefaultTrackSelector.ParametersBuilder yerine DefaultTrackSelector.buildUponParameters ve DefaultTrackSelector.Parameters.buildUpon değerlerini DefaultTrackSelector.Parameters.Builder döndürecek şekilde değiştirin.
    • Ekleme DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities varsayılan olarak etkindir. Etkinleştirildiğinde DefaultTrackSelector, kanal sayısı cihazın çıkış özelliklerini aşmayan ses parçalarını tercih eder. Elde taşınabilir cihazlarda, çok kanallı biçim uzamsallaştırılabilir (Android 12L+) veya Dolby surround ses biçimi olmadığı sürece DefaultTrackSelector, çok kanallı ses biçimleri yerine stereo/mono biçimini tercih eder. Ayrıca, ses uzamsallaştırmayı destekleyen cihazlarda DefaultTrackSelector, uzamsallaştırıcı özelliklerindeki değişiklikleri izler ve bu değişiklikler üzerine yeni bir parça seçimi tetikler. television kullanıcı arayüzü moduna sahip cihazlar bu kısıtlamaların dışında tutulur ve en yüksek kanal sayısına sahip biçim tercih edilir. Bu özelliği etkinleştirmek için DefaultTrackSelector örneği Context ile oluşturulmalıdır.
  • Video:
    • DummySurface öğesini PlaceholderSurface olarak yeniden adlandırın.
    • MediaCodecVideoRenderer.getCodecMaxInputSize'ya AV1 desteği ekleyin.
  • Ses:
    • Standart olmayan MIME türü reklamı yapan LG AC3 ses kod çözücüsünü kullanın.
    • API < 21'de yavaş ART doğrulamayı önlemek için AudioAttributes.getAudioAttributesV21() öğesinin dönüş türünü android.media.AudioAttributes yerine yeni bir AudioAttributesV21 sarmalayıcı sınıfı olarak değiştirin.
    • Biçim ses kanalı sayısı ayarlanmadığında platformu sorgulayın (API 29+) veya ses geçişi için ses kodlama kanalı sayısının varsayıldığını kabul edin. Bu durum, HLS parçasız hazırlama ile oluşur (10204).
    • Kod çözücü 12 kanallı PCM ses çıkışı veriyorsa AudioTrack öğesini kanal maskesiyle AudioFormat.CHANNEL_OUT_7POINT1POINT4 yapılandırın (#10322.
  • DRM
    • Biçim değişikliğinden hemen sonra arama yapıldığında DRM oturumunun her zaman doğru şekilde güncellendiğinden emin olun (10274).
  • Metin:
    • Player.getCurrentCues() değerini List<Cue> yerine CueGroup döndürecek şekilde değiştirin.
    • SSA: OutlineColour stil ayarını BorderStyle == 3 olduğunda destekler (ör. OutlineColour, ipucunun arka planını ayarlar) (#8435).
    • CEA-708: Verileri birden fazla hizmet bloğuna ayrıştırın ve şu anda seçili hizmet numarasıyla ilişkili olmayan blokları yoksayın.
    • Yalnızca Google içinde kullanılan bir altyazı biçimini işlemek için kullanılan RawCcExtractor kaldırıldı.
  • Ayıklayıcılar:
    • AVI desteği eklendi (#2092).
    • Matroska: Opus parçaları için DiscardPadding ayrıştırılır.
    • MP4: Bit hızlarını esds kutularından ayrıştırın.
    • Ogg: Yinelenen Opus kimliğine ve yorum başlıklarına izin verin (#10038).
  • UI:
    • OnClickListener cihazlarına etkinlik yayınlanmasıyla ilgili sorunları düzeltin. Bu sorunlar, useController=false durumunda PlayerView üzerinde ayarlanan OnClickListener cihazlarında görülür. (#9605). Ayrıca, tüm görünüm yapılandırmaları için OnLongClickListener'ya etkinlik teslimini düzeltin.
    • PlayerView sınırlarından ACTION_UP öncesinde çıkan bir dokunma etkinlikleri dizisinin yanlışlıkla tıklama olarak değerlendirilmesi sorunu düzeltildi (#9861).
    • Dokunulduğunda kontrolleri gizlemek yerine oynatmayı açıp kapatmaya neden olan PlayerView erişilebilirlik sorunu düzeltildi (#8627).
    • TrackSelectionView ve TrackSelectionDialogBuilder öğelerini ExoPlayer yerine Player arayüzüyle çalışacak şekilde yeniden yazın. Bu sayede görünümlerin diğer Player uygulamalarıyla kullanılması sağlanır ve kullanıcı arayüzü modülünün ExoPlayer modülüne olan bağımlılığı kaldırılır. Bu, önemli bir değişikliktir.
    • PlayerView parça seçicide zorunlu metin parçalarını göstermeyin ve "Yok" seçiliyse uygun bir zorunlu metin parçasını seçili tutun (#9432).
  • DASH:
    • DTS AudioChannelConfiguration öğelerinden kanal sayısını ayrıştırın. Bu, DTS akışları için ses geçişini yeniden etkinleştirir (#10159).
    • null öğesinin DashMediaSource.Factory.setCompositeSequenceableLoaderFactory öğesine aktarılmasına izin verme. Gerekirse DefaultCompositeSequenceableLoaderFactory örnekleri açıkça iletilebilir.
  • HLS:
    • Oynatma listesinin CODECS özelliğinde ses codec'i yoksa parçalı hazırlamaya geri dönülür (#10065).
    • null öğesinin HlsMediaSource.Factory.setCompositeSequenceableLoaderFactory, HlsMediaSource.Factory.setPlaylistParserFactory ve HlsMediaSource.Factory.setPlaylistTrackerFactory öğelerine aktarılmasına izin vermeyin. Gerekirse DefaultCompositeSequenceableLoaderFactory, DefaultHlsPlaylistParserFactory veya DefaultHlsPlaylistTracker.FACTORY referansının örnekleri açıkça iletilebilir.
  • Sorunsuz akış:
    • null öğesinin SsMediaSource.Factory.setCompositeSequenceableLoaderFactory öğesine aktarılmasına izin verme. Gerekirse DefaultCompositeSequenceableLoaderFactory örnekleri açıkça iletilebilir.
  • RTSP:
    • H263 için RTP okuyucu ekleyin (#63).
    • MPEG4 için RTP okuyucu ekleyin (#35).
    • HEVC için RTP okuyucu eklendi (#36).
    • AMR için RTP okuyucu eklendi. Şu anda yalnızca tek kanallı, araya eklenmemiş AMR akışları desteklenmektedir. Bileşik AMR RTP yükü desteklenmez. (#46)
    • VP8 için RTP okuyucu eklendi (#47).
    • WAV için RTP okuyucu ekleyin (#56).
    • RTSP temel yetkilendirme üstbilgisini düzeltin. (#9544).
    • ExoPlayer'ın zorunlu SDP alanlarına ihtiyacı olmadığından bu alanların kontrolü durduruldu (#10049).
    • RTSP zamanlaması ayrıştırılırken kontrol edilen istisnayı atma (#10165).
    • VP9 için RTP okuyucu eklendi (#47).
    • OPUS için RTP okuyucu eklendi (#53).
  • Veri kaynakları:
    • DummyDataSource öğesini PlaceholderDataSource olarak yeniden adlandırın.
    • OkHttp kesme işleme için geçici çözüm.
  • Oturum:
    • İsteklerin eşzamansız olarak çözümlenmesine izin vermek için MediaSession.MediaItemFiller yerine MediaSession.Callback.onAddMediaItems kullanın.
    • setMediaItems(s), eski bir medya oturumuna bağlandığında MediaController yöntemlerini destekler.
    • MediaController.setMediaUri ve MediaSession.Callback.onSetMediaUri öğelerini kaldırın. Aynı işlev, MediaController.setMediaItem ve MediaSession.Callback.onAddMediaItems kullanılarak da elde edilebilir.
    • Eski MediaController aramalarını onSetMediaUri yerine MediaSession.Callback.onAddMediaItems numarasına yönlendirin.
    • Bildirimi özelleştirmek için MediaNotification.Provider ve DefaultMediaNotificationProvider öğelerini ekleyin.
    • Albüm kapaklarını indirmek için BitmapLoader ve SimpleBitmapLoader özelliklerini ekleyin.
    • Eski oturumla geriye dönük uyumluluk sağlamak için MediaSession.setCustomLayout() ekleyin.
    • Eski oturumla özellik eşliği sağlamak için MediaSession.setSessionExtras() ekleyin.
    • MediaSession.MediaSessionCallback öğesini MediaSession.Callback, MediaLibrarySession.MediaLibrarySessionCallback öğesini MediaLibrarySession.Callback ve MediaSession.Builder.setSessionCallback öğesini setCallback olarak yeniden adlandırın.
    • MediaControllerImplLegacy içinde NPE düzeltildi (#59).
    • Zaman çizelgesinde oturum konumu bilgilerini güncelleme değişikliği(#51).
    • Denetleyici yayınlandıktan sonra MediaControllerImplBase içinde NPE'yi düzeltin (#74).
  • Reklam oynatma / IMA:
    • Medya Derecelendirme Konseyi'nin (MRC) önerileriyle uyumlu hale getirmek için reklam yoklama sıklığını her 100 ms'den her 200 ms'ye düşürün.
  • FFmpeg uzantısı:
    • Android Studio'nun Gradle senkronizasyonunun başarısız olmasına neden olan bir CMake hatasını önlemek için CMake sürümünü 3.21.0+ olarak güncelleyin ( #9933).
  • Desteği sonlandırılan sembolleri kaldırın:
    • Player.Listener.onTracksChanged(TrackGroupArray, TrackSelectionArray) öğesini kaldırın. Bunun yerine Player.Listener.onTracksChanged(Tracks) kullanın.
    • Player.getCurrentTrackGroups ve Player.getCurrentTrackSelections araçlarını kaldırın. Bunun yerine Player.getCurrentTracks kullanın. Bu yöntemler desteği sonlandırılmış olsa da ExoPlayer.getCurrentTrackGroups ve ExoPlayer.getCurrentTrackSelections kullanmaya devam edebilirsiniz.
    • DownloadHelper DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT ve DEFAULT_TRACK_SELECTOR_PARAMETERS sabitlerini kaldırın. Mümkün olduğunda getDefaultTrackSelectorParameters(Context), aksi takdirde DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT politikasını kullanın.
    • DefaultTrackSelector(ExoTrackSelection.Factory) oluşturucusunu kaldırın. Bunun yerine DefaultTrackSelector(Context, ExoTrackSelection.Factory) politikasını kullanın.
    • Transformer.Builder.setContext öğesini kaldırın. Context, Transformer.Builder oluşturucusuna iletilmelidir.

Sürüm 1.0.0-alpha03

14 Mart 2022

androidx.media3:media3-*:1.0.0-alpha03 iptal edilir. Version 1.0.0-alpha03 contains these commits.

Bu, ExoPlayer 2.17.1 sürümüne karşılık gelir.

  • Ses:
    • HLS'de Dolby Atmos (E-AC3-JOC) için ses özelliklerinin kontrolüyle ilgili hatayı düzeltir.
  • Ayıklayıcılar:
    • FMP4: Hem v0 hem de v1 emsg atomlarını içeren akışlarda emsg örnek meta verilerinin yanlış sırada çıkış yapılması sorunu düzeltildi (#9996).
  • Metin:
    • SingleSampleMediaSource.Factory.setTrackId ve MediaItem.SubtitleConfiguration.Builder.setId etkileşimini düzeltip SubtitleConfiguration alanına öncelik verin ve ayarlanmamışsa Factory değerine geri dönün (#10016).
  • Reklam oynatma:
    • HLS SSAI canlı yayınlarında reklam dönemleri arasındaki ses yetersizliklerini düzeltin.

Sürüm 1.0.0-alpha02

2 Mart 2022

androidx.media3:media3-*:1.0.0-alpha02 iptal edilir. Version 1.0.0-alpha02 contains these commits.

Bu, ExoPlayer 2.17.0 sürümüne karşılık gelir.

  • Core Library:
    • DefaultRenderersFactory.getCodecAdapterFactory() yöntemini korumalı olarak ekleyin. DefaultRenderersFactory alt sınıfları, buildVideoRenderers() veya buildAudioRenderers() yöntemlerini geçersiz kılarak codec bağdaştırıcı fabrikasına erişebilir ve oluşturdukları MediaCodecRenderer örneklerine iletebilir.
    • ICY üstbilgi alanları name ve genre'yi sırasıyla MediaMetadata.station ve MediaMetadata.genre'ye yayınlayın. Böylece bu alanlar Player.Listener.onMediaMetadataChanged() üzerinden uygulamaya ulaşır (#9677).
    • DefaultHttpDataSource#getResponseHeaders öğesinden boş anahtarları kaldırın.
    • MediaCodec örneği oluşturulurken hata oluştuğunda uyku moduna geçip tekrar deneme Bu, bazı cihazlarda bir yüzey güvenli bir codec'ten başka bir codec'e geçirilirken oluşan bir sorunu (#8696) çözmek için kullanılır.
    • Kullanıcıların MediaCodec'den metrik verileri almasına izin vermek için MediaCodecAdapter.getMetrics() ekleyin. (#9766).
    • Maven bağımlılığı çözümleme sorununu düzeltme (#8353).
    • Düşük gecikme süresi özellikleri içermeyen veya kullanıcı isteğiyle hız ayarı yapılmayan canlı yayınlarda otomatik hız ayarlamayı devre dışı bırakın (#9329).
    • DecoderCounters#inputBufferCount öğesini queuedInputBufferCount olarak yeniden adlandırın.
    • SimpleExoPlayer.renderers gizli hale getirin. Oluşturuculara şu yollarla erişilebilir: ExoPlayer.getRenderer.
    • AnalyticsListener.EventFlags sabit değerlerinden bazıları, Player.EventFlags değerleriyle eşleşecek şekilde güncellendi.
    • AnalyticsCollector, bir arayüz ve varsayılan uygulama olarak bölünerek bir uygulamanın ihtiyacı yoksa R8 tarafından kaldırılmasına izin verilir.
  • Parça seçimi:
    • Parça seçiminde tercih edilen video rolü işaretleri desteklenir (#9402).
    • Uyarlama için birden fazla video parçası seçerken tercih edilen MIME türlerini ve rol işaretlerini dikkate almak üzere video parçası seçme mantığını güncelleyin (#9519).
    • Video ve ses parçası seçim mantığını, yalnızca aynı düzeyde kod çözücü ve donanım desteğine sahip uyarlanabilir seçimler için biçimleri seçecek şekilde güncelleyin (#9565).
    • Birincil, donanım hızlandırmalı kod çözücüler tarafından birden fazla codec destekleniyorsa video parçası seçme mantığını daha verimli codec'leri tercih edecek şekilde güncelleyin (#4835).
    • Teknik parça seçim kısıtlamaları (ör. tercih edilen MIME türü veya maksimum kanal sayısı) yerine ses içeriği tercihlerine (ör. "varsayılan" ses parçası veya sistem yerel ayar diline uygun bir parça) öncelik verin.
    • Bir parça grubunu geçersiz kılmanın aynı türdeki diğer parça gruplarını devre dışı bırakmamasına neden olan parça seçimi sorunu düzeltildi (#9675).
    • Boş olmayan ve boş parça geçersiz kılmalarının karışımının doğru şekilde uygulanmadığı parça seçimi sorunu düzeltildi (#9649).
    • TrackGroupArray içinde yinelenen TrackGroup öğelerini yasaklayın. TrackGroups can always be made distinguishable by setting an id in the TrackGroup constructor. Bu düzeltme, etkin bir parça geçersiz kılma işlemiyle uygulama arka plana alındıktan sonra oynatmaya devam edildiğinde yaşanan kilitlenme sorununu giderir (#9718).
    • Oynatma, canlı yayının sonuna çok yakın olsa bile yeterli ağ bant genişliği olduğunda kalite artışına izin vermek için AdaptiveTrackSelection içindeki mantığı değiştirin (#9784).
  • Video:
    • Gerekirse uyumlu bir H264/H265 kod çözücüyü kullanmak için Dolby Vision'ın kod çözücü yedekleme mantığını düzeltin.
  • Ses:
    • Gerekirse uyumlu bir E-AC3 kod çözücü kullanmak için Dolby Atmos (E-AC3-JOC) kod çözücü yedek mantığını düzeltin.
    • AudioCapabilities API'lerini, null yerine AudioCapabilities.DEFAULT_AUDIO_CAPABILITIES'nin açıkça iletilmesini gerektirecek şekilde değiştirin.
    • AudioTrack arabellek boyutu hesaplamasının özelleştirilmesine izin verin. Bunu yapmak için DefaultAudioSink'ye AudioTrackBufferSizeProvider ekleyin. (#8891).
    • İstenen arabellek boyutu 1 MB'tan büyükse AudioTrack oluşturmayı yeniden deneyin. (#9712).
  • Ayıklayıcılar:
    • WAV: RF64 akışları için destek eklendi (#9543).
    • H.265 SPS NAL birimlerinin yanlış ayrıştırılması düzeltildi (#9719).
    • Ogg Opus ve Ogg Vorbis dosyalarındaki Vorbis yorumlarını (METADATA_BLOCK_PICTURE dahil) ayrıştırın.
  • Metin:
    • Yapılandırmadan oluşturulan altyazı parçasının MediaItem.SubtitleConfiguration.id alanına yayılan bir Format.id alanı ekleyin (#9673).
    • Matroska kapsayıcılarında WebVTT altyazıları için temel destek eklendi (#9886).
    • Cea708Decoder öğesinin, bir hizmet bloğunun belirtilen boyutundan daha fazlasını okumasını engelleme.
  • DRM:
    • playbackLooper, DrmSessionManager.(pre)acquireSession hesabından kaldırılsın mı? Bir DrmSessionManager, özel bir MediaSource içindeki bir uygulama tarafından kullanıldığında playbackLooper yerine DrmSessionManager.setPlayer'ye iletilmesi gerekir.
  • Reklam oynatma / IMA:
    • IMA Dinamik Reklam Ekleme (DAI) desteği eklendi (#8213).
    • AdPlaybackState için bir yöntem ekleyin. Böylece, reklam grubu sıfırlanarak tekrar oynatılabilir (#9615).
    • Reklam oynatılırken 1,0 oynatma hızını zorunlu kılma (#9018).
    • Yüklenemeyen bir reklam grubunun anında oynatma sıfırlamasına neden olması sorunu düzeltildi (#9929).
  • UI:
    • Belirli temalar kullanılırken StyledPlayerView geri sarma ve ileri sarma düğmelerindeki sayıların rengini düzeltme (#9765).
    • Oynatma hızı dizelerini doğru şekilde çevirin (#9811).
  • DASH:
    • Ayrıştırılan temel ve ek özellikleri Representation öğesine ekleyin (#9579).
    • forced-subtitle parça rolünü destekleyin (#9727).
    • main parça rolünü C.SELECTION_FLAG_DEFAULT olarak yorumlamayı durdurun.
    • DVB ad alanını bildirmeyen manifestler için temel URL hariç tutma mantığını düzeltin (#9856).
    • Göreceli MPD.Location URL'leri desteklenir (#9939).
  • HLS:
    • Yalnızca ses içeren HLS yayınları için Format.label öğesini doğru şekilde doldurun (#9608).
    • Başlatma süresini iyileştirmek için varsayılan olarak parçasız hazırlamayı kullanın. Oluşturduğunuz sürümlerde, ana oynatma listesinde bildirilmeyen çoklu dosyalı altyazı parçaları varsa bunların oynatılabilmesi için ana oynatma listesine eklenmesi veya HlsMediaSource.Factory.setAllowChunklessPreparation(false) ile parçasız hazırlamanın devre dışı bırakılması gerekir.
    • HLS'de anahtar kareye göre doğru arama desteği eklendi ( (#2882).
  • RTSP:
    • Herhangi bir sunucu bağlantısı için kullanılan SocketFactory'yı geçersiz kılmak üzere bir istemci API'si sağlayın (#9606).
    • Her ikisi de mevcutsa BASIC yerine DIGEST kimlik doğrulama yöntemini tercih edin (#9800).
    • RTSP parçası zamanlaması kullanılamadığında işleme (#9775).
    • Geçersiz RTP-Info üstbilgi değerlerini yoksayma (#9619).
  • Dönüştürücü:
    • Gerekli minimum API sürümünü 21'e yükseltin.
    • TransformationException artık dönüştürme sırasında oluşan hataları açıklamak için kullanılıyor.
    • Dönüşüm seçeneklerini belirtmek için TransformationRequest ekleyin.
    • Birden fazla dinleyicinin kaydolmasına izin verin.
    • Codec çıkışı kısmen okunduğunda Transformer'ın takılması sorunu düzeltildi.
    • Muxer yayınlanırken Transformer.getProgress içinde olası NPE'yi düzeltir.
    • Dönüşümleri uygulamak için bir demo uygulaması ekleyin.
  • MediaSession uzantısı:
    • MediaSessionConnector, durdurulduğunda oynatma listesini varsayılan olarak temizler. Oynatma listesinin korunmasını isteyen uygulamalar, bağlayıcıda setClearMediaItemsOnStop(false) işlevini çağırabilir.
  • Yayın uzantısı:
    • CastPlayer öğesinin onIsPlayingChanged işlevini doğru şekilde çağırmasını engelleyen hata düzeltildi (#9792).
    • Albüm kapakları da dahil olmak üzere ses meta verileri desteği eklendi DefaultMediaItemConverter (#9663).
  • FFmpeg uzantısı:
    • build_ffmpeg.sh'nın GNU yerine LLVM'nin bin utils'ine bağlı olmasını sağlayın (#9933).
  • Android 12 uyumluluğu:
    • Yayın uzantısını com.google.android.gms:play-services-cast-framework:20.1.0 sürümüne yükseltin. play-services-cast-framework'nın önceki sürümleri, Android 12'yi hedefleyen uygulamalarla uyumlu değildir ve PendingIntent oluşturulurken IllegalArgumentException ile kilitlenir (#9528).
  • Desteği sonlandırılan sembolleri kaldırın:
    • Player.EventListener öğesini kaldırın. Bunun yerine Player.Listener politikasını kullanın.
    • MediaSourceFactory#setDrmSessionManager, MediaSourceFactory#setDrmHttpDataSourceFactory ve MediaSourceFactory#setDrmUserAgent öğelerini kaldırın. Bunun yerine MediaSourceFactory#setDrmSessionManagerProvider kullanın.
    • MediaSourceFactory#setStreamKeys öğesini kaldırın. Bunun yerine MediaItem.Builder#setStreamKeys kullanın.
    • MediaSourceFactory#createMediaSource(Uri) öğesini kaldırın. Bunun yerine MediaSourceFactory#createMediaSource(MediaItem) kullanın.
    • setTag, DashMediaSource, HlsMediaSource ve SsMediaSource cihazlarından kaldırılsın mı? Bunun yerine MediaItem.Builder#setTag politikasını kullanın.
    • DashMediaSource#setLivePresentationDelayMs(long, boolean) öğesini kaldırın. Manifesti geçersiz kılmak için MediaItem.Builder#setLiveConfiguration ve MediaItem.LiveConfiguration.Builder#setTargetOffsetMs, yedek değer sağlamak için DashMediaSource#setFallbackTargetLiveOffsetMs öğesini kullanın.
    • (Simple)ExoPlayer.setThrowsWhenUsingWrongThread öğesini kaldırın. İleti dizisi zorunluluğunu devre dışı bırakmak artık mümkün değildir.
    • ActionFile ve ActionFileUpgradeUtil araçlarını kaldırın. Eski işlem dosyalarını ActionFileUpgradeUtil ile birleştirmek için ExoPlayer 2.16.1 veya önceki bir sürümü kullanın.DefaultDownloadIndex
    • ProgressiveMediaSource#setExtractorsFactory öğesini kaldırın. Bunun yerine ProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory) oluşturucusunu kullanın.
    • ProgressiveMediaSource.Factory#setTag ve ProgressiveMediaSource.Factory#setCustomCacheKey araçlarını kaldırın. Bunun yerine MediaItem.Builder#setTag ve MediaItem.Builder#setCustomCacheKey politikalarını kullanın.
    • DefaultRenderersFactory(Context, @ExtensionRendererMode int) ve DefaultRenderersFactory(Context, @ExtensionRendererMode int, long) yapılandırıcılarını kaldırın. Bunun yerine DefaultRenderersFactory(Context) oluşturucusunu, DefaultRenderersFactory#setExtensionRendererMode ve DefaultRenderersFactory#setAllowedVideoJoiningTimeMs kullanın.
    • Tüm herkese açık CronetDataSource oluşturucuları kaldırın. Bunun yerine CronetDataSource.Factory kullanın.
  • Yalnızca aşağıdaki IntDefs değerini @Target(TYPE_USE) olarak değiştirin. Bu durum, Kotlin'deki kullanımların derlenmesini bozabilir. Bu sorun, türü açıklama eklemek için açıklama ekleme işlevini taşıyarak (Int) düzeltilebilir.
    • @AacAudioObjectType
    • @Ac3Util.SyncFrameInfo.StreamType
    • @AdLoadException.Type
    • @AdtsExtractor.Flags
    • @AmrExtractor.Flags
    • @AspectRatioFrameLayout.ResizeMode
    • @AudioFocusManager.PlayerCommand
    • @AudioSink.SinkFormatSupport
    • @BinarySearchSeeker.TimestampSearchResult.Type
    • @BufferReplacementMode
    • @C.BufferFlags
    • @C.ColorRange
    • @C.ColorSpace
    • @C.ColorTransfer
    • @C.CryptoMode
    • @C.Encoding
    • @C.PcmEncoding
    • @C.Projection
    • @C.SelectionReason
    • @C.StereoMode
    • @C.VideoOutputMode
    • @CacheDataSource.Flags
    • @CaptionStyleCompat.EdgeType
    • @DataSpec.Flags
    • @DataSpec.HttpMethods
    • @DecoderDiscardReasons
    • @DecoderReuseResult
    • @DefaultAudioSink.OutputMode
    • @DefaultDrmSessionManager.Mode
    • @DefaultTrackSelector.SelectionEligibility
    • @DefaultTsPayloadReaderFactory.Flags
    • @EGLSurfaceTexture.SecureMode
    • @EbmlProcessor.ElementType
    • @ExoMediaDrm.KeyRequest.RequestType
    • @ExtensionRendererMode
    • @Extractor.ReadResult
    • @FileTypes.Type
    • @FlacExtractor.Flags (com.google.android.exoplayer2.ext.flac paketinde)
    • @FlacExtractor.Flags (com.google.android.exoplayer2.extractor.flac paketinde)
    • @FragmentedMp4Extractor.Flags
    • @HlsMediaPlaylist.PlaylistType
    • @HttpDataSourceException.Type
    • @IllegalClippingException.Reason
    • @IllegalMergeException.Reason
    • @LoadErrorHandlingPolicy.FallbackType
    • @MatroskaExtractor.Flags
    • @Mp3Extractor.Flags
    • @Mp4Extractor.Flags
    • @NotificationUtil.Importance
    • @PlaybackException.FieldNumber
    • @PlayerNotificationManager.Priority
    • @PlayerNotificationManager.Visibility
    • @PlayerView.ShowBuffering
    • @Renderer.State
    • @RendererCapabilities.AdaptiveSupport
    • @RendererCapabilities.Capabilities
    • @RendererCapabilities.DecoderSupport
    • @RendererCapabilities.FormatSupport
    • @RendererCapabilities.HardwareAccelerationSupport
    • @RendererCapabilities.TunnelingSupport
    • @SampleStream.ReadDataResult
    • @SampleStream.ReadFlags
    • @StyledPlayerView.ShowBuffering
    • @SubtitleView.ViewType
    • @TextAnnotation.Position
    • @TextEmphasisSpan.MarkFill
    • @TextEmphasisSpan.MarkShape
    • @Track.Transformation
    • @TrackOutput.SampleDataPart
    • @Transformer.ProgressState
    • @TsExtractor.Mode
    • @TsPayloadReader.Flags
    • @WebvttCssStyle.FontSizeUnit

Sürüm 1.0.0-alpha01

27 Ekim 2021

androidx.media3:media3-*:1.0.0-alpha01 iptal edilir. 1.0.0-alpha01 sürümü şu commit'leri içerir.

Yeni özellikler

Media3, ExoPlayer da dahil olmak üzere medya destek kitaplıklarının yeni adresidir. İlk alfa sürümünde, aşağıdakiler de dahil olmak üzere medya kullanım alanlarını uygulamaya yönelik kitaplıkların erken ve işlevsel uygulamaları yer alıyor:

  • ExoPlayer, Android için uygulama düzeyinde bir medya oynatıcıdır. Özelleştirilmesi ve genişletilmesi kolaydır.
  • Oynatmaları göstermek ve kontrol etmek için medya oturumu işlevselliği. Bu yeni oturum modülü, ExoPlayer ile aynı Player arayüzünü kullanır.
  • Medya oynatma kullanıcı arayüzleri oluşturmaya yönelik kullanıcı arayüzü bileşenleri.
  • ExoPlayer ile kullanılmak üzere diğer kitaplıklardaki işlevleri sarmalayan modüller (ör. IMA SDK aracılığıyla reklam ekleme).

Daha fazla bilgi için Media3 GitHub projesine bakın.

ExoPlayer daha önce ayrı bir ExoPlayer GitHub projesinde barındırılıyordu. Media3'teki paket adı androidx.media3.exoplayer'dır. Uygulamalara Media3'e geçiş yapmaları için zaman tanımak amacıyla ExoPlayer GitHub projesini bir süre daha desteklemeye ve yayınlamaya devam etmeyi planlıyoruz. Media3, yeni media3-session modülüyle değiştirilen eski media2 ve mediasession uzantıları hariç olmak üzere tüm ExoPlayer modüllerinin yerine kullanılabilir. Bu, bir bağdaştırıcı/bağlayıcı sınıfı kullanmaya gerek kalmadan oynatıcılar ve medya oturumları arasında doğrudan entegrasyon sağlar.