SlideShare a Scribd company logo
1 of 27
Responsive browser-based
video recording and playback
Oliver Friedmann
CTO & Founder, Ziggeo
@oliverfriedmann
Why not just the <video></video> tag?
No control over controls.
Safari Firefox Chrome / Opera
Video events is a cross-browser mess.
Even new browsers can only play MP4s.
MP4 3-52 21-47 3.1-9 3-37 12-14 9-11 5.1-9.3 4.3-6.0
WEBM 6-52 4-47 No 10.6-37 No No No 4.3-6.0
OGV 3-52 3.5-47 No 10.5-37 No No No No
Mobile WebDesktop Web
Existing players don’t behave like normal HTML
And if you think playback is broken, here is recording.
HTML 5 Yes Yes No Yes Yes No No 5.0
MediaRecorder No Yes No No No No No no
Flash Yes Yes Yes Yes Yes Yes No No
Capture No No No No No No Yes Yes
Mobile WebDesktop Web
Announcing:
BetaJS Player / Recorder
BetaJS Video Player
BetaJS Video Recorder
(open source coming soon)
For cloud-based version, visit http://ziggeo.com
BetaJS Player / Recording Browser Compatibility
Playback 15-52 4-44 5-9 18-37 12-14 8-11 7.0-9.0 4.0-6.0
Recording 15-52 4-44 5-9 18-37 12-14 8-11 7.0-9.0 4.0-6.0
(Includes falling back to Flash if necessary)
Mobile WebDesktop Web
Introducing:
Open-Source BetaJS Framework
What, yet another framework?
Building Web Components
● Extend websites by components like video players
● CSS of host website + embeddings don’t play well
● JS library dependencies of host + embed don’t play well
○ because different libraries clash
○ because different versions of the same library clash
Why iFrames are no good.
● Host website cannot properly communicate with embedding
● Additional round trips for every embed
● Extending embeddings via host website cumbersome
Combining frameworks is not easy.
(Host website must explicitly wrap calls to make it work.)
http://stackoverflow.com/questions/20947191/using-reactjs-with-angularjs
BetaJS Design Principles
● No outside dependencies (currently: jQuery but will eliminate in future release)
● Play nicely with other frameworks
● Loosely coupled and modularized
● Allow multiple versions to be present at the same time
● Don’t impose page/code structure
● Layered customizability
● Minimal footprint
Framework Overview
betajs-scoped scoped loading of modules and dependencies
betajs helper functions and classes
betajs-browser browser-specific methods
betajs-dynamics dynamic DOM templating engine
betajs-flash Flash-JavaScript bridging framework
betajs-media a JavaScript media framework (video playback, video recording)
betajs-media-components full video player / video recorder UI components
Footprint
Module Size (kb) Minified (kb)
betajs-scoped 18 9
betajs 214 120
betajs-browser 64 39
betajs-dynamics 75 42
betajs-flash 11 7
betajs-media 66 36
betajs-media-components 30 24
Total 478 277
Compiled for Player 301 172
VideoJS 697 250
JWPlayer ? 227
Customization Dimensions
Styles (Namespaced) CSS
UI HTML Templating System
Views JS Controller System (Dynamics)
Themes Bundling of Styles, UI, Views
Outside Control Exposed Methods + Events
Locales String assets for language support
(Customization supports granular changes at each layer)
Customizing CSS
Customizing Templates
Creating Themes
Adding Locales
Customizing the State Machine
VideoPlayer.PosterReady VideoPlayer.LoadVideo
click play
MyPlayer.PosterReady
extends
MyPlayer.Preroll
click play
preroll complete
VideoPlayer Class
MyPlayer Class
Open-Source Framework
Apache 2.0 License
Commercial Cloud Video & Backend Support
http://betajs.com
Oliver Friedmann
Founder & CTO, Ziggeo
oliver@ziggeo.com

More Related Content

What's hot

Upgrade to HTML5 Video
Upgrade to HTML5 VideoUpgrade to HTML5 Video
Upgrade to HTML5 Video
steveheffernan
 
Developer Training for 23 Video
Developer Training for 23 VideoDeveloper Training for 23 Video
Developer Training for 23 Video
Steffen
 
