Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

PGS (Presentation Graphic Stream) Subtitle For Media Playback

License

NotificationsYou must be signed in to change notification settings

monyone/pgs.js

Repository files navigation

Feature

  • HTML5 Canvas based PGS (Presentation Graphic Stream) rendering

Options

PGSController

exporttypePGSControllerOption={renderOption:{preferHTMLCanvasElement:boolean;// preffer HTMLCanvasElement in Main Thread. (default: false, recommended firefox is true)webWorker:boolean;// use WebWorker for rendering (default: false)}}

PGSSupFeeder/PGSAsyncSupFeeder

exporttypePGSSupFeederOption={timeshift:number;// offset for time (default: 0)preload:'none'|'decode'|'render';// prelodd rgba data (default: none)}

Getting Started

Requirements: Wrapping Relative Element Needed!

<divstyle="position: relative; display: inline-block;"><!-- This Relative Wrapping Needed! --><videoid="video"></video></div>

Work with SUP file (sync)

<scripttype="module">import{PGSController,PGSSupFeeder}from"pgs.js";constres=awaitfetch('./something.sup');constsup=awaitres.arrayBuffer();constvideo=document.getElementById('video');constcontroller=newPGSController();constfeeder=newPGSSupFeeder(sup);controller.attachFeeder(feeder);controller.attachMedia(video)</script>

Work with SUP file (async)

<scripttype="module">import{PGSController,PGSAsyncSupFeeder}from"pgs.js";constres=awaitfetch('./something.sup');constvideo=document.getElementById('video');constcontroller=newPGSController();constfeeder=newPGSAsyncSupFeeder(res.body);// use `feeder.done` for wait loadingcontroller.attachFeeder(feeder);controller.attachMedia(video)</script>

Work with M2TS

<scripttype="module">import{PGSController,PGSMpegTsFeeder}from"pgs.js";constvideo=document.getElementById('video');constcontroller=newPGSController();constfeeder=newPGSMpegTsFeeder();// call `feeder.feed(arraybuffer, pts, dts, timescale)` for insert PEScontroller.attachFeeder(feeder);controller.attachMedia(video)</script>

Build

yarnyarn build

About

PGS (Presentation Graphic Stream) Subtitle For Media Playback

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

[8]ページ先頭

©2009-2025 Movatter.jp