La API de Geospatial usa una combinación de datos de VPS y GPS para generar transformaciones geoespaciales de alta precisión. La API se puede usar en cualquier lugar en el que el dispositivo pueda determinar su ubicación:
- En áreas con baja precisión del GPS, como espacios interiores y entornos urbanos densos, la API se basará en la cobertura de VPS para generar transformaciones de alta precisión.
- En entornos al aire libre con pocas obstrucciones en el techo o sin ellas, es posible que la API de Geospatial pueda usar los datos de ubicación GPS disponibles para generar transformaciones geoespaciales con alta precisión.
Puedes determinar la disponibilidad de la VPS en una posición horizontal determinada antes de que comience la sesión de RA y usarla para crear experiencias más específicas; por ejemplo, para presentar un botón "Entrar a RA" solo cuando la VPS esté disponible.
Habilita la API de ARCore
Tu app debe habilitar la API de ARCore para verificar la disponibilidad de la VPS.
Cómo verificar la disponibilidad del VPS en tu app
La API de Geospatial se puede usar en cualquier lugar en el que el dispositivo pueda determinar su ubicación. Si tu experiencia de RA depende de la cobertura de VPS, puedes usar GARSession#checkVPSAvailabilityAtCoordinate:completionHandler:
para obtener un GARVPSAvailabilityFuture
, una tarea asíncrona que verifica la disponibilidad de VPS en una posición horizontal determinada.
Una vez que tengas el GARVPSAvailabilityFuture
, puedes obtener su resultado mediante sondeos o una devolución de llamada.
Cómo sondear el resultado
Usa GARFuture.state
para obtener el estado de Future
. Existen tres estados diferentes:
GARFutureStatePending
: La operación aún no se completa, por lo que no se conoce ningún resultado.GARFutureStateCancelled
:GARFuture#cancel
canceló la operación. Nunca se llamará a ninguna devolución de llamada registrada.GARFutureStateDone
: La operación se completó. UsaGARVPSAvailabilityFuture.result
para obtener el resultado.
Puedes seguir verificando GARFuture.state
hasta que se complete la tarea.
Obtén el resultado a través de una devolución de llamada
También puedes obtener el resultado de un Future
a través de una devolución de llamada. Usa GARSession#checkVPSAvailabilityAtCoordinate:completionHandler:
y proporciona un completionHandler
. Se llamará a esta completionHandler
en el subproceso principal poco después de que Future
tenga el estado GARFutureStateDone
.
Cancela el Future
.
Usa GARFuture#cancel
para intentar cancelar el Future
. Debido al paralelismo de subprocesos, es posible que tu intento de cancelación no se realice correctamente.
GARFuture#cancel
muestra YES
si este intento se realizó correctamente y NO
en caso contrario.
Usa la API de Geospatial sin cobertura de VPS
La API de Geospatial también se puede usar en áreas que no tienen cobertura de VPS. En entornos exteriores con pocas obstrucciones en el techo o sin ellas, es posible que el GPS sea suficiente para generar una pose con alta precisión.
¿Qué sigue?
- Obtén la posición geoespacial de la cámara del dispositivo para determinar la ubicación exacta del dispositivo del usuario en el mundo real.