Objective-C version by Jota Melo
Google Analytics tracker for Apple tvOS provides an easy integration of Google Analytics’ measurement protocol for Apple TV. This library enables sending screenviews, events, exceptions and any other hit type to Google Analytics. Implementation of the library and sending an initial hit to Google Analytics takes only a few minutes.
All code for this tracker is located in the "GATracker" class. The first step of the implementation is adding the .h and .m files to your project.
This library creates an object (a tracker) that holds persistent values such as client id, property id, and more. The tracker is created with the following command:
[[GATracker sharedInstance] setTrackingID:@"UA-1234567-89"];
This code should run in the AppDelegate method applicationDidFinishLaunchingWithOptions.
Once the tracker is set up you can start sending Google Analytics hits from your Apple TV application.
When sending the screenview hit type, the screenname parameter is a required field.
[[GATracker sharedInstance] screenView:@"FirstScreen" customParameters:nil];
When sending the event hit type, the event category and action a required fields
[[GATracker sharedInstance] eventWithCategory:@"category" action:@"action" label:nil customParameters:nil];
When sending the exception hit, the exception description and exception “fatality” are both required parameters
[[GATracker sharedInstance] exceptionWithDescription:@"This test failed" fatal:YES customParameters:nil];
With each hit you are also able to send additional parameters as specified in the Measurement Protocol reference. Examples include: “non interactive hit”, “event value”, “custom dimensions”, “custom metrics” etc.
In the following example we will add custom metric values and set this event hit as non interactive. The example shows how to send a video progress hit that includes video name as custom dimension 1, video author as custom dimension 2 and sets the event as non interactive (since this event is not a result of user interaction).
[[GATracker sharedInstance] eventWithCategory:@"Video" action:@"Progress" label:@"50%" customParameters:@{@"cd1": @"Incredible Video", @"cd2": @"Amazing A. Uthor", @"ni": @1}];
As mentioned before you are able to use any measurement protocol parameters inside the customParameters dictionary. https://developers.google.com/analytics/devguides/collection/protocol/v1/parameters?hl=en
Screenview, event and exception are not the only hit types available in Google Analytics, to send a different hit such as a transaction, item, social or timing hit use the send function.
In the following example we will send a transaction hit with transaction id 10001 and transaction revenue of $425,00.
[[GATracker sharedInstance] send:@"transaction" parameters:@{@"tid": @"10001", @"tr": @"425,00", @"cu": @"USD"}];