Google Analytics tracker for Apple tvOS
  • May 26, 2025

About


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.


Implementation

All code for this tracker is located inside a single file “GATracker.swift”. The first step of the implementation is associating this library file with your application 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.setup(“UA-1234567-89”)

This code should run in the AppDelegate method applicationDidFinishLaunchingWithOptions.

Hit Examples


Once the tracker is set up you can start sending Google Analytics hits from your Apple TV application.

Screenview

 

When sending the screenview hit type, the screenname parameter is a required field.

GATracker.sharedInstance.screenView(“FirstScreen”, customParameters: nil)

Event

 

When sending the event hit type, the event category and action a required fields

GATracker.sharedInstance.event(“category”, action: “action”, label: nil, customParameters: nil)

Exception

 

When sending the exception hit, the exception description and exception “fatality” are both required parameters

GATracker.sharedInstance.exception(“This test failed”, isFatal: true, customParameters: nil)

Sending Additional Parameters

 

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.event(“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

Sending Other Hit Types to Google Analytics

 

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”, params: [“tid”:”10001″, “tr”:”425,00″, “cu”:”USD”])

For additional information email gethelp@analyticspros.com or visit our website http://www.analyticspros.com

Sample App

 

When running the sample app make sure ot update the property id in the app delegate.

GATracker.setup(“[insert your GA property id]”)

GitHub


View Github

YOU MIGHT ALSO LIKE...
ConfettiView

A SwiftUI View that emits confetti with user-defined shapes, images, and text.

SwiftUI Colour Wheel

A colour wheel made all in SwiftUI. There are 2 different colour wheels to choose from. The first main one ...

ColorPickerRing

A color picker implementation with color wheel appearance written in plain SwiftUI. It is compatible with UIColor and NSColor.

ASCollectionView

This repository is no longer maintained. Here's why: with the release of iOS 16 SwiftUI now enables most of the ...