自 2026 年起,为了与我们的主干稳定开发模型保持一致,并确保生态系统的平台稳定性,我们将在第 2 季度和第 4 季度将源代码发布到 AOSP。对于构建 AOSP 和向 AOSP 贡献代码,我们建议使用 android-latest-release 而不是 aosp-main。android-latest-release 清单分支将始终引用推送到 AOSP 的最新版本。如需了解详情,请参阅 AOSP 变更。
将 VHAL 与 Native Client 搭配使用
使用集合让一切井井有条
根据您的偏好保存内容并对其进行分类。
VHAL 支持 Java 客户端和 Native Client。汽车服务是唯一适用于 VHAL 的 Java 客户端。对于典型的汽车应用,请使用 Car API(例如 CarPropertyManager)访问 VHAL 属性,而不是直接与 VHAL 通信。实际上,SELinux 会阻止此类访问。如需了解详情,请参阅软件包索引中的 Car API 文档。
对于 Native Client,从 Android 13 开始,请使用 libvhalclient,而不是直接连接 VHAL。这是一个客户端库,为 AIDL 和 HIDL VHAL 实现提供了一个通用接口 IVhalClient.h。下面的示例展示了如何创建 VHAL Native Client 并使用它来获取车辆识别码 (VIN) 号码:
using ::aidl::android::hardware::automotive::vehicle::VehicleProperty;
using ::android::frameworks::automotive::vhal::IVhalClient;
using ::android::hardware::automotive::vehicle::toInt;
auto vhalClient = IVhalClient::tryCreate();
if (vhalClient == nullptr) {
// handle error.
}
auto result = vhalClient->getValueSync(
*vhalClient->createHalPropValue(toInt(VehicleProperty::INFO_VIN)));
// Use result
本页面上的内容和代码示例受内容许可部分所述许可的限制。Java 和 OpenJDK 是 Oracle 和/或其关联公司的注册商标。
最后更新时间 (UTC):2025-03-26。
[[["易于理解","easyToUnderstand","thumb-up"],["解决了我的问题","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["没有我需要的信息","missingTheInformationINeed","thumb-down"],["太复杂/步骤太多","tooComplicatedTooManySteps","thumb-down"],["内容需要更新","outOfDate","thumb-down"],["翻译问题","translationIssue","thumb-down"],["示例/代码问题","samplesCodeIssue","thumb-down"],["其他","otherDown","thumb-down"]],["最后更新时间 (UTC):2025-03-26。"],[],[]]