SlideShare a Scribd company logo
Building a  tvOS Application
using TVJS & TVML
Michiel De Mey
Navigation
tvOS App
 TV Markup Language
<?xml version="1.0" encoding="UTF-8" ?>
<document>
<descriptiveAlertTemplate>
<title>Terms of Service</title>
<description>Lorem ipsum (…)</description>
<row>
<button>
<text>Accept</text>
</button>
<button>
<text>Decline</text>
</button>
</row>
</descriptiveAlertTemplate>
</document>
 TV Markup Language
 TV Markup Language
tvOS App
 TV Javascript Framework
 TV Javascript Framework
• Supports some standard DOM classes
DOMParser
Event
XMLSerializer
• Has some tvOS specific classes you can work with
XMLHttpRequest
MediaItem
Storage
• Not through HTML <audio> or <video> element
<audio> element is for background audio
• Through Javascript
var player = new Player();
var playlist = new Playlist();
var mediaItem = new MediaItem("audio", audioURL);
player.playlist = playlist;
player.playlist.push(mediaItem);
player.present();
 TV Javascript Framework
Playing Video/Audio?
• `Window` object is non-existent
Use `App` variable instead.
• No `Promise` support
Use core-js
https://github.com/zloirock/core-js
• JavaScript inconsistencies
Math.random().toString(36)
 TV Javascript Framework
Example App
Authentication
The Stack
• Browserify (Bundling)
• Babel (ES6)
• Hogan.js (mustache templating)
Debugging
Official  Resources
• Creating a Client-Server App
• TVJS Framework Reference
• TVML Language Reference
• tvOS Sample Code
Source Code
• Xcode Project:



https://github.com/MichielDeMey/cumulus-tv-xcode
• Client Project:



https://github.com/MichielDeMey/cumulus-tv
• OAuth Server:



https://github.com/MichielDeMey/tvos-oauth-flow
Thank You

More Related Content

Viewers also liked

tvOS
tvOStvOS
Building Apps for Apple TV
Building Apps for Apple TVBuilding Apps for Apple TV
Building Apps for Apple TV
davidolesch
 
Develop apps for (Apple) TV
Develop apps for (Apple) TVDevelop apps for (Apple) TV
Develop apps for (Apple) TV
Codemotion
 
Apple TV UX: 8 Guidelines for greater Apps
Apple TV UX: 8 Guidelines for greater Apps Apple TV UX: 8 Guidelines for greater Apps
Apple TV UX: 8 Guidelines for greater Apps
CELLULAR
 
E0502 01 2327
E0502 01 2327E0502 01 2327
E0502 01 2327IJMER
 
Aw2419401943
Aw2419401943Aw2419401943
Aw2419401943IJMER
 
User Navigation Pattern Prediction from Web Log Data: A Survey
User Navigation Pattern Prediction from Web Log Data: A SurveyUser Navigation Pattern Prediction from Web Log Data: A Survey
User Navigation Pattern Prediction from Web Log Data: A Survey
IJMER
 
On Gr-Separation Axioms
 On Gr-Separation Axioms  On Gr-Separation Axioms
On Gr-Separation Axioms
IJMER
 
Ijmer 46055056
Ijmer 46055056Ijmer 46055056
Ijmer 46055056IJMER
 
A Novel Data Extraction and Alignment Method for Web Databases
A Novel Data Extraction and Alignment Method for Web DatabasesA Novel Data Extraction and Alignment Method for Web Databases
A Novel Data Extraction and Alignment Method for Web Databases
IJMER
 
A Unique Approach for Data Hiding Using Audio Steganography
A Unique Approach for Data Hiding Using Audio SteganographyA Unique Approach for Data Hiding Using Audio Steganography
A Unique Approach for Data Hiding Using Audio Steganography
IJMER
 
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid CompositesFabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
IJMER
 
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh NetworksPerformance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
IJMER
 
