Guides and Sample Code

Developer

App Programming Guide for tvOS

Creating a Client-Server App

Client-server apps using JavaScript and TVML differ slightly from traditional apps. The main function of the project you create in Xcode is to access a main JavaScript file and present pages created from TVML files on the screen. Figure 2-1 shows the client-server model.

Figure 2-1Client-server model image: ../Art/flow_diagram_2x.png

Your JavaScript file loads TVML pages and pushes each page onto the navigation stack. As the user navigates through your app, TVML pages are pushed and popped from the stack. After the user closes your app, the Apple TV home screen appears. Figure 2-2 shows the flow for a basic app.

Figure 2-2Client-server app flow image: ../Art/flow_diagram2_2x.png

To build a client-server app:

  1. Open Xcode and create a new project.

  2. Select the Single View Application template from tvOS.

  3. Remove the view controller file and the main storyboard for the app.

  4. Open the info.plist file and remove the Main storyboard file base name entry.

  5. Make these changes to the AppDelegate.swift file:

    • Add import TVMLKit.

    • Change the class declaration to be class AppDelegate: UIResponder, UIApplicationDelegate, TVApplicationControllerDelegate {.

    • Add the following global variable to your class: var appController: TVApplicationController?

    • Modify application:didfinishLaunchingWithOptions: according to the code found in the listing below:

    1. func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    2. self.window = UIWindow(frame: UIScreen.mainScreen().bounds)
    3. let appControllerContext = TVApplicationControllerContext()
    4. let javascriptURL = NSURL(string: "Enter path to your JavaScript file here")
    5. appControllerContext.javaScriptApplicationURL = javascriptURL
    6. appControllerContext.launchOptions["BASEURL"] = TVBaseURL
    7. if let options = launchOptions {
    8. for (kind, value) in options {
    9. if let kindStr = kind as? String {
    10. appControllerContext.launchOptions[kindStr] = value
    11. }
    12. }
    13. }
    14. self.appController = TVApplicationController(context: appControllerContext, window: self.window, delegate: self)
    15. return true
    16. }

The code in the above example loads a JavaScript file which then loads a TVML page and displays it in the simulator or on a television screen if a new Apple TV is connected to your computer. For more information about JavaScript classes, see Apple TV JavaScript Framework Reference.

The JavaScript in Listing 2-1 loads a TVML page (Listing 2-2) that displays an alert asking if the user wants to upgrade to the premium version of your app. After the page is loaded, it is pushed onto the navigation stack The operating system then displays it to the user. For more information on available TVML templates and elements, see Apple TV Markup Language Reference.

Listing 2-1Pushing a TVML page onto the navigation stack
  1. function getDocument(url) {
  2. var templateXHR = new XMLHttpRequest();
  3. templateXHR.responseType = "document";
  4. templateXHR.addEventListener("load", function() {pushDoc(templateXHR.responseXML);}, false);
  5. templateXHR.open("GET", url, true);
  6. templateXHR.send();
  7. return templateXHR;
  8. }
  9. function pushDoc(document) {
  10. navigationDocument.pushDocument(document);
  11. }
  12. App.onLaunch = function(options) {
  13. var templateURL = 'Enter path to your server here/alertTemplate.tvml';
  14. getDocument(templateURL);
  15. }
  16. App.onExit = function() {
  17. console.log('App finished');
  18. }
Listing 2-2A TVML page to display an alert
  1. <document>
  2. <alertTemplate>
  3. <title>Update to premium</title>
  4. <description>Go ad free by updating to the premium version</description>
  5. <button>
  6. <text>Update Now</text>
  7. </button>
  8. <button>
  9. <text>Cancel</text>
  10. </button>
  11. </alertTemplate>
  12. </document>