Koordinatsystem i Unity
Windows Mixed Reality har stöd för appar i en mängd olika upplevelseskalor, från appar med endast orientering och sittande skalning upp via appar i rumsskala. På HoloLens kan du gå vidare och skapa appar i världsskala som låter användare gå längre än 5 meter och utforska en hel våning i en byggnad och bortom.
Ditt första steg i att skapa en mixad verklighetsupplevelse i Unity är att förstå koordinatsystem och välja vilken upplevelse som appen ska rikta in sig på.
Skapa en orienteringsbaserad eller sittande skalningsupplevelse
Namnområde: UnityEngine.XR
Typ: XRDevice
För att skapa en orienteringsbaserad eller sittande skalningsupplevelse måste du ange Unity till den stationära spårningsutrymmestypen. Stationära spårningsutrymmen ställer in Unitys världskoordinatsystem för att spåra referensramen. I läget Stationär spårning visas innehåll som placeras i redigeraren precis framför kamerans standardplats (vidarebefordran är -Z) framför användaren när appen startas.
XRDevice.SetTrackingSpaceType(TrackingSpaceType.Stationary);
Namnområde: UnityEngine.XR
Typ: InputTracking
För en ren orienteringsupplevelse som en 360-graders videovisare (där positionshuvuduppdateringar skulle förstöra illusionen) kan du sedan ange XR. InputTracking.disablePositionalTracking till true:
InputTracking.disablePositionalTracking = true;
För en platsskala kan du anropa XR om du vill att användaren senare ska kunna använda det sittande ursprunget . InputTracking.Recenter-metod :
InputTracking.Recenter();
Skapa en upplevelse i stående skala eller rumsskala
Namnområde: UnityEngine.XR
Typ: XRDevice
För en upplevelse i stående skala eller rumsskala måste du placera innehåll i förhållande till golvet. Du resonerar om användarens golv med hjälp av den rumsliga fasen, som representerar användarens definierade ursprung på golvnivå och valfri rumsgräns, som konfigurerades under den första körningen.
För att säkerställa att Unity fungerar med sitt världskoordinatsystem på golvnivå kan du ange och testa att Unity använder roomscale-spårningsutrymmetypen:
if (XRDevice.SetTrackingSpaceType(TrackingSpaceType.RoomScale))
{
// RoomScale mode was set successfully. App can now assume that y=0 in Unity world coordinate represents the floor.
}
else
{
// RoomScale mode was not set successfully. App cannot make assumptions about where the floor plane is.
}
- Om SetTrackingSpaceType returnerar true har Unity växlat sitt världskoordinatsystem för att spåra referensramen.
- Om SetTrackingSpaceType returnerar falskt gick det inte att växla till scenramen för referensen, sannolikt eftersom användaren inte har konfigurerat en våning i sin miljö. Även om ett falskt returvärde inte är vanligt kan det inträffa om fasen har konfigurerats i ett annat rum och enheten flyttas till det aktuella rummet utan att användaren konfigurerar en ny fas.
När appen har ställt in roomscale-spårningsutrymmestypen visas innehåll som placeras på y=0-planet på golvet. Ursprunget vid 0, 0, 0 kommer att vara den specifika platsen på golvet där användaren stod under rumskonfigurationen, med -Z som representerar den framåtriktade riktning som de var riktade mot under installationen.
Namnområde: UnityEngine.Experimental.XR
Typ: Gräns
I skriptkod kan du anropa metoden TryGetGeometry på typen UnityEngine.Experimental.XR.Boundary för att hämta en gränspolygon och ange en gränstyp av TrackedArea. Om användaren har definierat en gräns (du får tillbaka en lista över hörn) är det säkert att leverera en upplevelse i rumsskala till användaren, där de kan gå runt i den scen du skapar.
Kommentar
Systemet renderar automatiskt gränsen när användaren närmar sig den. Din app behöver inte använda den här polygonen för att återge själva gränsen. Du kan dock välja att lägga ut scenobjekt med hjälp av den här gränspolygonen för att säkerställa att användaren fysiskt kan nå dessa objekt utan att teleportera:
var vertices = new List<Vector3>();
if (UnityEngine.Experimental.XR.Boundary.TryGetGeometry(vertices, Boundary.Type.TrackedArea))
{
// Lay out your app's content within the boundary polygon, to ensure that users can reach it without teleporting.
}
Skapa en upplevelse i världsskala
Namnområde: UnityEngine.XR.WSA
Typ: WorldAnchor
För verkliga upplevelser i världsskala på HoloLens som låter användare vandra längre än 5 meter behöver du nya tekniker utöver de som används för upplevelser i rumsskala. En viktig teknik som du använder är att skapa ett rumsligt fästpunkt för att låsa ett kluster av hologram exakt på plats i den fysiska världen, oavsett hur långt användaren har vandrat och sedan hitta dessa hologram igen i senare sessioner.
I Unity skapar du en spatial fästpunkt genom att lägga till Komponenten WorldAnchor Unity i ett GameObject.
Lägga till en Världsankare
Om du vill lägga till en världsankare anropar du AddComponent<WorldAnchor>() på spelobjektet med den transformering som du vill förankra i den verkliga världen.
WorldAnchor anchor = gameObject.AddComponent<WorldAnchor>();
Det var allt! Det här spelobjektet kommer nu att vara förankrat på dess nuvarande plats i den fysiska världen – du kan se dess Unity-världskoordinater justeras något över tid för att säkerställa den fysiska justeringen. Använd beständighet för att hitta den här förankrade platsen igen i en framtida appsession.
Ta bort en världsankare
Om du inte längre vill att GameObject ska vara låst till en fysisk plats och inte tänker flytta den här ramen kan du bara anropa Destroy on the World Anchor-komponenten.
Destroy(gameObject.GetComponent<WorldAnchor>());
Om du vill flytta GameObject den här ramen måste du anropa DestroyImmediate i stället.
DestroyImmediate(gameObject.GetComponent<WorldAnchor>());
Flytta en värld förankrad GameObject
GameObject's kan inte flyttas medan en World Anchor är på den. Om du behöver flytta den här ramen i GameObject måste du:
- DestroyImmediate World Anchor-komponenten
- Flytta GameObject
- Lägg till en ny World Anchor-komponent i GameObject.
DestroyImmediate(gameObject.GetComponent<WorldAnchor>());
gameObject.transform.position = new Vector3(0, 0, 2);
WorldAnchor anchor = gameObject.AddComponent<WorldAnchor>();
Hantera ändringar i locatability
En WorldAnchor kanske inte är locatable i den fysiska världen vid en tidpunkt. Om detta inträffar uppdaterar Unity inte transformering av det förankrade objektet. Detta kan också ändras när en app körs. Om det inte går att hantera ändringen i locatability visas objektet inte på rätt fysisk plats i världen.
Meddelas om ändringar i locatability:
- Prenumerera på händelsen OnTrackingChanged
- Hantera händelsen
Händelsen OnTrackingChanged anropas när den underliggande rumsliga fästpunkten ändras mellan tillståndet att vara locatable jämfört med att den inte är locatable.The OnTrackingChanged event will be called whenever the underlying spatial anchor changes between a state of being locatable vs. not being locatable.
anchor.OnTrackingChanged += Anchor_OnTrackingChanged;
Hantera sedan händelsen:
private void Anchor_OnTrackingChanged(WorldAnchor self, bool located)
{
// This simply activates/deactivates this object and all children when tracking changes
self.gameObject.SetActiveRecursively(located);
}
Ibland finns fästpunkter omedelbart. I det här fallet anges den här isLocated-egenskapen för fästpunkten till true när AddComponent<WorldAnchor>() returnerar. Därför utlöses inte Händelsen OnTrackingChanged. Ett rent mönster skulle vara att anropa din OnTrackingChanged-hanterare med det inledande IsLocated-tillståndet efter att ha kopplat en fästpunkt.
Anchor_OnTrackingChanged(anchor, anchor.isLocated);
Nästa kontrollpunkt för utveckling
Om du följer unity-utvecklingskontrollens resa som vi har lagt fram är du mitt uppe i att utforska mixed reality-kärnbyggnadsblocken. Härifrån kan du fortsätta till nästa byggblock:
Eller hoppa till funktioner och API:er för Mixed Reality-plattformen:
Du kan alltid gå tillbaka till Unity-utvecklingspunkterna när som helst.