Em dispositivos dobráveis no estilo livro, é possível ativar o suporte aos modos de tenda e cunha.
Os modos de tenda e cunha permitem usar a tela externa quando o dispositivo está ligeiramente aberto, conforme mostrado na figura a seguir:

Figura 1. Posições dobráveis de tenda e cunha.
No modo de tenda, o dispositivo fica parcialmente aberto, usando as duas metades para se sustentar como uma tenda. No modo de cunha, o dispositivo é apoiado na metade direita, que fica plana em uma superfície.
O Android 16 e versões mais recentes oferecem suporte a esse comportamento usando
BookStyleDeviceStatePolicy como política de estado do dispositivo. Essa política funciona em um dispositivo dobrável com duas telas no estilo livro, com a dobradiça localizada no lado esquerdo do dispositivo quando dobrado.
Essa política mantém a tela externa ativada por mais tempo ao desdobrar em determinadas condições, por exemplo:
- A metade direita do dispositivo é quase plana, indicando que o dispositivo provavelmente está no modo de cunha.
- A orientação do dispositivo é paisagem invertida, indicando que ele provavelmente está no modo de tenda.
- A orientação da tela é paisagem ou paisagem invertida.
- Há um app que mantém um wakelock de tela (impedindo o tempo limite da tela).
A política não introduz um estado de dispositivo separado para a postura de tenda ou cunha. Ela mantém o estado fechado para uma variedade maior de ângulos de dobradiça nessas condições específicas.
Para oferecer suporte total a essas heurísticas, o dispositivo precisa de:
- Sensor de ângulo de dobradiça que informa o ângulo entre as duas metades do dispositivo
- Sensor de acelerômetro em cada metade (esquerda e direita) do dispositivo
Configurar o modo de tenda ou cunha
Siga estas etapas para ativar o suporte aos modos de tenda e cunha no dispositivo:
Crie uma implementação de
DeviceStatePolicy.Providerque retorne uma instância deBookStyleDeviceStatePolicy. A instância precisa fornecer todas as dependências necessárias, como objetos de sensor, ao construtorBookStyleDeviceStatePolicy.O exemplo a seguir mostra uma implementação:
package com.example; public class MyDevicePolicyProvider implements DeviceStatePolicy.Provider { @Override public DeviceStatePolicy instantiate(@NonNull Context context) { final SensorManager sensorManager = context.getSystemService(SensorManager.class); final Sensor hingeAngleSensor = sensorManager.getDefaultSensor(Sensor.TYPE_HINGE_ANGLE, /* wakeUp= */ true); final List<Sensor> sensors = sensorManager.getSensorList(Sensor.TYPE_ALL); final Sensor hallSensor = CollectionUtils.find(sensors, (sensor) -> Objects.equals(sensor.getStringType(), "com.example.hall_effect")); final Sensor rightAccelerometerSensor = CollectionUtils.find(sensors, (sensor) -> Objects.equals(sensor.getName(), "Accelerometer 0")); final Sensor leftAccelerometerSensor = CollectionUtils.find(sensors, (sensor) -> Objects.equals(sensor.getName(), "Accelerometer 1")); // You can pass a non-null value here to disable tent/wedge mode logic, // so the displays switch will always happen at the fixed hinge angle. // This might be useful, for example, when in a retail demo mode where // the hinge angle range of the device is limited. final Integer closeAngleDegrees = null; return new BookStyleDeviceStatePolicy(new FeatureFlagsImpl(), context, hingeAngleSensor, hallSensor, leftAccelerometerSensor, rightAccelerometerSensor, closeAngleDegrees); } }Adicione o provedor de políticas ao caminho de classe do servidor do sistema. Comece criando uma biblioteca com a classe do provedor de políticas de estado do dispositivo que você criou na etapa anterior.
O exemplo a seguir mostra uma configuração de blueprint
Android.bpdo Soong:java_library { name: "my-device-services", installable: true, system_ext_specific: true, srcs: [ "src/**/*.java" ], libs: [ "services", ], }Em seguida, para adicionar essa biblioteca ao servidor do sistema, modifique o arquivo makefile do dispositivo adicionando as seguintes linhas:
# Add system service libraries (they contain device-specific policies) PRODUCT_SYSTEM_SERVER_JARS += \ my-device-services PRODUCT_PACKAGES += \ my-device-servicesAtualize
config_deviceSpecificDeviceStatePolicyProviderpara o nome da classe do provedor no arquivoconfig.xml, por exemplo:<string translatable="false" name="config_deviceSpecificDeviceStatePolicyProvider">com.example.MyDevicePolicyProvider</string>