Medya bileşenlerini özelleştir

Tedarikçi uzantılarını kullanarak medya çıkarıcı ve medya codec bileşenlerini genişletebilirsiniz. MediaSession2 ve MediaParser API'leri özelleştirilemez (ancak eski MediaPlayer ve MediaSession API'leri için değişiklikleri yayına alabilirsiniz).

Android medya çerçevesinde ek medya türlerini desteklemek için özel bir ayıklayıcı ve kod çözücü oluşturmanız gerekir. Örneğin, AVI dosyalarında Windows Media videosu desteği eklemek için bir AVI Ayıklayıcı ve bir Windows Media video Kod Çözücü dosyası oluşturmanız gerekir.

Uzantılar hakkında

Varsayılan medya ayıklayıcılar gereksinimlerinizi karşılamıyorsa /system/lib[64]/extractors/ bölümüne özel ayıklayıcı eklentileri yerleştirebilirsiniz. Ayıklayıcı işlemi, Google tarafından sağlanan APEX paketinden ve /system/lib[64]/extractors/'ten ayıklayıcı eklentilerini otomatik olarak yükler.

Benzer şekilde, frameworks/av/media/codec2/core/ içinde tanımlanan Codec 2.0 arayüzünü kullanan özel medya codec hizmetleri de ayarlayabilirsiniz. Temel uygulama için frameworks/av/media/codec2/hidl/services/ başlıklı makaleyi inceleyin. Kitaplık giriş noktası C2ComponentStore arayüzüdür. Örneğin, frameworks/av/media/codec2/vndk/C2Store.cpp adresindeki varsayılan yazılım codec mağazası uygulamasına bakın.

Kendi APEX'inizi kullanırken codec hizmetini yapılandırın ve mediaswcodec hizmetiyle aynı işlemleri kullanarak APEX dosyasını yükleyin. Bunu yapmak için tüm C2 bileşenlerini kaydetmekten sorumlu üst düzey bir paylaşılan kitaplık tanımlayın, ardından tedarikçi bölümünde yer alan bir APEX paketi (geçişli bağımlılıklarla) oluşturun. Tedarikçi codec hizmeti işlemi başladığında bu üst düzey giriş noktasını yükleyebilir.

Ayıklayıcı oluşturma

Yeni bir biçim için ayıklayıcı eklerken ayıklayıcının yalnızca kararlı NDK API'lerine bağlı olduğundan ve herhangi bir gizli API'ye bağlı olmadığından emin olun. Ayıklayıcılar, frameworks/av/include/media/MediaExtractorPluginApi.h tarafından tanımlanan API'yi uygulamalı ve frameworks/av/include/media/MediaExtractorPluginHelper.h'teki C++ kolaylık sarmalayıcılarını kullanabilir. Android 10 veya sonraki sürümler yalnızca ayıklayıcı API'nin en yüksek sürümünü desteklediğinden, ayıklayıcınızı en yüksek API sürüm numaralı ayıklayıcıya göre modellediğinizden emin olun.

Özel ayıklayıcıları /system/lib/64/extractors bölümüne veya Google ayıklayıcılarını içeren Google APEX ile birlikte açılan bir tedarikçi APEX'e yerleştirin. Çerçevenin ayrıştırıcınızı yüklediğini doğrulamak için aşağıdaki komutu çalıştırın.

adb shell dumpsys media.extractor

Aşağıdakine benzer kullanılabilir ayıklayıcıların bir listesini alırsınız.