Experimental Investigation of the Residual Stress and calculate Average Fatig...
Experimental Investigation of the Residual Stress and calculate Average Fatig...Experimental Investigation of the Residual Stress and calculate Average Fatig...
Experimental Investigation of the Residual Stress and calculate Average Fatig...
IJMER
 
Apstyleppt 140104202730-phpapp02
Apstyleppt 140104202730-phpapp02Apstyleppt 140104202730-phpapp02
Apstyleppt 140104202730-phpapp02
joycefeuerborn
 
Some New Families on H-Cordial Graphs
Some New Families on H-Cordial GraphsSome New Families on H-Cordial Graphs
Some New Families on H-Cordial Graphs
IJMER
 
Photography powerpoint
Photography powerpointPhotography powerpoint
Photography powerpoint
joycefeuerborn
 
Writing for pr #2
Writing for pr #2Writing for pr #2
Writing for pr #2
Dicky Ahmad
 
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
IJMER
 
Spectrophotometric Determination of Cardiovascular Drugs
Spectrophotometric Determination of Cardiovascular DrugsSpectrophotometric Determination of Cardiovascular Drugs
Spectrophotometric Determination of Cardiovascular Drugs
IJMER
 

Viewers also liked (20)

tvOS
tvOStvOS
tvOS
 
Building Apps for Apple TV
Building Apps for Apple TVBuilding Apps for Apple TV
Building Apps for Apple TV
 
Develop apps for (Apple) TV
Develop apps for (Apple) TVDevelop apps for (Apple) TV
Develop apps for (Apple) TV
 
Apple TV UX: 8 Guidelines for greater Apps
Apple TV UX: 8 Guidelines for greater Apps Apple TV UX: 8 Guidelines for greater Apps
Apple TV UX: 8 Guidelines for greater Apps
 
E0502 01 2327
E0502 01 2327E0502 01 2327
E0502 01 2327
 
Aw2419401943
Aw2419401943Aw2419401943
Aw2419401943
 
User Navigation Pattern Prediction from Web Log Data: A Survey
User Navigation Pattern Prediction from Web Log Data: A SurveyUser Navigation Pattern Prediction from Web Log Data: A Survey
User Navigation Pattern Prediction from Web Log Data: A Survey
 
On Gr-Separation Axioms
 On Gr-Separation Axioms  On Gr-Separation Axioms
On Gr-Separation Axioms
 
Ijmer 46055056
Ijmer 46055056Ijmer 46055056
Ijmer 46055056
 
A Novel Data Extraction and Alignment Method for Web Databases
A Novel Data Extraction and Alignment Method for Web DatabasesA Novel Data Extraction and Alignment Method for Web Databases
A Novel Data Extraction and Alignment Method for Web Databases
 
A Unique Approach for Data Hiding Using Audio Steganography
A Unique Approach for Data Hiding Using Audio SteganographyA Unique Approach for Data Hiding Using Audio Steganography
A Unique Approach for Data Hiding Using Audio Steganography
 
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid CompositesFabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
Fabrication and Characterization of PPS /40%GF/nano-CaCo3 Hybrid Composites
 
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh NetworksPerformance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
Performance Analysis of Trust-Aware Routing Framework for Wireless Mesh Networks
 
Experimental Investigation of the Residual Stress and calculate Average Fatig...
Experimental Investigation of the Residual Stress and calculate Average Fatig...Experimental Investigation of the Residual Stress and calculate Average Fatig...
Experimental Investigation of the Residual Stress and calculate Average Fatig...
 
Apstyleppt 140104202730-phpapp02
Apstyleppt 140104202730-phpapp02Apstyleppt 140104202730-phpapp02
Apstyleppt 140104202730-phpapp02
 
Some New Families on H-Cordial Graphs
Some New Families on H-Cordial GraphsSome New Families on H-Cordial Graphs
Some New Families on H-Cordial Graphs
 
