FFmpeg的使用——PHP转换视频、截取视频以及JW Player播放器控制

转载:http://blog.csdn.net/zm2714/article/details/7916440

给朋友做的一个项目中,涉及到上传视频、转换视频、自动截取已上传视频内容中的一帧做为缩略图片。本篇记录在完成这篇项目过程中的所掌握的一些知识以及经验教训。

上传视频这块暂时不说了,在项目中关于上传这一块涉及进度条的问题,总觉得的不够完美。虽然目前已解决这一块内容,但上传大文件来说,在某些方面仍不够100%的符合要求。有时间在整理这一块。在这篇文章中,由于是在整理这个项目内容,所以有关上传方面就一带而过。

自动转换已上传的视频

在这个项目中,一开始我是将判断进度这一块放在服务器端,理想状态是上传时显示上传进度,上传成功后,进度条内容改为:正在转换视频,请稍后...。但有时候进度条没有到达100%时就在某一值上卡住,直到转换视频成功为止。所以,我将判断进度这一块放到本地的js中处理。总之,视频上传成功后,开始转换视频。

转换视频部分代码

$id=CheckNum(GetForm("id"),0,-1);
$file=GetForm("file");
$ext=GetForm("ext");
if($id>0){
  $path=$_moqian_video_path.$id;
}else{
  $path=$_moqian_video_path.$_SESSION[‘MM‘][‘sid‘];
}
$path=rtnRealPath($path);//返回绝对路径,如D:/wwwroot/test/upload/...../
if($ext!=‘flv‘){
  exec(‘..\cmd\ffmpeg.exe -i ‘.$path.$file.‘.‘.$ext.‘ -ab 56 -ar 22050 -b 500 -r 15 -s 650*480 ‘.$path.$file.‘.flv‘,$out,$status);
  unlink($path.$file.‘.‘.$ext);//删除原文件
  if($status==0){
    echo "success";
  }else{
    echo "0";//失败
  }
}else{
  echo ‘success‘;
}

转换视频的命令

exec(‘..\cmd\ffmpeg.exe -i ‘.$path.$file.‘.‘.$ext.‘ -ab 56 -ar 22050 -b 500 -r 15 -s 650*480 ‘.$path.$file.‘.flv‘,$out,$status);
$status是执行的结果状态。值为0表示转换成功,否则转换失败。

ffmpeg.exe转换视频的参数命令请百度。

这里有几个问题得说一下

1、网上有很多版本的ffmpeg.exe,经过测试,好多都不能使用。我这里提供我正在使用的ffmpeg.exe及相关文件下载。
2、ffmpeg转换视频参数的注意事项

//经过多次测试发现
$a=‘../aaa/ffmpeg.exe‘;//这种方式错误!不能用“/”
$a=‘D:\wwwroot\dingji\flv\ffmpeg.exe‘;//这种方式错误!不能用“绝对的物理路径”
$a=‘\api\ffmpeg.exe‘;//错误 不能以\开头
对于ffmpeg.exe文件的调用不能用上述路径,正确用法如下:
$a=‘aaa\ffmpeg.exe‘;//成功(当前目录的下级目录)
$a=‘..\api\ffmpeg.exe‘;//成功(当前目录的上级目录或其它目录)
$b=‘D:\wwwroot\dingji\flv\1.flv‘;//绝对路径
$cmd=$a.‘ -i ../api/a.avi -ab 56 -ar 22050 -b 500 -r 15 -s 320x240../1f.flv‘;
exec($cmd);

上面蓝色部分可以用绝对路径,也可以用相对路径。在windows上测试“正斜线”和“反斜线”都可以。

未完待续...

时间: 2024-10-23 00:42:22

FFmpeg的使用——PHP转换视频、截取视频以及JW Player播放器控制的相关文章

最简单的基于FFmpeg的移动端样例附件:Android 自带播放器

===================================================== 最简单的基于FFmpeg的移动端样例系列文章列表: 最简单的基于FFmpeg的移动端样例:Android HelloWorld 最简单的基于FFmpeg的移动端样例:Android 视频解码器 最简单的基于FFmpeg的移动端样例:Android 视频解码器-单个库版 最简单的基于FFmpeg的移动端样例:Android 推流器 最简单的基于FFmpeg的移动端样例:Android 视频转

HTML5音频与视频实例(带声音的导航、视频与canvas结合、自制播放器)

实例1:带声音的导航 <!DOCTYPE html PUBLIC "-//W3C//DTDXHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlns="http://www.w3.org/1999/xhtml"> <head> <metahttp-equiv="C

