documentation

Record and Replay Image Sequences
Level: Basic
input_sources2_tut_banner.jpg

In one of the prior tutorials we got into the different input types which you use for tracking.

In this tutorial we are going to record an image sequence of tracking a target for testing. Especially during the development, using pre-recorded image sequences can become extremely helpful. With VisionLib, you can pre-record sequences which enable you to test tracking configuration and application development at your desk without the need to have the targets physically present.

Note: It is a good practice to use the recorded image sequences for testing and adjusting tracking parameters using our tool VisLab. You can download it in the customer area

Note: We recommend using image sequences on your standalone PC or Mac, this feature is not designed for the use on mobile devices.

Preparations

We start with an empty new project in Unity3D. As a test target we use the mini car model from prior tutorials. You can download the car template here. You can create a sequence either with your built-in camera, an external camera attached to your computer, on with the camera of a mobile device. As the latter basically includes the process of the first two, we are going to use a mobile device, in this case the iPhone X. We also assume you have downloaded the latest vlUnitySDK.

The Image Recorder Example Scene

After importing the vlUnitPackage.unitypackage, switch to Assets in Unity's Project panel, go to the VisionLib/Examples/ImageRecorder/Scenes folder and open the SimpleImageRecorderExample. Run the scene inside Unity with a camera present. In Game mode you'll see two buttons on the left side, Start recording, Start recording Extendible and Stop.

Pressing the first will start the recording, pressing the latter will stop it. The records are stored on your hard disc inside a recordings folder, when running the scene on your desktop. Each take is stored in an record_<index> sub-folder with an increment at the end, once you press the Stop button.

An overview of the file locations and more details can be found in the reference at: Image Recorder and Configuration File Reference. (Windows it is User/username, on Mac /Users/username/Documents, iOS: Documents)

Stop the scene and take a quick look at the .vl file used for recording: In the Project panel, open the folder StreamingAssets/VisionLib/Examples/ImageRecorder and select the imageRecorder.vl file. Right-click on it, Reveal in Explorer (Win) or Finder (macOS) and view it with your preferred text editor. For this tutorial, we don't need to make any changes. The file should look like this:

{
"type": "VisionLibTrackerConfig",
"version": 1,
"meta": {
"name": "Simple Recording Example",
"description": "Simple configuration file allowing for recording image sequences",
"author": "VisionLib"
},
"tracker": {
"type": "imageRecorder",
"version": 1,
"parameters": {
"recordOnStartup": true,
"recordToNewDir": true,
"recordURIPrefix": "local_storage_dir:records/record/image_",
"recordImageType": "jpg"
}
}
}

If you don't intend to build and run the recorder on a mobile device, your are almost good to go. By running the scene inside Unity, you can record camera images and use them in your project later on. You can skip the next section and continue with the instructions to replay your sequences.

We recommend to use the same camera for recording, as later on in your project, since the camera lens intrinsics are then the same.

Build the Scene to Record on a Mobile Device

Unity Settings

As mentioned earlier, in this tutorial we are going to use an iPhoneX to record our image sequence. To do so, open Unity's Build Settings dialog and switch the build platform to iOS.

Next, open Project›Settings›Player. At Other Settings put a text in the Camera Usage Description, for instance "Augmented Reality, please allow". Once built and published to the iOS device, a dialog will prompt you to give this app access to the camera. Since we intend to use the camera, this parameter ensures our scene/Unity app won't be blocked from iOS' security settings.

input_sources2_tut_camera-usage.png

Next, build an Unity-iPhone app from your scene: open Build Settings again and press Build and Run. Unity will ask for a location and app name. Choose whatever you like, for instance imageRecorder.

Xcode Settings

Open the resulting project in Xcode, after Unity has finished compiling. We need to do one more adjustment, before we can build the app and deploy it on the smartphone. Switch to the Info tab with the Unity-iPhone project opened in Xcode. In the Custom iOS Target Properties, add the key UIFileSharingEnabled to the list and set its value to YES. This will basically enable file sharing for our app: by doing so, we can use iTunes to access and download the recorded image sequence from our phone by connecting it via cable.

input_sources2_tut_xcode2.png

If you haven't done it already, attach your phone to your computer and hit Build and Run in Xcode. Once the app is built and published, take your phone, open the app and record a sequence of your target: press Start Recording and Stop once you're done.

While Recording a Sequence on the Mobile Device

While recording, focus on parts of the target that are of interest to you during development. Make sure you start with a good pose or match your init pose in order to ease initialization when using the sequence as an input source. Hold the pose for a couple of seconds before you start moving around your target. In general, don't be too fast or shaky in your movements, e.g. don't flip or change your pose too suddenly, and try to avoid intensive motion blur when you move.

Important note: From VisionLib version 19.3.1, images on mobile devices are recorded in landscape orientation. If you flip your device to portrait orientation, the sequence will be saved in landscape orientation (turned).

ARKit's SLAM poses on iOS

If you plan creating an application using ARKit, you may have noticed that enabling ARKit usually happens by enabling the extendibleTracking parameter to true. This happens also in the image recorder by pressing the Start recording Ext button. Then, the external SLAM pose of ARKit is saved additionally and it can be used to replay the whole scenario, as if you would have an iOS device on the desktop. Please also check the image recorder reference or the input sources tutorial for more information.

Fetching the Image Sequences

Reconnect your mobile device to your desktop machine with a cable. Open iTunes, select your connected phone and then File Sharing listed under Settings from the left panel. At File Sharing select your recorder app, in our case named imageRecorder. Once selected, you will see the app's accessible folders listed. Select records, next press Save to... and store it locally.

Replay the Image Sequences

We're almost done. If you haven't saved it to this folder already, copy the preferred record into the Assets/StreamingAssets/VisionLib/Examples/ImageRecorder folder of your VisionLib Unity project. You can either use the entire sequence or only parts of it. VisionLib will follow the index but won't complain if it is not consecutive.

Make sure you have your .vl file prepared for image sequences as an input source. Take a look at the tutorial Handling Input Sources and the Configuration File Reference for further assistance.

In order to simulate your application on-site with your recording, please add the following in the .vl file you are using in your application:

//...
"tracker" {
// ... tracker definition
"simulateExternalSLAM":true
},
"input": {
"useImageSource": "imageSequenceFromiOSDevice",
"imageSources": [{
"name": "imageSequenceFromiOSDevice",
"type": "imageSequence",
"data": {
"uri": "project_dir:testsequence/*.jpg",
"simulateMobileRecording": true
}
}]
}
//...

In this example, the image source is named imageSequenceFromiOSDevice. You can use any custom name here. This way you can declare multiple image sources in your .vl file and specify which one to use by setting the parameter useImageSource to the name of the desired source.

Note When replaying the image sequence in Unity, make sure the tracking start in your scene is not using the camera selection.