Par défaut, la plupart des services pour voitures sont obligatoires et toujours activés. Toutefois, vous pouvez désigner un sous-ensemble de services de voiture comme facultatif, car certaines fonctionnalités peuvent ne pas être compatibles avec toutes les voitures.
Liste des fonctionnalités facultatives
Les fonctionnalités de contrôle de la voiture facultatives que vous pouvez activer et désactiver sont listées dans le tableau ci-dessous.
Fonctionnalité de contrôle de la voiture | Valeur de chaîne |
---|---|
Service EVS de voiture | car_evs_service |
Service expérimental de verrouillage des touches pour voiture | experimental_car_keyguard_service |
Service de navigation pour voiture | car_navigation_service |
Service de connexion des occupants de la voiture | car_occupant_connection_service |
Service d'accès à distance pour les voitures | car_remote_access_service |
Service d'appareil à distance pour voiture | car_remote_device_service |
Service de télémétrie de la voiture | car_telemetry_service |
Service d'avis pour les utilisateurs de voitures | com.android.car.user.CarUserNoticeService |
Service de page d'accueil du cluster | cluster_home_service |
Service de diagnostic | diagnostic |
Service de perception de l'occupant | occupant_awareness |
Service de surveillance du stockage | storage_monitoring |
Service de cartographie pour véhicule | vehicle_map_service |
Activer et désactiver les fonctionnalités de contrôle de la voiture
Vous pouvez contrôler la prise en charge des fonctionnalités dans vos builds de deux manières : avec des superpositions de ressources d'exécution (RRO) ou via la couche d'abstraction matérielle du véhicule (VHAL).
Utiliser des RRO
Utilisez la configuration de ressource nommée config_allowed_optional_car_features
, qui répertorie toutes les fonctionnalités facultatives que vous pouvez activer. Lorsque vous démarrez une voiture pour la première fois, les fonctionnalités facultatives possibles sont notées et activées si elles ne figurent pas sur la liste de blocage du VHAL.
Pour en savoir plus sur les RRO, consultez la section Modifier la valeur des ressources d'une application au moment de l'exécution.
Utiliser le VHAL
La couche d'abstraction matérielle du véhicule (VHAL) contrôle les fonctionnalités en servant de liste de blocage pour désactiver des fonctionnalités facultatives spécifiques. La propriété VHAL nommée DISABLED_OPTIONAL_FEATURES
liste les fonctionnalités facultatives de la superposition à désactiver. Si cette propriété n'existe pas, la liste des fonctionnalités facultatives des RRO est entièrement activée. Pour en savoir plus sur le VHAL, consultez la présentation du VHAL.
Utiliser des commandes shell de débogage
Une troisième méthode consiste à utiliser une paire de commandes shell, qui ne sont disponibles que dans les builds user-debug
et sont destinées aux développeurs. Le tableau de la section Liste des fonctionnalités facultatives contient les valeurs à utiliser à la place de <FEATURE_STRING_VALUE>
.
Pour activer une fonctionnalité:
adb root; adb shell cmd car_service enable-feature <FEATURE_STRING_VALUE>; adb reboot
Pour désactiver une fonctionnalité:
adb root; adb shell cmd car_service disable-feature <FEATURE_STRING_VALUE>; adb reboot
Déterminer quelles fonctionnalités sont activées
Lorsque vous déboguez des problèmes liés à des fonctionnalités spécifiques, il peut être utile de savoir quelles fonctionnalités sont activées et pourquoi. Pour vider les informations feature-related
, exécutez la commande suivante:
adb shell dumpsys car_service --services CarFeatureController
Cette commande liste les types d'informations ci-dessous.
Valeur | Description |
---|---|
mEnabledFeatures |
Fonctionnalités actuellement activées. |
mDefaultEnabledFeaturesFromConfig |
Fonctionnalités facultatives listées dans config_allowed_optional_car_features . |
mDisabledFeaturesFromVhal |
Fonctionnalités spécifiées par le VHAL à désactiver dans la propriété VHAL, DISABLED_OPTIONAL_FEATURES . |
mPendingEnabledFeatures |
Fonctionnalités à activer lors d'un redémarrage. |
mPendingDisabledFeatures |
Fonctionnalités à désactiver après un redémarrage. |