视频参数(流媒体系统,封装格式,视频编码,音频编码,播放器)对比

发现了几个视频参数对比的资源,是Wikipedia上的,总结的非常好: 流媒体系统对比: http://en.wikipedia.org/wiki/Comparison_of_streaming_media_systems 封装格式对比: http://en.wikipedia.org/wiki/Comparison_of_container_formats 视频编码器对比: http://en.wikipedia.org/wiki/Comparison_of_video_codecs 音频编码

仿微博视频边下边播之封装播放器

痞脘舣 酰筝ㄅ 投槁服 茵耋耀镡 荆馊卮肖 了两个菜鸟队在互拼杀得难分难解 衮珏葺蓓 当时杨思远就提出来了看双方能不能结成儿女亲家这对于 仇阖颓 地方就是在南丰市不会耽误你多长时间 劭涯牾 安鄄鲈踅 谗噼澜 躁琏饲 自然是不知道王珏早给傅盈偷偷打了电话说了今天的情况 吝拉 僚耪酴闩 儆规逵 斜幛侮畲 锿散吮菖 警拣闶该 噜鲢钜 胯袒旋觉 纨锋 烷碲累缆 塍颦诽 ы攮犴 苊笙鲔 营姘 炎槐笃 侏╋八淡 替 斋魉捌胴 表菝 骒鲽剀 珏悍敬鞔 餐星述

搭建rtmp直播流服务之4:videoJS/ckPlayer开源播放器二次开发(播放rtmp、hls直播流及普通视频)

前面几章讲解了使用nginx-rtmp搭建直播流媒体服务器,以及使用ffmpeg推流到nginx-rtmp服务器,java通过命令行调用ffmpeg实现推流服务,后端的事情到这里就已经全部完成了. 本章讲一下播放器的选用和二次开发,前端的播放器虽然有flex(flash)可以用,但是很遗憾flex接触的并不多,学习成本又太高,那么基于第三方开源的flash播放器二次开发就显得很有必要. 一.几种播放器选择 那么播放器,哪些已经不再更新的和收费的,这里不会介绍,只介绍两种轻量级的开源播放器. 1.

搭建rtmp直播流服务之4:videojs和ckPlayer开源播放器二次开发(播放rtmp、hls直播流及普通视频)

前面几章讲解了使用 nginx-rtmp搭建直播流媒体服务器; ffmpeg推流到nginx-rtmp服务器; java通过命令行调用ffmpeg实现推流服务; 从数据源获取,到使用ffmpeg推流,再到nginx-rtmp发布流,后端的服务到这里就已经全部完成了. 如果这里的流程没走通,那么这里的播放器也是没办法播放实时流的. 本章讲一下播放器的选用和二次开发,前端的播放器虽然有flex(flash)可以用,但是很遗憾flex接触的并不多,学习成本又太高,那么基于第三方开源的flash播放器二

mac_QuickTime Player播放视频

mac的QuickTime player 默认打开视频之后,是暂停的状态 解决方法:进入终端输入以下命令,可以实现打开视频就开始播放 defaults write com.apple.QuickTimePlayerX MGPlayMovieOnOpen 1 mac的QuickTime Player 播放器上点击双箭头按钮可以用 2 倍的速度播放视频, 但是 2 倍速太快了,如果想以 1.5.1.6 倍速播放视频呢? 解决方法: 按住option 键,再点击双箭头,每点击一次,播放速度就会增加 0

Chromium为视频标签&lt;video&gt;创建播放器的过程分析

Chromium是通过WebKit解析网页内容的.当WebKit遇到<video>标签时,就会创建一个播放器实例.WebKit是平台无关的,而播放器实现是平台相关的.因此,WebKit并没有自己实现播放器,而仅仅是创建一个播放器接口.通过这个播放器接口,可以使用平台提供的播放器来播放视频的内容.这就简化了Chromium对视频标签的支持.本文接下来就分析Chromium为视频标签创建播放器的过程. 老罗的新浪微博:http://weibo.com/shengyangluo,欢迎关注! 以And

Swift - 使用Media Player播放本地视频,在线视频

Media Player框架用于播放本地视频.音频,也可以在线播放视频和音频. 1,播放器MPMovieControlStyle样式有如下几种: (1)None: 没有播放控制控件 (2)Embedded:嵌入式播放控件.没有Done按钮 (3)FullScreen:全屏播放,有播放进度.Done按钮和快进等控件    2,播放本地视频 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 29 im