Photography powerpoint
Photography powerpointPhotography powerpoint
Photography powerpoint
 
Writing for pr #2
Writing for pr #2Writing for pr #2
Writing for pr #2
 
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
Improving the Stability of Cascaded DC Power Supply System by Adaptive Active...
 
Spectrophotometric Determination of Cardiovascular Drugs
Spectrophotometric Determination of Cardiovascular DrugsSpectrophotometric Determination of Cardiovascular Drugs
Spectrophotometric Determination of Cardiovascular Drugs
 

Similar to Building a tvOS Application

HTML5 Introduction
HTML5 IntroductionHTML5 Introduction
HTML5 Introduction
Jaeni Sahuri
 
Html5 intro
Html5 introHtml5 intro
Html5 intro
Kevin DeRudder
 
Craft 2019 - “The Upside Down” Of The Web - Video technologies
Craft 2019 - “The Upside Down” Of The Web - Video technologiesCraft 2019 - “The Upside Down” Of The Web - Video technologies
Craft 2019 - “The Upside Down” Of The Web - Video technologies
Máté Nádasdi
 
HTML5
HTML5 HTML5
Html 5
Html 5Html 5
What you need to know bout html5
What you need to know bout html5What you need to know bout html5
What you need to know bout html5
Kevin DeRudder
 
Building appsinsilverlight4 part_1
Building appsinsilverlight4 part_1Building appsinsilverlight4 part_1
Building appsinsilverlight4 part_1
Dennis Perlot
 
HTML5 Refresher
HTML5 RefresherHTML5 Refresher
HTML5 Refresher
Ivano Malavolta
 
HTML 5
HTML 5HTML 5
HTML 5
Rajan Pal
 
Getting Started with Tizen TV Web Apps
Getting Started with Tizen TV Web AppsGetting Started with Tizen TV Web Apps
Getting Started with Tizen TV Web AppsRyo Jin
 
Html5 tags
Html5 tagsHtml5 tags
Html5 tags
Tahira Sadaf
 
14 tiles, notifications, and action center
14   tiles, notifications, and action center14   tiles, notifications, and action center
14 tiles, notifications, and action center
WindowsPhoneRocks
 
1. introduction to html5
1. introduction to html51. introduction to html5
1. introduction to html5
JayjZens
 
Html5 tutorial
Html5 tutorialHtml5 tutorial
Html5 tutorialmadhavforu
 
Justmeans power point
Justmeans power pointJustmeans power point
Justmeans power point
justmeanscsr
 
Web Directions @media 2010
Web Directions @media 2010Web Directions @media 2010
Web Directions @media 2010Patrick Lauke
 
Html5 shubelal
Html5 shubelalHtml5 shubelal
Html5 shubelal
Shub
 
Top 10 HTML5 features every developer should know!
Top 10 HTML5 features every developer should know!Top 10 HTML5 features every developer should know!
Top 10 HTML5 features every developer should know!Gill Cleeren
 
Lab#4 html5new element
Lab#4 html5new elementLab#4 html5new element
Lab#4 html5new element
Yaowaluck Promdee
 

Similar to Building a tvOS Application (20)

HTML5 Introduction
HTML5 IntroductionHTML5 Introduction
HTML5 Introduction
 
Html5 intro
Html5 introHtml5 intro
Html5 intro
 
Craft 2019 - “The Upside Down” Of The Web - Video technologies
Craft 2019 - “The Upside Down” Of The Web - Video technologiesCraft 2019 - “The Upside Down” Of The Web - Video technologies
Craft 2019 - “The Upside Down” Of The Web - Video technologies
 
HTML5
HTML5 HTML5
HTML5
 
Html 5
Html 5Html 5
Html 5
 
Html 5
Html 5Html 5
Html 5
 
What you need to know bout html5
What you need to know bout html5What you need to know bout html5
What you need to know bout html5
 