Mike Taulty Beyond Silverlight With W P F
Mike Taulty  Beyond  Silverlight  With  W P FMike Taulty  Beyond  Silverlight  With  W P F
Mike Taulty Beyond Silverlight With W P F
ukdpe
 
Imagine recap-devhub
Imagine recap-devhubImagine recap-devhub
Imagine recap-devhub
Magento Dev
 

What's hot (20)

Upgrade to HTML5 Video
Upgrade to HTML5 VideoUpgrade to HTML5 Video
Upgrade to HTML5 Video
 
Browserium
BrowseriumBrowserium
Browserium
 
Browserium
BrowseriumBrowserium
Browserium
 
Mage Titans USA 2016 M2 deployment
Mage Titans USA 2016  M2 deploymentMage Titans USA 2016  M2 deployment
Mage Titans USA 2016 M2 deployment
 
JavaFX vs AJAX vs Flex
JavaFX vs AJAX vs FlexJavaFX vs AJAX vs Flex
JavaFX vs AJAX vs Flex
 
Html5, Native and Platform based Mobile Applications
Html5, Native and Platform based Mobile ApplicationsHtml5, Native and Platform based Mobile Applications
Html5, Native and Platform based Mobile Applications
 
Developer Training for 23 Video
Developer Training for 23 VideoDeveloper Training for 23 Video
Developer Training for 23 Video
 
Oleh Kobchenko - Configure Magento 2 to get maximum performance
Oleh Kobchenko - Configure Magento 2 to get maximum performanceOleh Kobchenko - Configure Magento 2 to get maximum performance
Oleh Kobchenko - Configure Magento 2 to get maximum performance
 
Mike Taulty Beyond Silverlight With W P F
Mike Taulty  Beyond  Silverlight  With  W P FMike Taulty  Beyond  Silverlight  With  W P F
Mike Taulty Beyond Silverlight With W P F
 
#2 Hanoi Magento Meetup - Part 2: Knockout JS
#2 Hanoi Magento Meetup - Part 2: Knockout JS#2 Hanoi Magento Meetup - Part 2: Knockout JS
#2 Hanoi Magento Meetup - Part 2: Knockout JS
 
Webview: The fifth element
Webview: The fifth elementWebview: The fifth element
Webview: The fifth element
 
Layout draft
Layout draftLayout draft
Layout draft
 
Imagine recap-devhub
Imagine recap-devhubImagine recap-devhub
Imagine recap-devhub
 
Magento 2 - An Intro to a Modern PHP-Based System - Northeast PHP 2015
Magento 2 - An Intro to a Modern PHP-Based System - Northeast PHP 2015Magento 2 - An Intro to a Modern PHP-Based System - Northeast PHP 2015
Magento 2 - An Intro to a Modern PHP-Based System - Northeast PHP 2015
 
Practical guide for front-end development for django devs
Practical guide for front-end development for django devsPractical guide for front-end development for django devs
Practical guide for front-end development for django devs
 
Html5video
Html5videoHtml5video
Html5video
 
Rock-solid Magento Deployments (and Development)
Rock-solid Magento Deployments (and Development)Rock-solid Magento Deployments (and Development)
Rock-solid Magento Deployments (and Development)
 
How To Install Magento 2 (updated for the latest version)
How To Install Magento 2 (updated for the latest version)How To Install Magento 2 (updated for the latest version)
How To Install Magento 2 (updated for the latest version)
 
Unscrambling An Omelette - How Companies Can Use WordPress Better - Jeremy Ke...
Unscrambling An Omelette - How Companies Can Use WordPress Better - Jeremy Ke...Unscrambling An Omelette - How Companies Can Use WordPress Better - Jeremy Ke...
Unscrambling An Omelette - How Companies Can Use WordPress Better - Jeremy Ke...
 
Packaging DNN extensions
Packaging DNN extensionsPackaging DNN extensions
Packaging DNN extensions
 

Viewers also liked

SOTM10 lightning talk : BMO differential import
SOTM10 lightning talk : BMO  differential importSOTM10 lightning talk : BMO  differential import
SOTM10 lightning talk : BMO differential import
fvanderbiest
 
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
European School of Oncology
 
