JSMpeg的使用

JavaScript3年前 (2021)发布 小马大哥哥
569 0 0

JSMpeg是JS写的视频、音频解码器,能使用WebGL&Canvas2D渲染以及WebAudio声音输出。

1.官网:https://jsmpeg.com/

github:https://github.com/phoboslab/jsmpeg

官方例子:https://jsmpeg.com/perf.html

 

2.简单例子

<canvas id="video" width="667" height="375"></canvas>
<script type="text/javascript" src="jsmpeg.min.js"></script>
<script>
var player = new JSMpeg.Player('test.ts', {
    canvas: document.getElementById('video'),
    decodeFirstFrame: true,
    disableWebAssembly: false,
    throttled: false, //这里设置为false,不然不触发onSourceCompleted事件
    chunkSize: 4 * 1024 * 1024,
    disableGl: false,
    audio: true,
    autoplay:true,
    loop:false,
    onSourceCompleted:()=>{
    }
});
player.play();
</script>

3.注意事项

①需要转换为特定的格式,比如将mp4文件进行转换:

ffmpeg -i in.mp4 -f mpegts \
    -codec:v mpeg1video -s 960x540 -b:v 1500k -r 30 -bf 0 \
    -codec:a mp2 -ar 44100 -ac 1 -b:a 128k \
    out.ts

②IOS声音问题:IOS播放时默认没有声音,需要用户点击后才能发声(相当于获得用户允许后才能发声)。解决方案就是在启动时增加一个开始按钮或者增加一个音量已关闭的按钮,让用户点击时解锁声音。

function onUnlocked () {
    player.volume = 1
    document.removeEventListener('touchstart', onTouchStart)
}
function onTouchStart () {
    player.audioOut.unlock(onUnlocked)
    document.removeEventListener('touchstart', onTouchStart)
}

// try to unlock immediately
player.audioOut.unlock(onUnlocked)

// try to unlock by touchstart event
document.addEventListener('touchstart', onTouchStart, false)
© 版权声明

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...