视频切片转m3u8

1、安装ffmpeg

1
brew install ffmpeg

2. 安装ffmpeg依赖

查看安装信息

1
brew info ffmpeg

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

1
brew install 需要安装的依赖

3. 视频转换

查看视频信息,只有视频编码h.264,音频编码aac的mp4视频可以转m3u8

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

显示如下信息

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 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), 1920x1080, 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

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

视频如果太大可以压缩

1
ffmpeg -i input_file -s 320x240 output_file

分辨率自己看着改

mp4转ts

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

视频切片

1
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.xmlckplayer文件夹放到根目录下

<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的水印,但是不影响。

  • © 2020-02 MonkeyInWind
  • GitHub

请我喝杯咖啡吧~