Building appsinsilverlight4 part_1
Building appsinsilverlight4 part_1Building appsinsilverlight4 part_1
Building appsinsilverlight4 part_1
 
HTML5 Refresher
HTML5 RefresherHTML5 Refresher
HTML5 Refresher
 
HTML 5
HTML 5HTML 5
HTML 5
 
Getting Started with Tizen TV Web Apps
Getting Started with Tizen TV Web AppsGetting Started with Tizen TV Web Apps
Getting Started with Tizen TV Web Apps
 
Html5 tags
Html5 tagsHtml5 tags
Html5 tags
 
14 tiles, notifications, and action center
14   tiles, notifications, and action center14   tiles, notifications, and action center
14 tiles, notifications, and action center
 
1. introduction to html5
1. introduction to html51. introduction to html5
1. introduction to html5
 
Html5 tutorial
Html5 tutorialHtml5 tutorial
Html5 tutorial
 
Justmeans power point
Justmeans power pointJustmeans power point
Justmeans power point
 
Web Directions @media 2010
Web Directions @media 2010Web Directions @media 2010
Web Directions @media 2010
 
Html5 shubelal
Html5 shubelalHtml5 shubelal
Html5 shubelal
 
Top 10 HTML5 features every developer should know!
Top 10 HTML5 features every developer should know!Top 10 HTML5 features every developer should know!
Top 10 HTML5 features every developer should know!
 
Lab#4 html5new element
Lab#4 html5new elementLab#4 html5new element
Lab#4 html5new element
 

Recently uploaded

2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx
Georgi Kodinov
 
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
Mind IT Systems
 
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoamOpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
takuyayamamoto1800
 
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdfEnhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
Jay Das
 
top nidhi software solution freedownload
top nidhi software solution freedownloadtop nidhi software solution freedownload
top nidhi software solution freedownload
vrstrong314
 
A Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of PassageA Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of Passage
Philip Schwarz
 
Cyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdfCyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdf
Cyanic lab
 
Lecture 1 Introduction to games development
Lecture 1 Introduction to games developmentLecture 1 Introduction to games development
Lecture 1 Introduction to games development
abdulrafaychaudhry
 
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, BetterWebinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
XfilesPro
 
How Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptxHow Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptx
wottaspaceseo
 
A Comprehensive Look at Generative AI in Retail App Testing.pdf
A Comprehensive Look at Generative AI in Retail App Testing.pdfA Comprehensive Look at Generative AI in Retail App Testing.pdf
A Comprehensive Look at Generative AI in Retail App Testing.pdf
kalichargn70th171
 
Using IESVE for Room Loads Analysis - Australia & New Zealand
Using IESVE for Room Loads Analysis - Australia & New ZealandUsing IESVE for Room Loads Analysis - Australia & New Zealand
Using IESVE for Room Loads Analysis - Australia & New Zealand
IES VE
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
Max Andersen
 
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERRORTROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
Tier1 app
 
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology SolutionsProsigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns
 
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Natan Silnitsky
 
Cracking the code review at SpringIO 2024
Cracking the code review at SpringIO 2024Cracking the code review at SpringIO 2024
Cracking the code review at SpringIO 2024
Paco van Beckhoven
 
Enterprise Resource Planning System in Telangana
Enterprise Resource Planning System in TelanganaEnterprise Resource Planning System in Telangana
Enterprise Resource Planning System in Telangana
NYGGS Automation Suite
 
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing SuiteAI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
Google
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
AMB-Review
 

Recently uploaded (20)

2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx
 
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
Custom Healthcare Software for Managing Chronic Conditions and Remote Patient...
 
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoamOpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
OpenFOAM solver for Helmholtz equation, helmholtzFoam / helmholtzBubbleFoam
 
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdfEnhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
Enhancing Project Management Efficiency_ Leveraging AI Tools like ChatGPT.pdf
 
