Difference between revisions of "BBB"

From CDOT Wiki
Jump to: navigation, search
(Releases)
(Releases)
 
(46 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 
== HTML 5 Open Video Player ==
 
== HTML 5 Open Video Player ==
  
The National Film Board of Canada is seeking to create an online video player using HTML5 and JavaScript.
+
The BBB is seeking to create an online video player using HTML5 and JavaScript.
  
 
== Project Description ==
 
== Project Description ==
  
The [http://www.nfb.ca/ National Film Board of Canada] is an agency of the Ministry of Canadian Heritage, and has been using Flash web technology to provide free viewings of their films online since January 2009. Inspired by [[PopcornOpenVideoAPI|Popcorn.js]] they are looking to develop a video player using HTML5 and JavaScript. Extending on the basic video capabilities of play/pause/stop/volume, this player will be skinnable for consistent viewing across web browsers, and a large focus will be placed on accessibility in the form of subtitles and screen reader compatibility as well as social networking interaction. Complete information can be seen at the NFB's [http://developer.nfb.ca/trac/web/wiki/NFBHTML5videoplayer developer centre].
+
Inspired by [[PopcornOpenVideoAPI|Popcorn.js]] the BBB is looking to develop a video player using HTML5 and JavaScript. Extending on the basic video capabilities of play/pause/stop/volume, this player will be skinnable for consistent viewing across web browsers, and a large focus will be placed on accessibility in the form of subtitles and screen reader compatibility as well as social networking interaction. Complete information can be seen at the BBB's [http://developer.nfb.ca/trac/web/wiki/NFBHTML5videoplayer developer centre].
  
 
== Project Leader(s) ==
 
== Project Leader(s) ==
Line 21: Line 21:
 
== Project Details ==
 
== Project Details ==
  
Below is a listing of project details copied from the [http://developer.nfb.ca/trac/web/wiki/NFBHTML5videoplayer NFB Developer Centre]. For information on the direction they wish to take the project, see [http://developer.nfb.ca/trac/web/wiki/NFBHTML5videoplayer#PAGEPLAYERINTERACTIONS here].
+
Below is a listing of project details.
  
 
===Core Fuctionality===
 
===Core Fuctionality===
Line 43: Line 43:
 
* JSON, AMF support to interact with the NFB video management environment.
 
* JSON, AMF support to interact with the NFB video management environment.
 
* Watermark overlay on the video.
 
* Watermark overlay on the video.
* Source hidding : Provide the user with an ObjectID in order to hide the real address of the film in order to prevent downloads.
+
* Source hiding : Provide the user with an ObjectID in order to hide the real address of the film in order to prevent downloads.
 
* Like feature. Within the player, users should have the ability to “like” a film. If the user is log in to the site, this features should populate his profile. If the user is not logged in, then it’s a simple add to build “most liked” film lists.
 
* Like feature. Within the player, users should have the ability to “like” a film. If the user is log in to the site, this features should populate his profile. If the user is not logged in, then it’s a simple add to build “most liked” film lists.
  
Line 63: Line 63:
 
** Video chapter playback
 
** Video chapter playback
 
** Sequential video chapter playback
 
** Sequential video chapter playback
** JSON Serialization for Bookmark objects
+
** JSON Serialization and Deserialization for Bookmark objects
 
** Dynamic DOM creation (Bookmark objects)
 
** Dynamic DOM creation (Bookmark objects)
** Working demo
+
** [http://matrix.senecac.on.ca/~kclascon/DPS909/BBB/Demos/demo.html Working demo]
 +
 
 +
* 0.2
 +
** TTXT-formatted subtitle support
 +
** Text suite framework
 +
** Remote retrieval of JSON-formatted chapter data
 +
** Simpler library interface
 +
** Watermark overlay
 +
** Statistics
 +
** Recommendations
 +
** HTML5 local storage support (experimental)
 +
* 0.3
 +
** Subtitle toggling
 +
** Time In/Out Buttons for setting bookmark times
 +
** Popcorn-formatted metadata generation
 +
** Drag and drop re-ordering of bookmarks
 +
** HTML5 Local storage
 +
** Re-factored watermark overlay
 +
** Fixed sequential bookmark play bug
 +
 
 +
 
 +
{| class="standard-table" border="1"
 +
|-
 +
|'''Functionality'''
 +
|'''Assigned To'''
 +
|'''GitHub Branch'''
 +
|'''Last Updated'''
 +
|'''Blog'''
 +
|'''Demo'''
 +
|-
 +
| TTXT Subtitle Parsing and Loading
 +
| Steven
 +
| [https://github.com/stevenaw/BBB/tree/TTXTSubs TTXTSubs]
 +
| November 10, 2010
 +
| [http://sweerdenburg.wordpress.com/2010/11/10/ttxt-subtitling-for-bbb-video-player/ Blog]
 +
| [http://matrix.senecac.on.ca/~sweerdenburg/Projects/DPS909/BBB/Demos/demoTTXT.html TTXT Demo]
 +
|-
 +
| Fix Event Overriding so that Video.js and BBB.js can respond to the same event
 +
| Steven
 +
| Seems to have resolved.
 +
| November 10, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~sweerdenburg/Projects/DPS909/BBB/Demos/demo.html Subtitling and Chapter Control both use timeupdate]
 +
|-
 +
| Reactor Library for JS Best Practices
 +
| Steven
 +
| [https://github.com/stevenaw/BBB/tree/RefactorToJSON RefactorToJSON]
 +
| November 10, 2010
 +
| [http://sweerdenburg.wordpress.com/2010/11/07/javascript-the-nitty-gritty/ Blog]
 +
| -
 +
|-
 +
| Test Suite Framework
 +
| Steven
 +
| [https://github.com/stevenaw/BBB/tree/testSuite testSuite]
 +
| November 10, 2010
 +
| [http://sweerdenburg.wordpress.com/2010/11/10/bbbtest-framework-skeleton/ Blog]
 +
| [http://matrix.senecac.on.ca/~sweerdenburg/Projects/DPS909/BBB/Tests/test.html Test Demos]
 +
|-
 +
| Remote Querying of Chapter Information (JSON formatted array)
 +
| Steven
 +
| [https://github.com/stevenaw/BBB/tree/remoteQuery remoteQuery]
 +
| November 13, 2010
 +
| [http://sweerdenburg.wordpress.com/2010/11/15/bbb-remote-bookmarks/ Blog]
 +
| [http://matrix.senecac.on.ca/~sweerdenburg/Projects/DPS909/BBB/Demos/demo.html Demo]
 +
|-
 +
| Add HTML5 local storage to BBB.js to simulate storage environment
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/html5Storage HTML5 storage]
 +
| November 14, 2010
 +
| WIP - will refactor later
 +
| -
 +
|-
 +
| Watermark overlay
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/rec Watermark overlay]
 +
| November 18, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.2/Demos/recDemo.html Demo]
 +
|-
 +
| Like Feature
 +
| Kevin
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Statistics
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/rec Statistics]
 +
| November 18, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.2/Demos/recDemo.html Demo]
 +
|-
 +
| Video recommendation
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/rec Video recommendation]
 +
| November 18, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.2/Demos/recDemo.html Demo]
 +
|-
 +
| [https://github.com/stevenaw/BBB/issues/issue/3 Fix: Need to distinguish subtitles by movie]
 +
| Steven
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Internationalization/Settings File
 +
| Steven
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Add/remove chapters hooked up to remote data source
 +
| Steven
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Toggleable Subtitles (functionality and stats)
 +
| Steven
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Keyboard Accessibility
 +
| Steven
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Re-factor 0.2 code
 +
| Kevin
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| Source Hiding
 +
| Kevin
 +
| -
 +
| -
 +
| -
 +
| -
 +
|-
 +
| HTML5 Local Storage (integration with storage module)
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/0.3B HTML5 Local Storage integration]
 +
| December 09, 2010
 +
| -
 +
|
 +
|-
 +
| Fix sequential order bug
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/0.3B Sequential Order Bug Resolved]
 +
| December 10, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.3B/BBB/Demos/fixedDemo.html Demo]
 +
|-
 +
| Re-factor watermark overlay
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/0.3B Watermark Overlay (Re-factored)]
 +
| December 13, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.3B/BBB/Demos/fixedDemo.html Demo]
 +
|-
 +
| Re-factor Drag and Drop Bookmark Ordering
 +
| Kevin
 +
| [https://github.com/klasconia/BBB/tree/0.3B Drag and Drop Bookmark Ordering (Re-factored)]
 +
| December 13, 2010
 +
| -
 +
| [http://matrix.senecac.on.ca/~kclascon/DPS909/demos/0.3B/BBB/Demos/orderDemo.html Demo]
 +
|}
  
 
== Source Code ==
 
== Source Code ==
 
* [http://github.com/klasconia/BBB GitHub] - Kevin
 
* [http://github.com/klasconia/BBB GitHub] - Kevin
 
* [http://github.com/stevenaw/BBB GitHub] - Steven
 
* [http://github.com/stevenaw/BBB GitHub] - Steven
 +
 +
== Lighthouse Account ==
 +
* [https://webmademovies.lighthouseapp.com/projects/64427-bbb/overview BBB]
  
 
== Project News ==
 
== Project News ==
  
* '''10/22/10''' - Release 0.1  
+
* '''10/22/10''' - Release 0.1
 
+
* '''11/16/10''' - Release 0.2
 +
* '''12/08/10 & 12/15/10''' - Release 0.3
 
<!-- Put detailed technical information into the Project Details page (i.e., update it as you go), and save this section for news about participation in the project. -->
 
<!-- Put detailed technical information into the Project Details page (i.e., update it as you go), and save this section for news about participation in the project. -->

Latest revision as of 18:25, 15 December 2010

HTML 5 Open Video Player

The BBB is seeking to create an online video player using HTML5 and JavaScript.

Project Description

Inspired by Popcorn.js the BBB is looking to develop a video player using HTML5 and JavaScript. Extending on the basic video capabilities of play/pause/stop/volume, this player will be skinnable for consistent viewing across web browsers, and a large focus will be placed on accessibility in the form of subtitles and screen reader compatibility as well as social networking interaction. Complete information can be seen at the BBB's developer centre.

Project Leader(s)

Project Contributor(s)

TBA

Project Details

Below is a listing of project details.

Core Fuctionality

  • Play/Pause/Stop
  • Variable Volume/Mute
  • Seeking, visible time codes, total duration
  • Flash fallback if HTML5 is not fully supported
  • Player resizing, ability for fullscreen
  • Multiple codec support (mp4/h264, vp6), browser dependant?
  • Completely customizable visuals through CSS
  • Accessibility (Keyboard-only, screen-reader support)
  • Internationalization (driven from config file)

Extensible Required Features

  • Ratings (mature content, violence, sexuality)
  • Support multiple streaming methods (rtmp, rtmpt, rtsp, http)
  • Support multiple streaming speeds (low, medium, high)
  • Subtitles support in TTXT
  • Audio description playback – detect the MP4 audio track specific to Audio description
  • Statistics : IP, onLoad, start, reached 25%, 50%, 75%, 90%, 100%, CC_ON, CC_OFF, AD_ON, AD_OFF (must be sent to NFB server)
  • JSON, AMF support to interact with the NFB video management environment.
  • Watermark overlay on the video.
  • Source hiding : Provide the user with an ObjectID in order to hide the real address of the film in order to prevent downloads.
  • Like feature. Within the player, users should have the ability to “like” a film. If the user is log in to the site, this features should populate his profile. If the user is not logged in, then it’s a simple add to build “most liked” film lists.

Optional Features

  • Message overlay on load, pause/stop, end
  • Message overlay at specific in and out point
  • Recommendation at 90% of the film: once the film reaches the 90% mark, related films should be suggested with thumbnails, titles and duration. This needs to appear as a layer over the video
  • Follow feature: The follow features means the user will be notified every time there is a comment on the film. This should be linked to the user profile, hence the user must be authenticated.
  • Google translation: Give users the ability to get the machine translation from Google based on the subtitles of the film.

Page & Player Interaction

  • Visual bookmarking
  • Video chaptering
  • Video assembly from multiple chapters of multiple videos

Releases

  • 0.1
    • Video chapter creation
    • Video chapter playback
    • Sequential video chapter playback
    • JSON Serialization and Deserialization for Bookmark objects
    • Dynamic DOM creation (Bookmark objects)
    • Working demo
  • 0.2
    • TTXT-formatted subtitle support
    • Text suite framework
    • Remote retrieval of JSON-formatted chapter data
    • Simpler library interface
    • Watermark overlay
    • Statistics
    • Recommendations
    • HTML5 local storage support (experimental)
  • 0.3
    • Subtitle toggling
    • Time In/Out Buttons for setting bookmark times
    • Popcorn-formatted metadata generation
    • Drag and drop re-ordering of bookmarks
    • HTML5 Local storage
    • Re-factored watermark overlay
    • Fixed sequential bookmark play bug


Functionality Assigned To GitHub Branch Last Updated Blog Demo
TTXT Subtitle Parsing and Loading Steven TTXTSubs November 10, 2010 Blog TTXT Demo
Fix Event Overriding so that Video.js and BBB.js can respond to the same event Steven Seems to have resolved. November 10, 2010 - Subtitling and Chapter Control both use timeupdate
Reactor Library for JS Best Practices Steven RefactorToJSON November 10, 2010 Blog -
Test Suite Framework Steven testSuite November 10, 2010 Blog Test Demos
Remote Querying of Chapter Information (JSON formatted array) Steven remoteQuery November 13, 2010 Blog Demo
Add HTML5 local storage to BBB.js to simulate storage environment Kevin HTML5 storage November 14, 2010 WIP - will refactor later -
Watermark overlay Kevin Watermark overlay November 18, 2010 - Demo
Like Feature Kevin - - - -
Statistics Kevin Statistics November 18, 2010 - Demo
Video recommendation Kevin Video recommendation November 18, 2010 - Demo
Fix: Need to distinguish subtitles by movie Steven - - - -
Internationalization/Settings File Steven - - - -
Add/remove chapters hooked up to remote data source Steven - - - -
Toggleable Subtitles (functionality and stats) Steven - - - -
Keyboard Accessibility Steven - - - -
Re-factor 0.2 code Kevin - - - -
Source Hiding Kevin - - - -
HTML5 Local Storage (integration with storage module) Kevin HTML5 Local Storage integration December 09, 2010 -
Fix sequential order bug Kevin Sequential Order Bug Resolved December 10, 2010 - Demo
Re-factor watermark overlay Kevin Watermark Overlay (Re-factored) December 13, 2010 - Demo
Re-factor Drag and Drop Bookmark Ordering Kevin Drag and Drop Bookmark Ordering (Re-factored) December 13, 2010 - Demo

Source Code

Lighthouse Account

Project News

  • 10/22/10 - Release 0.1
  • 11/16/10 - Release 0.2
  • 12/08/10 & 12/15/10 - Release 0.3