Available extractors:
AAC Extractor: plugin\_version(2), uuid(4fd80eae03d24d729eb948fa6bb54613), version(1), path(/system/lib64/extractors/libaacextractor.so)
AMR Extractor: plugin\_version(2), uuid(c86639c92f3140aca715fa01b4493aaf), version(1), path(/system/lib64/extractors/libamrextractor.so)
FLAC Extractor: plugin\_version(2), uuid(1364b048cc454fda9934327d0ebf9829), version(1), path(/system/lib64/extractors/libflacextractor.so)
MIDI Extractor: plugin\_version(2), uuid(ef6cca0af8a243e6ba5fdfcd7c9a7ef2), version(1), path(/system/lib64/extractors/libmidiextractor.so)
MP3 Extractor: plugin\_version(2), uuid(812a3f6cc8cf46deb5293774b14103d4), version(1), path(/system/lib64/extractors/libmp3extractor.so)
MP4 Extractor: plugin\_version(2), uuid(27575c6744174c548d3d8e626985a164), version(2), path(/system/lib64/extractors/libmp4extractor.so)
MPEG2-PS/TS Extractor: plugin\_version(1), uuid(3d1dcfebe40a436da574c2438a555e5f), version(1), path(/system/lib64/extractors/libmpeg2extractor.so)
Matroska Extractor: plugin\_version(2), uuid(abbedd9238c44904a4c1b3f45f899980), version(1), path(/system/lib64/extractors/libmkvextractor.so)
Ogg Extractor: plugin\_version(2), uuid(8cc5cd06f772495e8a62cba9649374e9), version(1), path(/system/lib64/extractors/liboggextractor.so)
WAV Extractor: plugin\_version(3), uuid(7d61385858374a3884c5332d1cddee27), version(1), path(/system/lib64/extractors/libwavextractor.so)

Özel ayıklayıcınız Google tarafından sağlanan bir ayıklayıcı tarafından zaten desteklenen bir biçimi destekliyorsa Sniff() işlevini kullanarak Google'ın sağladığından daha yüksek bir güven düzeyi döndürerek çerçeveyi ayıklayıcınızı kullanmaya zorlayabilirsiniz.

Medya çerçevesi, ayıklayıcınızı (/system/lib/64/extractors veya bir tedarikçi APEX'ten) yüklediğinde dosyayı tanır ve içeriği hakkında bilgi alır. Sonraki adım, çerçevenin dosya içeriğini nasıl ayrıştıracağını anlayabilmesi için biçim için bir kod çözücü eklemektir.

Özel kod çözücü oluşturma

Google tarafından sağlanan bir kod çözücü tarafından desteklenmeyen tüm biçimler için özel bir kod çözücüye ihtiyacınız vardır. Örnek:

  • MP3 içeren AVI dosyaları için medya çerçevesi desteği eklemek istiyorsanız bir AVI çıkarıcıya ihtiyacınız vardır ancak MP3 kod çözücüye ihtiyacınız yoktur çünkü zaten mevcuttur.

  • Windows Media içeren AVI dosyaları için medya çerçevesi desteği eklemek istiyorsanız hem AVI çıkarıcıya hem de Windows Media kod çözücüsüne ihtiyacınız vardır.

Yeni bir kod çözücü eklemek, AVC veya HEVC için kendi donanım kod çözücülerinizi eklemeye benzer.

Ayıklayıcı, içerdiği medya kanallarının MIME türünü yayınlarken dosyanın tam olarak desteklenmesi için bu MIME türlerini destekleyen codec'lerin mevcut olması gerekir. Kullanılan gerçek MIME türü dizesi, kesinlikle çıkarıcı ile codec arasında bir anlaşmadır (diyenin MediaDefs.h dosyasına eklenmesi gerekmez).

Medya tarayıcısı ile entegrasyon

Medya tarayıcısı yeni dosya türleri arar ve bunları medya veritabanına ekler. Medya tarayıcısının özel dosya türünüzü işleyebilmesi için tarayıcının bu dosya türünü bilmesi gerekir. Android 10 veya sonraki sürümlerde MimeUtils (libcore sürümünde), MIME-uzantı eşlemesini korur. Daha önce bu eşleme, MIME türünden MTP biçim sabitlerine bir eşleme içermeye devam eden MediaFile.java dosyasında işleniyordu.

Bir ayıklayıcı, destekledikleri dosya adı uzantılarının (MP3 veya MP4 gibi) bir listesini dışa aktarabilir. Ancak bu yalnızca LegacyMediaScanner tarafından kullanılır; varsayılan olarak kullanılan ModernMediaScanner üzerinde etkisi yoktur.