Os apps de IoT permitem que os usuários realizem ações relevantes em dispositivos conectados de dentro do carro. Entre outras coisas, é possível controlar o estado de determinados dispositivos, como a abertura de um portão de garagem, o acionamento de interruptores de luz ou a ativação da segurança residencial.
Declarar suporte à categoria no manifesto
Seu app precisa declarar a categoria de app para carros
androidx.car.app.category.IOT
no filtro de intent de
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>
Implementar a funcionalidade do app
Para implementar o app, consulte Como usar a biblioteca Android for Cars App sobre como os apps da biblioteca são criados. Além disso, leia as Diretrizes de qualidade de apps de carros para apps da IoT, já que o app será analisado de acordo com essas diretrizes.
Para apps da IoT, o GridTemplate
é uma ótima opção para mostrar uma lista de dispositivos e permitir que o usuário
interaja com eles, conforme mostrado no exemplo a seguir:
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();