Spåra förlust i Unity
När enheten inte kan hitta sig själv i världen upplever appen "spårningsförlust". Som standard pausar Unity uppdateringsloopen och visar en välkomstbild för användaren när spårningen går förlorad. När spårningen har återfåtts försvinner välkomstbilden och uppdateringsloopen fortsätter.
Alternativt kan användaren hantera den här övergången manuellt genom att välja bort inställningen. Allt innehåll verkar bli kroppslåst under spårningsförlust om inget görs för att hantera det.
Standardhantering
Uppdateringsloopen och alla meddelanden och händelser stoppas under hela spårningsförlusten som standard. Samtidigt visas en bild för användaren. Du kan anpassa den här bilden genom att gå till Redigera inställningar-Spelare>>, klicka på Välkomstbild och ange holografisk spårningsförlustbild.
Manuell hantering
Om du vill hantera spårningsförlust manuellt måste du gå till Redigera>projektinställningar>Spelare> Universell Windows-plattform fliken>Splash Image>Windows Holographic och avmarkera "Pausa spårningsförlust och visa bild". Därefter måste du hantera spårningsändringar med de API:er som anges nedan.
Namnområde: UnityEngine.XR.WSA
Typ: WorldManager
- World Manager exponerar en händelse för att identifiera spårning som förlorats/vunnits (WorldManager.OnPositionalLocatorStateChanged) och en egenskap för att fråga det aktuella tillståndet (WorldManager.state)
- När spårningstillståndet inte är aktivt ser kameran inte ut att översättas i den virtuella världen även när användaren översätter. Objekt motsvarar inte längre någon fysisk plats och alla visas som låsta i brödtexten.
När du hanterar spårningsändringar på egen hand måste du antingen söka efter delstatsegenskapen varje bildruta eller hantera händelsen OnPositionalLocatorStateChanged .
avsökning
Det viktigaste tillståndet är PositionalLocatorState.Active, vilket innebär att spårningen fungerar fullt ut. Alla andra tillstånd resulterar endast i rotationsdelta till huvudkameran. Till exempel:
void Update()
{
switch (UnityEngine.XR.WSA.WorldManager.state)
{
case PositionalLocatorState.Active:
// handle active
break;
case PositionalLocatorState.Activating:
case PositionalLocatorState.Inhibited:
case PositionalLocatorState.OrientationOnly:
case PositionalLocatorState.Unavailable:
default:
// only rotational information is available
break;
}
}
Hantera händelsen OnPositionalLocatorStateChanged
Enklare är att prenumerera på OnPositionalLocatorStateChanged för att hantera övergångarna:
void Start()
{
UnityEngine.XR.WSA.WorldManager.OnPositionalLocatorStateChanged += WorldManager_OnPositionalLocatorStateChanged;
}
private void WorldManager_OnPositionalLocatorStateChanged(PositionalLocatorState oldState, PositionalLocatorState newState)
{
if (newState == PositionalLocatorState.Active)
{
// Handle becoming active
}
else
{
// Handle becoming rotational only
}
}