Skip to content

Extras

This section describes additional functions of the VIRNECT Track Framework.

Get Framework Log Messages

The Track framework provides three methods in the LOG namespace to retrieve log messages:

#import <VARAPI/TrackingFramework/Log.hpp>    

  • Latest log message
    To retrieve the latest log message as a string, simply call the following method:

    // Retrieve the latest log message
    const std::string lastLogMessage = VIRNECT::LOG::getLastLogMessage();
    
  • All log messages
    To retrieve a vector containing all log messages call:

    // Retrieve all log messages
    const std::vector<std::string> allLogMessages = VIRNECT::LOG::getAllLogMessages();
    
  • Register a callback function
    To automatically invoke a custom method on a logging event, you can register a callback function:

    // Register callback function for logging
    VIRNECT::LOG::registerLogCallbackFunction(logCallback);
    

    Example declaration for such a callback function:

    /**
    * @brief Callback function that will be invoked when Track logs a message
    * @param message Log message
    * @param level Log level
    */
    void logCallback(const std::string& message, VIRNECT::LOG::LogLevel level)
    {
        std::cout << message << std::endl;
    }
    


Get Target Meta Information

Meta information about targets, like their type or physical size, can be retrieved by calling the following method:

// Get target meta information
const std::unordered_map<std::string, VIRNECT::TargetInformation> targetInfo = self.mTrackingFramework->getTargetInformation();

Modify Trackable Targets at Runtime

By modifying the target meta information, you can activate and deactivate the tracking for each individual target during runtime. To do so, set the mIgnore property of the target information accordingly.

// Get target meta information

std::unordered_map<std::string, VIRNECT::TargetInformation> targetInfo = self.mTrackingFramework->getTargetInformation();

// Deactivate tracking for target "VARIMG_000"
targetInfo["VARIMG_000"].mIgnore = true;

// Set target meta information
self.mTrackingFramework->setTargetInformation(targetInfo);

Changing any other property of the target meta information will have no effect on the framework.


Camera Intrinsic Parameter

If your iOS device supports isCameraIntrinsicMatrixDeliverySupported, you can fetch intrinsic parameter from device.

- (void)captureOutput:(AVCaptureOutput *)output didOutputSampleBuffer:(CMSampleBufferRef)sampleBuffer fromConnection:(AVCaptureConnection *)connection{

if ([connection isCameraIntrinsicMatrixDeliveryEnabled]) {
    NSData* intrinsics = (__bridge NSData*)CMGetAttachment(sampleBuffer, kCMSampleBufferAttachmentKey_CameraIntrinsicMatrix, nil);

    matrix_float3x3* intrinsicsParameter = (matrix_float3x3 *)intrinsics.bytes;

    VIRNECT::CameraCalibration cameraCalibration;

    cameraCalibration.mResolution[0] = PROCESS_WIDTH;
    cameraCalibration.mResolution[1] = PROCESS_HEIGHT;

    cameraCalibration.mFocalLength[0] = intrinsicsParameter->columns[0][0];
    cameraCalibration.mFocalLength[1] = intrinsicsParameter->columns[1][1];
    cameraCalibration.mPrincipalPoint[0] = intrinsicsParameter->columns[2][0];
    cameraCalibration.mPrincipalPoint[1] = intrinsicsParameter->columns[2][1];
}
}

The Calibration Reader Tool enables a convenient reading of calibration data from a JSON file.

#import <VARAPI/TrackingFramework/Tools.hpp>

// Instantiate camera calibration object
VIRNECT::CameraCalibration cameraCalibration;

// Use the calibration reader tool to load camera calibration from JSON file
VIRNECT::TOOLS::readCalibrationFile(calibrationPath, cameraCalibration);

// Set camera calibration
self.mTrackingFramework->setCameraCalibration(cameraCalibration);

For more details about camera calibration and the JSON file format, please read the instructions of the Camera Calibration section.


Record Image Sequence

Track provides convenient methods to record the camera input stream as an image sequence:

#import <VARAPI/TrackingFramework/Tools.hpp>

#if TARGET_OS_IPHONE
NSString* documentPath = [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject].path;
#else
NSString* documentPath = @"ROOT PATH";
#endif

// Start recording
VIRNECT::TOOLS::RECORDER::startRecording(documentPath.UTF8String);

self.mTrackingFramework->process();

// Retrieve recording state
VIRNECT::TOOLS::RECORDER::isRecording();

// Stop recording
VIRNECT::TOOLS::RECORDER::stopRecording();

To use the recording functionality the framework needs to be set up and running. Once recording is enabled via the startRecording method, each call of the process Method will record one frame.

Supported file formats are JPG & PGM.

A recorded file sequences can be used as an Image Source for the Track framework.


Extended Tracking

The extended tracking feature can be used to enlarge your tracking space:

// Enable extended tracking
self.mTrackingFramework->enableExtendedTracker(true);

When using this the extended tracking, only one target may be defined. This target needs to be stationary in its environment.

Warning

This feature is currently in experimental stage. It only supports macOS, no mobile builds.

Back to top