Image Tracking
Introductionβ
NRSDK's Image Tracking capability helps you build AR apps that can respond to and follow images in the natural environment. These can include books, signs, posters, or logos.
A set of images can be uploaded to the database as pre-trained references. These images can then be tracked by NRSDK in the physical world while the transformation of the images are updated during the session.
Capabilitiesβ
- NRSDK can detect and track images that are fixed in place, such as a painting on a wall or a book on the table. It can also track moving images, such as a rotating billboard or a poster held by someone walking around.
- Upon initiating tracking with NRSDK, the system delivers continuous estimations for the position and orientation of the tracked image. It is advisable to configure the size in Unity to match the printed tracked image. The transformation estimates for the image are continually updated, leading to enhanced tracking accuracy, particularly for static images, as NRSDK accumulates data from various angles over time.
- NRSDK can remember up to 8 images in the environment. However, these images cannot be tracked simultaneously in the current version. Therefore, only one image can be tracked in each frame. Additionally, NRSDK will not track multiple instances of the same image.
Requirementsβ
Image Selection Checklistβ
- Reference images should be in JPEG format, grayscale or RGB color, and have a dpi value of 150. The dimensions of printed reference images should be less than 1m^2.
- To enable better tracking, it is important to use images with well-distributed feature points and low degrees of self-similarity. NRSDK can evaluate the tracking quality of the reference images when you add them to the database. Images with low tracking quality cannot be added to the database.
- For those who design original reference images, we suggest to export the image using Adobe Illustrator rather than Adobe Photoshop. This is because Photoshop has looser export standards and NRSDK can sometimes fail to read information on pixel density.
Image Tracking Condition Requirement
- Images printed with dull surfaces perform better than glossy ones due to reduced light reflections.
- The quickest way to initialize image tracking is to view the image at a slight angle while keeping the image flat and undistorted.
- The NRImageTracking Tool gives a score between 0 and 100 for each uploaded reference image. We recommend using images with a score of 65 and above. Using an image with a score lower than 40 will result in poor tracking quality.
Examples of good images and bad images:
Developer Guideβ
Learn how to use the Image Tracking feature in your own apps.
Build and Run the Sample Appβ
Create a new project in Unity.
Need help setting up? Try Getting Started with NRSDK first
Before you build the app, make sure you include the tracking image scene located in
Assets > NRSDK > Demos > ImageTracking
Make sure your phone is connected to your PC before clicking Build and Run. Unity builds your project into an Android APK, which will be installed onto your phone. The app can then be launched once you plug XREAL Light glasses into the phone.
As you move your XREAL Light glasses, the app automatically detects and tracks images from the set of reference images.
Create the Database Fileβ
Select one or more pictures you want to use with the mouse, then right-click and select the Create > NRSDK > TrackingImageDatabase
menu to create the database file.
A new image database is created in the same folder as the reference images.
The images in the database will be shown in the Inspector window along with image quality scores. We recommend using images with scores higher than 65 to guarantee good tracking performance.
The dimensions of the physical image (in meters) for each uploaded reference image should be the same as the dimension shows above.
You can click 'x' to delete items.
Note: The size of the images you use must correspond to the size in the database
Set the Database Fileβ
-
Find the session config file in your scene and open it.
-
In the Inspector window, click the box next to Tracking Image Database and select the database file you created.
Get Tracked Imageβ
To display different virtual objects based on the tracked images, you can modify the TrackingImageExampleController.cs
script and TrackingImageVisualizer.cs
script. Here's an example of how you can achieve this:
namespace NRKernal.NRExamples
{
using System.Collections.Generic;
using UnityEngine;
public class TrackingImageExampleController : MonoBehaviour
{
public TrackingImageVisualizer TrackingImageVisualizerPrefab;
public GameObject FitToScanOverlay;
private Dictionary<int, TrackingImageVisualizer> m_Visualizers
= new Dictionary<int, TrackingImageVisualizer>();
private List<NRTrackableImage> m_TempTrackingImages = new List<NRTrackableImage>();
public void Update()
{
#if !UNITY_EDITOR
if (NRFrame.SessionStatus != SessionState.Running)
{
return;
}
#endif
NRFrame.GetTrackables<NRTrackableImage>(m_TempTrackingImages, NRTrackableQueryFilter.New);
foreach (var image in m_TempTrackingImages)
{
TrackingImageVisualizer visualizer = null;
m_Visualizers.TryGetValue(image.GetDataBaseIndex(), out visualizer);
if (image.GetTrackingState() != TrackingState.Stopped && visualizer == null)
{
visualizer = Instantiate(TrackingImageVisualizerPrefab, image.GetCenterPose().position, image.GetCenterPose().rotation);
visualizer.Image = image;
visualizer.transform.parent = transform;
m_Visualizers.Add(image.GetDataBaseIndex(), visualizer);
}
else if (image.GetTrackingState() == TrackingState.Stopped && visualizer != null)
{
m_Visualizers.Remove(image.GetDataBaseIndex());
Destroy(visualizer.gameObject);
}
FitToScanOverlay.SetActive(false);
}
}
public void EnableImageTracking()
{
var config = NRSessionManager.Instance.NRSessionBehaviour.SessionConfig;
config.ImageTrackingMode = TrackableImageFindingMode.ENABLE;
NRSessionManager.Instance.SetConfiguration(config);
}
public void DisableImageTracking()
{
var config = NRSessionManager.Instance.NRSessionBehaviour.SessionConfig;
config.ImageTrackingMode = TrackableImageFindingMode.DISABLE;
NRSessionManager.Instance.SetConfiguration(config);
}
}
}
namespace NRKernal.NRExamples
{
using UnityEngine;
public class TrackingImageVisualizer : MonoBehaviour
{
public NRTrackableImage Image;
// Configure virtual objects for different images
public GameObject VirtualObjectForImageA;
public GameObject VirtualObjectForImageB;
private GameObject instantiatedObject;
public void Update()
{
if (Image == null || Image.GetTrackingState() != TrackingState.Tracking)
{
if (instantiatedObject != null)
{
instantiatedObject.SetActive(false);
}
return;
}
if (instantiatedObject == null)
{
// Select the virtual object to instantiate based on the image
if (Image.GetDataBaseIndex() == 0) // Assuming index 0 is for ImageA
{
instantiatedObject = Instantiate(VirtualObjectForImageA, transform);
}
else if (Image.GetDataBaseIndex() == 1) // Assuming index 1 is for ImageB
{
instantiatedObject = Instantiate(VirtualObjectForImageB, transform);
}
}
if (instantiatedObject != null)
{
instantiatedObject.transform.position = Image.GetCenterPose().position;
instantiatedObject.transform.rotation = Image.GetCenterPose().rotation;
instantiatedObject.SetActive(true);
}
}
}
}