HarmonyOS 除了限制系统能力来保证驾驶员安全,同时提供了驾驶模式相关接口,允许开发者使用第三方能力库来开发驾驶模式下可用的安全应用,本章节主要简述如何开发驾驶模式下安全应用。
HarmonyOS 提供了驾驶模式管理类 DrivingSafetyManager,开发者可以使用该类的开放能力,开发符合驾驶模式安全要求的应用。
接口名 | 描述 |
---|---|
getRestraint() | 获取当前系统在“驾驶模式”状态下的约束条件。 |
isDrivingMode() | 查询当前车辆是否处于“驾驶模式”状态。 |
isDrivingSafety() | 判断当前的应用是否是安全的。 |
开发一个应用具备如下能力:
HarmonyOS 车载应用需要开发者指定当前应用是否支持“驾驶模式”状态。对于不支持驾驶模式状态的应用,在汽车进入“驾驶模式”状态后,不允许启动,对于已经启动的应用也会冻结操作并退出。因此,开发者需要在应用配置文件(config.json)中"supported-modes"配置项中增加"drive"模式,以表示该应用支持“驾驶模式”状态,保证车辆在行驶过程中,应用可以正常运行。如下所示:
"abilities": {
"name": ".carlink",
"icon": "$carlink:icon",
"label": "carlink",
"supported-modes": ["drive"],
}
if (isDrivingSafety(context)) { // 判断应用当前状态是否是驾驶安全的
int restraintCode = DrivingSafetyManager.getRestraint(); // 获取当前系统限制条件
if (restraintCode < 0) {
HiLog.error("GetRestraint error: %d", restraintCode);
return;
}
if (restraintCode == 0) { // 当前系统不受限
HiLog.error("No restraint");
return;
}
// 限制视频播放
if (0x2 & restraintCode != 0) {
Player play = new Player(content); // 第三方视频播放器
play.stop();
}
// 限制输入法弹窗
if (0x4 & restraintCode != 0) {
InputMethodController mIMController = InputMethodController.getInstance(); // 第三方输入法
mIMController.stopInput(InputMethodController.STOP_IM_NORMAL);
}
// 其他限制
...
}
场景介绍应用可以通过分布式文件服务实现多个设备间的文件共享,设备 1 上的应用A创建了分布式文件 a,设备 2 上的应用A能够通过...
AccessibilityStateEventjava.lang.Object |---ohos.accessibility.AccessibilityStateEventpublic class AccessibilityStateEve...
Component.CanAcceptScrollListenerpublic static interface Component.CanAcceptScrollListener提供要调用的侦听器来决定是否可...
Component.UnconsumedKeyEventListenerpublic static interface Component.UnconsumedKeyEventListener如果键盘事件没有被使用,...
ComponentSaveStatejava.lang.Object |---ohos.agp.components.AbsComponentSaveState |---|---ohos.agp.components.ComponentSa...