Personnaliser les composants multimédias

Vous pouvez étendre les composants de l'extracteur multimédia et du codec multimédia à l'aide d'extensions du fournisseur. Les API MediaSession2 et MediaParser ne peuvent pas être personnalisées (mais vous pouvez mettre en amont des modifications pour les anciennes API MediaPlayer et MediaSession).

Pour prendre en charge des types de médias supplémentaires dans le framework multimédia Android, vous devez créer un extracteur et un décodeur personnalisés. Par exemple, pour prendre en charge les vidéos Windows Media dans les fichiers AVI, vous devez créer un extracteur AVI et un décodeur vidéo Windows Media.

À propos des extensions

Si les extracteurs multimédias par défaut ne répondent pas à vos exigences, vous pouvez placer des plug-ins d'extraction personnalisés dans /system/lib[64]/extractors/. Processus d'extraction charge automatiquement les plug-ins extracteurs à partir du package APEX fourni par Google et de /system/lib[64]/extractors/.

De même, vous pouvez configurer des services de codec multimédia personnalisés qui utilisent le codec Codec 2.0 définie dans frameworks/av/media/codec2/core/. Pour une implémentation, consultez frameworks/av/media/codec2/hidl/services/. Le point d'entrée de la bibliothèque est l'interface C2ComponentStore. Pour obtenir un exemple, consultez l'implémentation du dépôt de codecs logiciels par défaut sur frameworks/av/media/codec2/vndk/C2Store.cpp.

Lorsque vous utilisez votre propre APEX, structurez le service de codec et chargez le fichier APEX à l'aide des mêmes processus que le service mediaswcodec. Pour ce faire, définissez bibliothèque partagée de premier niveau responsable de l'enregistrement de tous les composants C2, puis créer un package APEX (avec des dépendances transitives) qui se trouve dans le fournisseur partition. Lorsque le processus de service du codec du fournisseur démarre, il peut charger ce point d'entrée de niveau supérieur.

Créer un extracteur

Lorsque vous ajoutez un extracteur pour un nouveau format, assurez-vous que celui-ci dépend uniquement de des API NDK stables et ne dépend d'aucune API privée. Les extracteurs doivent implémenter l'API définie par frameworks/av/include/media/MediaExtractorPluginApi.h et peuvent utiliser le langage C++ des wrappers de commodité dans frameworks/av/include/media/MediaExtractorPluginHelper.h Étant donné qu'Android 10 ou version ultérieure n'est compatible qu'avec la version la plus récente de l'API d'extraction, veillez à modéliser votre extracteur après celui qui possède le numéro de version d'API le plus élevé.

Placez des extracteurs personnalisés dans /system/lib/64/extractors ou dans un apex de fournisseur, qui s'ouvre avec l'apex Google contenant les extracteurs Google. À vérifiez que le framework a chargé votre extracteur, exécutez la commande suivante.

adb shell dumpsys media.extractor

Vous devriez obtenir une liste d'extracteurs disponibles semblable à celle-ci.

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)

Si votre extracteur personnalisé prend en charge un format déjà pris en charge par un fourni par Google, vous pouvez forcer le framework à utiliser votre extracteur en Utiliser la fonction Sniff() pour renvoyer un niveau de confiance supérieur à celui fourni par Google.

Lorsque Media Framework charge votre extracteur (à partir de /system/lib/64/extractors ou d'un fournisseur APEX), il reconnaît le fichier et obtient des informations sur son contenus. L'étape suivante consiste à ajouter un décodeur pour le format afin que le framework puisse comprendre comment analyser le contenu du fichier.

Créer un décodeur personnalisé

Vous avez besoin d'un décodeur personnalisé pour tout format qui n'est pas déjà compatible avec un décodeur fourni par Google. Exemple :

  • Pour ajouter la prise en charge du framework multimédia pour les fichiers AVI contenant du MP3, vous avez besoin d'un extracteur AVI, mais pas d'un décodeur MP3, car il en existe déjà un.

  • Pour ajouter la compatibilité avec Media Framework pour les fichiers AVI contenant Windows Media, vous devez besoin à la fois d’un extracteur AVI et d’un décodeur Windows Media.

Ajouter un nouveau décodeur est semblable à ajouter vos propres décodeurs matériels pour AVC ou HEVC.

Bien que l'extracteur publie le type MIME des pistes multimédias qu'il contient, les codecs compatibles avec ces types MIME doivent être présents pour que le fichier soit entièrement compatible. La chaîne de type MIME réelle utilisée est strictement accord entre l'extracteur et le codec (la chaîne n'a pas besoin d'être ajouté au fichier MediaDefs.h).

Intégrer à Media Scanner

L'explorateur multimédia recherche de nouveaux types de fichiers et les ajoute à la base de données multimédia. Pour que le scanner puisse gérer votre type de fichier personnalisé, il doit le savoir. Sur Android 10 ou version ultérieure, MimeUtils (dans libcore) gère le mappage de la MIME à l'extension. Auparavant, ce mappage était géré dans le fichier MediaFile.java, qui continue de contenir un mappage à partir de Type MIME vers constantes de format MTP.

Un extracteur peut exporter une liste des extensions de nom de fichier qu'il accepte (par exemple, MP3 ou MP4). Toutefois, seul LegacyMediaScanner l'utilise. Cela n'a aucun effet sur ModernMediaScanner, qui est utilisé par défaut.