Image Tracking allows to detect a picture or photo in order to put virtual content over it.
The picture can be a magazine cover, poster, flyer, business card or whatever is plane and has enough identity or texture to be differentiable.
When creating a new Image scene inside Studio, you will be asked to upload the reference or marker image you want to detect and track, along with its real world size (when printed).
Not every image is suitable for its use in AR, check How to choose a good marker image for more information.
You can use this site to check the quality of any marker image: marker quality portal
In order to differentiate one reference image from another or from any random frame taken by your device's camera, Onirix creates an Image Classifier every time you upload a marker image.
This classifier inspects your image looking for identificable features like corners, edges, high contrast zones, and so on. The following figure shows an example of detected features (green dots on right image).
After this process, the classifier outputs a quality score (percentage) based on the number of different features found and image resolution. You can check this score on the scene properties panel.
The more score you get, the better your reference will be detected and tracked over time. The following table illustrates how well your marker image will perform based on its quality score:
|< 25%||It may not be able to be detected and tracking will fail very easily|
|> 25% & < 50%||It may be able to be detected but tracking will fail easily|
|> 50%||Your marker image is almost perfect, tracking will only fail under severe lighting conditions, fast movements or on low-end devices|
So, you should ensure to get at least a 50% quality score for your marker images. Here it is a list with some tips and recommendations to design or choose a good marker image:
- Real world pictures are usually better than computer designed ones as objects are more complex, not perfect or symmetric and thus have more identificable features.
- Avoid images with large textureless regions. Flat images or minimalistic logos won't work well as they don't have enough features to track.
- Avoid repetitive features. A grid or similar pattern will add new features to the image but being all with the same shape will make image detector not able to differentiate one feature to another.
- Different colors won't generate different features. Features are detected based on contrast changes so adding more colors won't make any effect.
- Avoid printing or placing marker images under high reflective materials. Lighting reflections add artificial features to the image tracking process and may affect its performance.
Want to check the quality of any marker image right away? just visit our marker quality portal and drop any image
Trick: If you use a printed image as a marker. It's usually better to use a real camera picture of printed image as the marker because printing process usually modify colors and intensities of designed image.
In Onirix you can create several scenes within a project, and therefore, each of these scenes can have a different image marker (for example if you want to include AR in several pages of a magazine).
You can use any number of images within a project, however, using more than 15 images will have some implications in the weight of the resources the WebAR player will need to download.
When there are less than 15 images, the player will just compare the camera feed with every of these images to see if there is a match and then, load the corresponding scene. With more than 15 images, comparing one-by-one would be very slow so the WebAR player will download an additional 25MB file to add a preprocessing step to speed up detection.
If your project uses more than 15 images, you may consider splitting it into several projects, as the additional file download will increase loading times and data consumption.
Image-Tracking experiences created from Onirix Studio require to upload image markers for each corresponding scene. However, some projects would require to use a dynamic (unknown in advance) image marker.