Natureza Maravilhosa
Natureza MaravilhosaNatureza Maravilhosa
Natureza Maravilhosa
Anjovison .
 
story of leonard
story of leonardstory of leonard
story of leonard
sjunielle
 
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
CORE Group
 

Viewers also liked (20)

Tarea 1.1 tice
Tarea 1.1 ticeTarea 1.1 tice
Tarea 1.1 tice
 
テーマ「最適化 その2」
テーマ「最適化 その2」テーマ「最適化 その2」
テーマ「最適化 その2」
 
Gold, серебро
Gold, сереброGold, серебро
Gold, серебро
 
2007 nov amsterdam m3 marketing - payments are sexy
2007 nov amsterdam   m3 marketing - payments are sexy2007 nov amsterdam   m3 marketing - payments are sexy
2007 nov amsterdam m3 marketing - payments are sexy
 
Utplassering 2012
Utplassering 2012Utplassering 2012
Utplassering 2012
 
SOTM10 lightning talk : BMO differential import
SOTM10 lightning talk : BMO  differential importSOTM10 lightning talk : BMO  differential import
SOTM10 lightning talk : BMO differential import
 
Hydrologist-CV
Hydrologist-CVHydrologist-CV
Hydrologist-CV
 
Research in Emergency Medicine: Medical school aspect
Research in Emergency Medicine: Medical school aspectResearch in Emergency Medicine: Medical school aspect
Research in Emergency Medicine: Medical school aspect
 
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
ECCLU 2011 - B. Tombal - Prostate cancer: From biology to live expectancy - S...
 
Creating Email Campaigns that Work: A Focus on Design Elements
Creating Email Campaigns that Work: A Focus on Design ElementsCreating Email Campaigns that Work: A Focus on Design Elements
Creating Email Campaigns that Work: A Focus on Design Elements
 
080409 Churchill Club Slides
080409 Churchill Club Slides080409 Churchill Club Slides
080409 Churchill Club Slides
 
research paper 2012
research paper 2012research paper 2012
research paper 2012
 
Financial IT Forum 2011
Financial IT Forum 2011Financial IT Forum 2011
Financial IT Forum 2011
 
Something about node in the realworld
Something about node in the realworldSomething about node in the realworld
Something about node in the realworld
 
Funciones de cadena
Funciones de cadenaFunciones de cadena
Funciones de cadena
 
Presentation
PresentationPresentation
Presentation
 
Natureza Maravilhosa
Natureza MaravilhosaNatureza Maravilhosa
Natureza Maravilhosa
 
story of leonard
story of leonardstory of leonard
story of leonard
 
Symantec Delivers 30x Faster Failover For Microsoft Environments
Symantec Delivers 30x Faster Failover For Microsoft EnvironmentsSymantec Delivers 30x Faster Failover For Microsoft Environments
Symantec Delivers 30x Faster Failover For Microsoft Environments
 
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
Understanding the Essential Nutrition Actions Framework_Jennifer Nielsen_5.5.14
 

Similar to Responsive browser-based video recording and playback

