ts-ebml
ebml encoder and decoder written in TypeScript.
Fork of node-ebml
It is a fork of https://github.com/themasch/node-ebml
install
npm install ts-ebml --save
usage
show EBML structure on conosle
$ ts-ebml foo.webm0 m 0 EBML5 u 1 EBMLVersion 19 u 1 EBMLReadVersion 113 u 1 EBMLMaxIDLength 417 u 1 EBMLMaxSizeLength 821 s 1 DocType webm28 u 1 DocTypeVersion 232 u 1 DocTypeReadVersion 236 m 0 Segment48 m 1 Info53 u 2 TimecodeScale 1000000...
node
;; ; fs.createReadStream'media/test.webm'.on'data',;
browser
; ; fetch'media/test.webm' .thenres.arrayBuffer .then;
features
- get WebP frame from MediaRecorder WebM VP8 Stream
- create seekable webm from media-recoder
- create playable webm to media-stream-api from media-recorder
see src/test.ts
and src/example_seekable.ts
stable API
;; ;;;;
develop
npm run setup # install cli tools npm run init # install libraries npm run build # build js code npm run lint # tslint npm run doc # typedoc npm run check # type check npm run test # build test npm run example # build example
debugging tools
- https://www.matroska.org/downloads/mkvalidator.html
- https://www.matroska.org/downloads/mkclean.html
- https://mkvtoolnix.download/doc/mkvinfo.html
- https://github.com/Matroska-Org/matroska-test-files
MOZ_LOG_FILE="log.txt" MOZ_LOG="MediaDemuxer:5" /Applications/FirefoxNightly.app/Contents/MacOS/firefox-bin
MOZ_LOG_FILE="log.txt" MOZ_LOG="MediaDemuxer:5" /Applications/Firefox.app/Contents/MacOS/firefox-bin
- chrome://media-internals/
- chrome://webrtc-internals/
- ./out/gn/Chromium.app/Contents/MacOS/Chromium -vmodule="video=0,ffmpeg=1,media=1" https://webrtc.github.io/samples/src/content/getusermedia/record/
ffmpeg -i not_seekable.webm -c copy seekable.webm
mkclean --doctype 4 --keep-cues --optimize not_seekable.webm seekable.webm
webm_info -a foo.webm
- https://chromium.googlesource.com/webm/libwebm
license
MIT
related info
- https://www.matroska.org/technical/specs/index.html
- https://www.matroska.org/technical/specs/notes.html
- https://www.matroska.org/technical/order/index.html
related issues
media recorder seekable webm
chrome
- MediaRecorder output should have Cues element - https://bugs.chromium.org/p/chromium/issues/detail?id=561606
- Videos created with MediaRecorder API are not seekable / scrubbable - https://bugs.chromium.org/p/chromium/issues/detail?id=569840
- No duration or seeking cue for opus audio produced with mediarecoder - https://bugs.chromium.org/p/chromium/issues/detail?id=599134
- MediaRecorder: consider producing seekable WebM files - https://bugs.chromium.org/p/chromium/issues/detail?id=642012
firefox
- Seeking in WebM files with no Cues element is not supported - https://bugzilla.mozilla.org/show_bug.cgi?id=657791
- Recorder video clips result can't replay /seekable on firefox - https://bugzilla.mozilla.org/show_bug.cgi?id=969290
others
- Optimizing WebM Video for Faster Streaming and Seeking - https://rigor.com/blog/2016/02/optimizing-webm-video-for-faster-streaming-and-seeking
- Creation of Seekable Files - https://github.com/w3c/mediacapture-record/issues/119
media recorder media source gap
chrome
- MediaSource api not able to play webm video recorded from MediaRecorder - https://bugs.chromium.org/p/chromium/issues/detail?id=606000
- Video playback freezes using MediaSource API (MSE) - https://bugs.chromium.org/p/chromium/issues/detail?id=678269
- MediaSource API: Appending chunks to a SourceBuffer creates gaps and playback stops - https://bugs.chromium.org/p/chromium/issues/detail?id=688490
- Playback of video segments freezes with errors in media-internals - https://bugs.chromium.org/p/chromium/issues/detail?id=711829
others
chrome
- Regression: Playback of mediaStream recording shows blank video - https://bugs.chromium.org/p/chromium/issues/detail?id=657532
firefox
- Webm video recorded with MediaRecorder cannot be played more than once - https://bugzilla.mozilla.org/show_bug.cgi?id=1272371
related works
- https://github.com/antimatter15/js-ebml
- https://bitbucket.org/desmaj/libvpx.js/src/1ea3218282b6eb129061341831d23409dd539054/webm.js
- https://github.com/themasch/node-ebml
- https://github.com/oeuillot/node-matroska
- https://github.com/eadle/webm-byte-stream
- https://github.com/mafintosh/webm-cluster-stream
- https://github.com/Matroska-Org/libebml/
- https://github.com/Matroska-Org/foundation-source
- https://github.com/webmproject/libwebm
- https://chromium.googlesource.com/webm/libvpx/+/master/third_party/libwebm
- https://github.com/mozilla/gecko-dev/tree/master/dom/media/webm
- https://github.com/yellowdoge/libwebm