Skip to main content

How to Download a Mesh Using the API

With the Mesh Downloading API, you can download and create a mesh of any Public Location at runtime. Its optional parameters provide ways to customize how it works, some of which are explored in this How-To.

Prerequisites

You will need a Unity project with ARDK installed and an AR scene with Location AR. For more information, see Installing ARDK 3 and How to Place Content in Real-World Locations Using Location AR. Your project must have an ARLocation for this How-To.

Getting Ready in Unity

Before using the Mesh Downloading API, you will need to add a Location Mesh Manager Component and an associated script that will download the mesh.

To create the Location Mesh Manager and mesh downloading script:

  1. Add GameObjects to hold the manager and script:

    1. In the Hierarchy, right-click in your AR scene, then select Create Empty and name the new GameObject LocationMeshManager. Repeat these steps, but name the second object MeshDownloadHowTo.
  2. Select LocationMeshManager, then, in the Inspector, click Add Component and add a Location Mesh Manager.

    Adding a Location Mesh Manager
  3. Select MeshDownloadHowTo, then, in the Inspector, click Add Component and add a New Script. Name it MeshDownloadHowTo.

    Adding the Mesh Download How To script

Downloading a Mesh Using an AR Location Payload

With the Location Mesh Manager ready, you can use the API to download a mesh and set its position at runtime. In this example, you will do this using an ARLocation payload to place the mesh on top of the real world in that location. This will generate a GameObject with the mesh populated that you can use or modify like any other. For example, you might have the mesh download and appear when the user pushes a button or pass it to some other function for collision detection.

To get started, open MeshDownloadHowTo.cs, then replace the code with the following code:

Click to reveal the Mesh Download function
using System.Threading.Tasks;

using Niantic.Lightship.AR.LocationAR;
using Niantic.Lightship.AR.PersistentAnchors;
using Niantic.Lightship.AR.Subsystems;

using UnityEngine;

public class MeshDownloadHowTo : MonoBehaviour
{
[SerializeField]
private LocationMeshManager _meshManager;

[SerializeField]
private ARLocationManager _arLocationManager;

private GameObject _downloadedMesh;
private bool _startedDownload;

private void Start()
{
_arLocationManager.locationTrackingStateChanged += OnLocationTrackingStateChanged;
}

private void OnLocationTrackingStateChanged(ARLocationTrackedEventArgs args)
{
if (args.Tracking && !_startedDownload)
{
_startedDownload = true;
_ = DownloadAndPositionMeshAsync(location: args.ARLocation);
}
}

private async Task DownloadAndPositionMeshAsync(ARLocation location)
{
var payload = location.Payload;

// wait async for the mesh to download so it doesn't block the main thread
var go = await _meshManager.GetLocationMeshForPayloadAsync(payload.ToBase64());

// set the mesh as a child of the ARLocation's position and place it in the scene
go.transform.SetParent(location.transform, false);
_downloadedMesh = go;
}

private void OnDestroy()
{
if (_downloadedMesh)
{
Destroy(_downloadedMesh);
}
}
}

Adjusting the Mesh at Runtime

Once your mesh is downloaded, you can adjust it using the API options. In this example, you will use the API to get a textured mesh and lighten its transparency. By placing it using an ARLocation payload, you can create a transparent mesh overlay of any existing Public Location at runtime.

Before updating the script, create a Material that supports transparency and add it to LocationMeshManager:

  1. In the Project window, right-click in the Assets directory, then open the Create menu and select Material. Name the new material trans_light.

  2. Select trans_light, then, in the Inspector, set the Rendering Mode to Transparent.

    Making the light transparent material
  3. In the Hierarchy, select LocationMeshManager, then add trans_light to the Standard Material field.

    Adding the light transparent material

Open MeshDownloadHowTo.cs, then update the DownloadAndPositionMeshAsync function with the following code:

Click to reveal the updated Mesh Download function
private async Task DownloadAndPositionMeshAsync(ARLocation location)
{
var payload = location.Payload;
// Use a textured option for the mesh download
var go = await _meshManager.GetLocationMeshForPayloadAsync(payload.ToBase64(), meshFormat: MeshDownloadRequestResponse.MeshAlgorithm.TEXTURED);
go.transform.SetParent(location.transform, false);

// Get the mesh renderers and set the transparency of the material to 0.5
foreach (var meshRenderer in go.GetComponentsInChildren<MeshRenderer>())
{
var mat = meshRenderer.material;
if (mat != null)
{
var color = mat.color;
color.a = 0.5f;
meshRenderer.material.color = color;
}
}
_downloadedMesh = go;
}

More Information

  • For general information, see the Mesh Download feature page.
  • For details and more optional parameters, see the Mesh Download API Reference.
  • To see Mesh Downloading in action, try out the VPS Coverage API sample.