Mit IoT-Apps können Nutzer relevante Aktionen auf verbundenen Geräten aus dem Auto heraus ausführen. Beispiele hierfür sind das Steuern des Status bestimmter Geräte, z. B. das Öffnen eines Garagentors, das Betätigen von Lichtschaltern zu Hause oder das Aktivieren der Haussicherheit.
Kategorieunterstützung im Manifest deklarieren
Ihre App muss die androidx.car.app.category.IOT
Kategorie für Auto-Apps im Intent
Filter ihres CarAppService deklarieren.
<application>
...
<service
...
android:name=".MyCarAppService"
android:exported="true">
<intent-filter>
<action android:name="androidx.car.app.CarAppService" />
<category android:name="androidx.car.app.category.IOT"/>
</intent-filter>
</service>
...
<application>
App-Funktionen implementieren
Informationen zur Implementierung Ihrer App finden Sie unter Android for Cars-App-Bibliothek verwenden. Machen Sie sich außerdem mit den Qualitätsrichtlinien für Auto-Apps für IoT-Apps vertraut, da Ihre App anhand dieser Richtlinien überprüft wird.
Für IoT-Apps ist GridTemplate
eine gute Wahl, um eine Liste von Geräten anzuzeigen und dem Nutzer die
Interaktion mit ihnen zu ermöglichen, wie im folgenden Beispiel gezeigt:
val listBuilder = ItemList.Builder() val headerBuilder = Header.Builder() val garageIcon = IconCompat.createWithResource( carContext, R.drawable.ic_garage ) listBuilder.addItem( GridItem.Builder() .setTitle("Garage door") .setImage( CarIcon.Builder(garageIcon).build(), GridItem.IMAGE_TYPE_ICON ) .setOnClickListener { // Handle user interactions } .build() ) listBuilder.addItem( GridItem.Builder() .setTitle("Garage lights") // Show a loading indicator until the status of the device is known // (call invalidate() when the status is known to refresh the screen) .setLoading(true) .build() ) return GridTemplate.Builder() .setHeader( headerBuilder.setTitle("Devices") .setStartHeaderAction(Action.APP_ICON).build() ) .setSingleList(listBuilder.build()) .build()