(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
Web::Strategija
 
Arm html5 presentation
Arm html5 presentationArm html5 presentation
Arm html5 presentation
Ian Renyard
 
Mobile Meow at Mobilism
Mobile Meow at MobilismMobile Meow at Mobilism
Mobile Meow at Mobilism
Greg Schechter
 

Similar to Responsive browser-based video recording and playback (20)

JS Days HTML5 Flash and the Battle for Faster Cat Videos
JS Days HTML5 Flash and the Battle for Faster Cat VideosJS Days HTML5 Flash and the Battle for Faster Cat Videos
JS Days HTML5 Flash and the Battle for Faster Cat Videos
 
GDD HTML5, Flash, and the Battle for Faster Cat Videos
GDD HTML5, Flash, and the Battle for Faster Cat VideosGDD HTML5, Flash, and the Battle for Faster Cat Videos
GDD HTML5, Flash, and the Battle for Faster Cat Videos
 
(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
(WS11) Dobrica Pavlinušić: HTML5TV - kako obraditi i objaviti predavanja na w...
 
HTML5, Flash, and the Battle For Faster Cat Videos
HTML5, Flash, and the Battle For Faster Cat VideosHTML5, Flash, and the Battle For Faster Cat Videos
HTML5, Flash, and the Battle For Faster Cat Videos
 
Jun Heider - Flex Application Profiling By Example
Jun Heider - Flex Application Profiling By ExampleJun Heider - Flex Application Profiling By Example
Jun Heider - Flex Application Profiling By Example
 
Streaming in grails
Streaming in grailsStreaming in grails
Streaming in grails
 
Arm html5 presentation
Arm html5 presentationArm html5 presentation
Arm html5 presentation
 
JS Days Mobile Meow
JS Days Mobile MeowJS Days Mobile Meow
JS Days Mobile Meow
 
Mobile Meow at Mobilism
Mobile Meow at MobilismMobile Meow at Mobilism
Mobile Meow at Mobilism
 
Webrtc plugins for Desktop Browsers
Webrtc plugins for Desktop BrowsersWebrtc plugins for Desktop Browsers
Webrtc plugins for Desktop Browsers
 
HTML5 Comprehensive Guide
HTML5 Comprehensive GuideHTML5 Comprehensive Guide
HTML5 Comprehensive Guide
 
You Can Work on the Web Patform! (GOSIM 2023)
You Can Work on the Web Patform! (GOSIM 2023)You Can Work on the Web Patform! (GOSIM 2023)
You Can Work on the Web Patform! (GOSIM 2023)
 
How I built a WebRTC enabled website in 20 minutes!
How I built a WebRTC enabled website in 20 minutes!How I built a WebRTC enabled website in 20 minutes!
How I built a WebRTC enabled website in 20 minutes!
 
[1C5]Lessons from developing a web browser for raspberry pi
[1C5]Lessons from developing a web browser for raspberry pi[1C5]Lessons from developing a web browser for raspberry pi
[1C5]Lessons from developing a web browser for raspberry pi
 
Accelerate graphics performance with ozone-gbm on Intel based Linux desktop s...
Accelerate graphics performance with ozone-gbm on Intel based Linux desktop s...Accelerate graphics performance with ozone-gbm on Intel based Linux desktop s...
Accelerate graphics performance with ozone-gbm on Intel based Linux desktop s...
 
Web DU Mobile Meow
Web DU Mobile MeowWeb DU Mobile Meow
Web DU Mobile Meow
 
HTML5 video & Amazon elastic transcoder - FCIP August 2014
HTML5 video & Amazon elastic transcoder - FCIP August 2014HTML5 video & Amazon elastic transcoder - FCIP August 2014
HTML5 video & Amazon elastic transcoder - FCIP August 2014
 
HTML5 Intoduction for Web Developers
HTML5 Intoduction for Web DevelopersHTML5 Intoduction for Web Developers
HTML5 Intoduction for Web Developers
 
Html5 Video Vs Flash Video presentation
Html5 Video Vs Flash Video presentationHtml5 Video Vs Flash Video presentation
Html5 Video Vs Flash Video presentation
 
Ilog Ria2
Ilog Ria2Ilog Ria2
Ilog Ria2
 

Recently uploaded

result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college project
Tonystark477637
 
AKTU Computer Networks notes --- Unit 3.pdf
AKTU Computer Networks notes ---  Unit 3.pdfAKTU Computer Networks notes ---  Unit 3.pdf
AKTU Computer Networks notes --- Unit 3.pdf
ankushspencer015
 
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
dharasingh5698
 
UNIT-V FMM.HYDRAULIC TURBINE - Construction and working
UNIT-V FMM.HYDRAULIC TURBINE - Construction and workingUNIT-V FMM.HYDRAULIC TURBINE - Construction and working
UNIT-V FMM.HYDRAULIC TURBINE - Construction and working
rknatarajan
 
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar ≼🔝 Delhi door step de...
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar  ≼🔝 Delhi door step de...Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar  ≼🔝 Delhi door step de...
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar ≼🔝 Delhi door step de...
9953056974 Low Rate Call Girls In Saket, Delhi NCR
 

Recently uploaded (20)

CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete RecordCCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
CCS335 _ Neural Networks and Deep Learning Laboratory_Lab Complete Record
 
result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college project
 
(INDIRA) Call Girl Aurangabad Call Now 8617697112 Aurangabad Escorts 24x7
(INDIRA) Call Girl Aurangabad Call Now 8617697112 Aurangabad Escorts 24x7(INDIRA) Call Girl Aurangabad Call Now 8617697112 Aurangabad Escorts 24x7
(INDIRA) Call Girl Aurangabad Call Now 8617697112 Aurangabad Escorts 24x7
 
AKTU Computer Networks notes --- Unit 3.pdf
AKTU Computer Networks notes ---  Unit 3.pdfAKTU Computer Networks notes ---  Unit 3.pdf
AKTU Computer Networks notes --- Unit 3.pdf
 
University management System project report..pdf
University management System project report..pdfUniversity management System project report..pdf
University management System project report..pdf
 
Intze Overhead Water Tank Design by Working Stress - IS Method.pdf
Intze Overhead Water Tank  Design by Working Stress - IS Method.pdfIntze Overhead Water Tank  Design by Working Stress - IS Method.pdf
Intze Overhead Water Tank Design by Working Stress - IS Method.pdf
 
(INDIRA) Call Girl Bhosari Call Now 8617697112 Bhosari Escorts 24x7
(INDIRA) Call Girl Bhosari Call Now 8617697112 Bhosari Escorts 24x7(INDIRA) Call Girl Bhosari Call Now 8617697112 Bhosari Escorts 24x7
(INDIRA) Call Girl Bhosari Call Now 8617697112 Bhosari Escorts 24x7
 
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
 
UNIT-V FMM.HYDRAULIC TURBINE - Construction and working
UNIT-V FMM.HYDRAULIC TURBINE - Construction and workingUNIT-V FMM.HYDRAULIC TURBINE - Construction and working
UNIT-V FMM.HYDRAULIC TURBINE - Construction and working
 
UNIT - IV - Air Compressors and its Performance
UNIT - IV - Air Compressors and its PerformanceUNIT - IV - Air Compressors and its Performance
UNIT - IV - Air Compressors and its Performance
 
data_management_and _data_science_cheat_sheet.pdf
data_management_and _data_science_cheat_sheet.pdfdata_management_and _data_science_cheat_sheet.pdf
data_management_and _data_science_cheat_sheet.pdf
 
Call for Papers - International Journal of Intelligent Systems and Applicatio...
Call for Papers - International Journal of Intelligent Systems and Applicatio...Call for Papers - International Journal of Intelligent Systems and Applicatio...
Call for Papers - International Journal of Intelligent Systems and Applicatio...
 
(INDIRA) Call Girl Meerut Call Now 8617697112 Meerut Escorts 24x7
(INDIRA) Call Girl Meerut Call Now 8617697112 Meerut Escorts 24x7(INDIRA) Call Girl Meerut Call Now 8617697112 Meerut Escorts 24x7
(INDIRA) Call Girl Meerut Call Now 8617697112 Meerut Escorts 24x7
 
Call Girls Walvekar Nagar Call Me 7737669865 Budget Friendly No Advance Booking
Call Girls Walvekar Nagar Call Me 7737669865 Budget Friendly No Advance BookingCall Girls Walvekar Nagar Call Me 7737669865 Budget Friendly No Advance Booking
Call Girls Walvekar Nagar Call Me 7737669865 Budget Friendly No Advance Booking
 
Coefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptxCoefficient of Thermal Expansion and their Importance.pptx
Coefficient of Thermal Expansion and their Importance.pptx
 
Roadmap to Membership of RICS - Pathways and Routes
Roadmap to Membership of RICS - Pathways and RoutesRoadmap to Membership of RICS - Pathways and Routes
Roadmap to Membership of RICS - Pathways and Routes
 
Top Rated Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated  Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...Top Rated  Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
 
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar ≼🔝 Delhi door step de...
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar  ≼🔝 Delhi door step de...Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar  ≼🔝 Delhi door step de...
Call Now ≽ 9953056974 ≼🔝 Call Girls In New Ashok Nagar ≼🔝 Delhi door step de...
 
PVC VS. FIBERGLASS (FRP) GRAVITY SEWER - UNI BELL
PVC VS. FIBERGLASS (FRP) GRAVITY SEWER - UNI BELLPVC VS. FIBERGLASS (FRP) GRAVITY SEWER - UNI BELL
PVC VS. FIBERGLASS (FRP) GRAVITY SEWER - UNI BELL
 
Online banking management system project.pdf
Online banking management system project.pdfOnline banking management system project.pdf
Online banking management system project.pdf
 

Responsive browser-based video recording and playback

  • 1. Responsive browser-based video recording and playback Oliver Friedmann CTO & Founder, Ziggeo @oliverfriedmann
  • 2. Why not just the <video></video> tag?
  • 3. No control over controls. Safari Firefox Chrome / Opera
  • 4. Video events is a cross-browser mess.
  • 5. Even new browsers can only play MP4s. MP4 3-52 21-47 3.1-9 3-37 12-14 9-11 5.1-9.3 4.3-6.0 WEBM 6-52 4-47 No 10.6-37 No No No 4.3-6.0 OGV 3-52 3.5-47 No 10.5-37 No No No No Mobile WebDesktop Web
  • 6. Existing players don’t behave like normal HTML
  • 7. And if you think playback is broken, here is recording. HTML 5 Yes Yes No Yes Yes No No 5.0 MediaRecorder No Yes No No No No No no Flash Yes Yes Yes Yes Yes Yes No No Capture No No No No No No Yes Yes Mobile WebDesktop Web
  • 10. BetaJS Video Recorder (open source coming soon) For cloud-based version, visit http://ziggeo.com
  • 11. BetaJS Player / Recording Browser Compatibility Playback 15-52 4-44 5-9 18-37 12-14 8-11 7.0-9.0 4.0-6.0 Recording 15-52 4-44 5-9 18-37 12-14 8-11 7.0-9.0 4.0-6.0 (Includes falling back to Flash if necessary) Mobile WebDesktop Web
  • 13. What, yet another framework?
  • 14. Building Web Components ● Extend websites by components like video players ● CSS of host website + embeddings don’t play well ● JS library dependencies of host + embed don’t play well ○ because different libraries clash ○ because different versions of the same library clash
  • 15. Why iFrames are no good. ● Host website cannot properly communicate with embedding ● Additional round trips for every embed ● Extending embeddings via host website cumbersome
  • 16. Combining frameworks is not easy. (Host website must explicitly wrap calls to make it work.) http://stackoverflow.com/questions/20947191/using-reactjs-with-angularjs
  • 17. BetaJS Design Principles ● No outside dependencies (currently: jQuery but will eliminate in future release) ● Play nicely with other frameworks ● Loosely coupled and modularized ● Allow multiple versions to be present at the same time ● Don’t impose page/code structure ● Layered customizability ● Minimal footprint
  • 18. Framework Overview betajs-scoped scoped loading of modules and dependencies betajs helper functions and classes betajs-browser browser-specific methods betajs-dynamics dynamic DOM templating engine betajs-flash Flash-JavaScript bridging framework betajs-media a JavaScript media framework (video playback, video recording) betajs-media-components full video player / video recorder UI components
  • 19. Footprint Module Size (kb) Minified (kb) betajs-scoped 18 9 betajs 214 120 betajs-browser 64 39 betajs-dynamics 75 42 betajs-flash 11 7 betajs-media 66 36 betajs-media-components 30 24 Total 478 277 Compiled for Player 301 172 VideoJS 697 250 JWPlayer ? 227
  • 20. Customization Dimensions Styles (Namespaced) CSS UI HTML Templating System Views JS Controller System (Dynamics) Themes Bundling of Styles, UI, Views Outside Control Exposed Methods + Events Locales String assets for language support (Customization supports granular changes at each layer)
  • 25. Customizing the State Machine VideoPlayer.PosterReady VideoPlayer.LoadVideo click play MyPlayer.PosterReady extends MyPlayer.Preroll click play preroll complete VideoPlayer Class MyPlayer Class
  • 26. Open-Source Framework Apache 2.0 License Commercial Cloud Video & Backend Support
  • 27. http://betajs.com Oliver Friedmann Founder & CTO, Ziggeo oliver@ziggeo.com