Aplikacje IoT pozwalają użytkownikom wykonywać odpowiednie działania na połączonych urządzeniach z w samochodzie. Może to być na przykład sterowanie stanem określonych urządzeń, otwieranie bramy garażowej, przewracanie przełączników oświetlenia czy włączenie ochrony domu.
Zadeklaruj obsługę kategorii w pliku manifestu
Aplikacja musi zadeklarować androidx.car.app.category.IOT
kategoria aplikacji samochodu w zamiarze
filtra CarAppService
.
<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>
Wdróż funkcje aplikacji
Aby wdrożyć aplikację, zapoznaj się z Korzystanie z biblioteki aplikacji Android do samochodu Aplikacje biblioteczne są tworzone. Zapoznaj się też z Wskazówki dotyczące jakości aplikacji samochodowych w przypadku IoT , ponieważ Twoja aplikacja zostanie sprawdzona pod kątem zgodności z tymi wytycznymi.
W przypadku aplikacji IoT GridTemplate
to świetny wybór do wyświetlania listy urządzeń
wchodzić z nimi w interakcję, tak jak w tym przykładzie:
Kotlin
val listBuilder = ItemList.Builder() listBuilder.addItem( GridItem.Builder() .setTitle("Garage door") .setImage(...) // Handle user interactions .setOnClickListener {...} .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() .setTitle("Devices") .setHeaderAction(Action.APP_ICON) .setSingleList(listBuilder.build()) .build()
Java
ItemList.Builder listBuilder = new ItemList.Builder(); listBuilder.addItem( new GridItem.Builder() .setTitle("Garage door") .setImage(...) // Handle user interactions .setOnClickListener(() -> {...}) .build() ); listBuilder.addItem( new 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 new GridTemplate.Builder() .setTitle("Devices") .setHeaderAction(Action.APP_ICON) .setSingleList(listBuilder.build()) .build();