微信搜索superit|邀请体验:大数据, 数据管理、OLAP分析与可视化平台 | 赞助作者:赞助作者

ffmpeg视频切片mp4转m3u8

ffmpeg aide_941 26℃

1、安装ffmpeg

brew install ffmpeg
  1. 安装ffmpeg依赖
    查看安装信息

    brew info ffmpeg

会显示依赖安装情况❌ 表示未安装

brew install 需要安装的依赖
  1. 视频转换
    查看视频信息,只有视频编码h.264,音频编码aac的mp4视频可以转m3u8

    ffprobe trailer.mp4(视频文件+后缀 我的源文件就是mp4)

显示如下信息
ffprobe version 3.4 Copyright (c) 2007-2017 the FFmpeg developers
built with Apple LLVM version 9.0.0 (clang-900.0.37)
configuration: –prefix=/usr/local/Cellar/ffmpeg/3.4 –enable-shared –enable-pthreads –enable-version3 –enable-hardcoded-tables –enable-avresample –cc=clang — host-cflags= –host-ldflags= –enable-gpl –enable-libmp3lame –enable-libx264 –enable-libxvid –enable-opencl –enable-videotoolbox –disable-lzma
libavutil 55. 78.100 / 55. 78.100
libavcodec 57.107.100 / 57.107.100
libavformat 57. 83.100 / 57. 83.100
libavdevice 57. 10.100 / 57. 10.100
libavfilter 6.107.100 / 6.107.100
libavresample 3. 7. 0 / 3. 7. 0
libswscale 4. 8.100 / 4. 8.100
libswresample 2. 9.100 / 2. 9.100
libpostproc 54. 7.100 / 54. 7.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from ‘trailer.mp4’:
Metadata:
major_brand : mp42
minor_version : 0
compatible_brands: mp42mp41
creation_time : 2017-11-27T13:16:02.000000Z
Duration: 00:04:02.47, start: 0.000000, bitrate: 10342 kb/s
Stream #0:0(eng): Video: h264 (Main) (avc1 / 0x31637661), yuv420p(tv, bt709), 1920×1080, 10018 kb/s, 25 fps, 25 tbr, 25k tbn, 50 tbc (default)
Metadata:
creation_time : 2017-11-27T13:16:02.000000Z
handler_name : Alias Data Handler
encoder : AVC Coding
Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 317 kb/s (default)
Metadata:
creation_time : 2017-11-27T13:16:02.000000Z
handler_name : Alias Data Handler

视频转mp4

ffmpeg -i 视频源文件.后缀 -acodec copy -vcodec copy out.mp4

视频如果太大可以压缩

ffmpeg -i input_file -s 320x240 output_file

分辨率自己看着改
mp4转ts

ffmpeg -i out.mp4 -c copy -bsf:v h264_mp4toannexb output.ts

视频切片

ffmpeg -i output.ts -c copy -map 0 -f segment -segment_list playlist.m3u8 -segment_time 5 output%03d.ts

命令里边的5为每段视频5秒,可自行调整,完成之后会生成一个playlist.m3u8和一堆.ts,切片到这里就完成了。
4. 页面插入视频
试了两种方式
一种是video.js + videojs-contrib-hls.js
这种方式不兼容IE10-
video.js
videojs-contrib-hls

<video id=example-video width=960 height=540 class="video-js vjs-default-skin" controls>
        <source src="./video/playlist.m3u8" type="application/x-mpegURL">
</video>
<script src="video.js"></script>
<script src="videojs.hls.min.js"></script>
<script>
        var player = videojs('example-video');
        player.play();
</script>

另一种方式用ckplayer
官网:http://www.ckplayer.com/
下载之后解压找到crossdomain.xml和ckplayer文件夹放到根目录下

<script type="text/javascript" src="ckplayer/ckplayer.js"></script>
    <div id="video" style="width:600px;height:400px;"></div>
    <script>
            var videoObject = {
                    container:'#video',
                    variable:'player',
                    autoplay:true, //强制使用ckplay做播放器
                    video:'./video/playlist.m3u8'
            };
            var player=new ckplayer(videoObject);
    <script>

视频会带ckplay的水印,但是不影响。

转载请注明:SuperIT » ffmpeg视频切片mp4转m3u8

喜欢 (0)or分享 (0)