top nidhi software solution freedownload
top nidhi software solution freedownloadtop nidhi software solution freedownload
top nidhi software solution freedownload
 
A Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of PassageA Sighting of filterA in Typelevel Rite of Passage
A Sighting of filterA in Typelevel Rite of Passage
 
Cyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdfCyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdf
 
Lecture 1 Introduction to games development
Lecture 1 Introduction to games developmentLecture 1 Introduction to games development
Lecture 1 Introduction to games development
 
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, BetterWebinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
Webinar: Salesforce Document Management 2.0 - Smarter, Faster, Better
 
How Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptxHow Recreation Management Software Can Streamline Your Operations.pptx
How Recreation Management Software Can Streamline Your Operations.pptx
 
A Comprehensive Look at Generative AI in Retail App Testing.pdf
A Comprehensive Look at Generative AI in Retail App Testing.pdfA Comprehensive Look at Generative AI in Retail App Testing.pdf
A Comprehensive Look at Generative AI in Retail App Testing.pdf
 
Using IESVE for Room Loads Analysis - Australia & New Zealand
Using IESVE for Room Loads Analysis - Australia & New ZealandUsing IESVE for Room Loads Analysis - Australia & New Zealand
Using IESVE for Room Loads Analysis - Australia & New Zealand
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
 
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERRORTROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
TROUBLESHOOTING 9 TYPES OF OUTOFMEMORYERROR
 
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology SolutionsProsigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology Solutions
 
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
 
Cracking the code review at SpringIO 2024
Cracking the code review at SpringIO 2024Cracking the code review at SpringIO 2024
Cracking the code review at SpringIO 2024
 
Enterprise Resource Planning System in Telangana
Enterprise Resource Planning System in TelanganaEnterprise Resource Planning System in Telangana
Enterprise Resource Planning System in Telangana
 
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing SuiteAI Pilot Review: The World’s First Virtual Assistant Marketing Suite
AI Pilot Review: The World’s First Virtual Assistant Marketing Suite
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
 

Building a tvOS Application

  • 1. Building a  tvOS Application using TVJS & TVML
  • 3.
  • 5.
  • 6. tvOS App  TV Markup Language
  • 7. <?xml version="1.0" encoding="UTF-8" ?> <document> <descriptiveAlertTemplate> <title>Terms of Service</title> <description>Lorem ipsum (…)</description> <row> <button> <text>Accept</text> </button> <button> <text>Decline</text> </button> </row> </descriptiveAlertTemplate> </document>  TV Markup Language
  • 8.  TV Markup Language
  • 9.
  • 10. tvOS App  TV Javascript Framework
  • 11.  TV Javascript Framework • Supports some standard DOM classes DOMParser Event XMLSerializer • Has some tvOS specific classes you can work with XMLHttpRequest MediaItem Storage
  • 12. • Not through HTML <audio> or <video> element <audio> element is for background audio • Through Javascript var player = new Player(); var playlist = new Playlist(); var mediaItem = new MediaItem("audio", audioURL); player.playlist = playlist; player.playlist.push(mediaItem); player.present();  TV Javascript Framework Playing Video/Audio?
  • 13. • `Window` object is non-existent Use `App` variable instead. • No `Promise` support Use core-js https://github.com/zloirock/core-js • JavaScript inconsistencies Math.random().toString(36)  TV Javascript Framework
  • 16.
  • 17.
  • 18.
  • 19.
  • 20. The Stack • Browserify (Bundling) • Babel (ES6) • Hogan.js (mustache templating)
  • 22.
  • 23. Official  Resources • Creating a Client-Server App • TVJS Framework Reference • TVML Language Reference • tvOS Sample Code
  • 24. Source Code • Xcode Project:
 
 https://github.com/MichielDeMey/cumulus-tv-xcode • Client Project:
 
 https://github.com/MichielDeMey/cumulus-tv • OAuth Server:
 
 https://github.com/MichielDeMey/tvos-oauth-flow