wherewhat / php-ffmpeg
FFMpeg PHP,一个用于与 AVconv / ffmpeg 通信的面向对象库
Requires
- php: >=5.3.3
- alchemy/binary-driver: ~1.5
- doctrine/cache: ~1.0
- evenement/evenement: ~1.0
- neutron/temporary-filesystem: ~2.1, >=2.1.1
Requires (Dev)
- phpunit/phpunit: ~3.7
- sami/sami: ~1.0
- silex/silex: ~1.0
Suggests
- php-ffmpeg/extras: A compilation of common audio & video drivers for PHP-FFMpeg
This package is not auto-updated.
Last update: 2024-09-23 16:36:56 UTC
README
#PHP FFmpeg
一个用于使用 FFmpeg / AVConv 转换视频/音频文件的面向对象库。
请注意:请查看另一个令人惊叹的存储库: PHP FFMpeg extras,您将在这里找到大量的音频/视频格式。
请注意
此库的工作原理
此库需要安装正常工作的 FFMpeg。您将需要 FFMpeg 和 FFProbe 的二进制文件才能使用它。请确保这些二进制文件可以通过系统 PATH 定位,以便利用二进制检测的好处,否则您必须在加载时明确给出二进制文件的路径。
对于 Windows 用户:请从以下链接找到二进制文件:http://ffmpeg.zeranoe.com/builds/。
已知问题
- 当使用 libav 0.8 时,使用旋转和缩放将产生损坏的输出。此错误已在版本 9 中修复。此错误在最新的 ffmpeg 版本中不会出现。
安装
安装 PHP-FFMpeg 的推荐方法是使用 Composer。
{ "require": { "php-ffmpeg/php-ffmpeg": "~0.5" } }
基本用法
$ffmpeg = FFMpeg\FFMpeg::create(); $video = $ffmpeg->open('video.mpg'); $video ->filters() ->resize(new FFMpeg\Coordinate\Dimension(320, 240)) ->synchronize(); $video ->frame(FFMpeg\Coordinate\TimeCode::fromSeconds(10)) ->save('frame.jpg'); $video ->save(new FFMpeg\Format\Video\X264(), 'export-x264.mp4') ->save(new FFMpeg\Format\Video\WMV(), 'export-wmv.wmv') ->save(new FFMpeg\Format\Video\WebM(), 'export-webm.webm');
文档
此文档是发现 API 的介绍。建议浏览源代码,因为它有自我文档化的功能。
FFMpeg
FFMpeg\FFMpeg
是用于操作媒体的主要对象。要构建它,请使用静态 FFMpeg\FFMpeg::create
$ffmpeg = FFMpeg\FFMpeg::create();
FFMpeg 将自动检测 ffmpeg 和 ffprobe 的二进制文件。如果您想明确地给出二进制文件的路径,可以传递一个数组作为配置。也可以传递一个 Psr\Logger\LoggerInterface
以记录二进制执行。
$ffmpeg = FFMpeg\FFMpeg::create(array( 'ffmpeg.binaries' => '/opt/local/ffmpeg/bin/ffmpeg', 'ffprobe.binaries' => '/opt/local/ffmpeg/bin/ffprobe', 'timeout' => 3600, // The timeout for the underlying process 'ffmpeg.threads' => 12, // The number of threads that FFMpeg should use ), $logger);
操作媒体
FFMpeg\FFMpeg
根据 URI 创建媒体。URI 可以是本地文件系统资源的指针、HTTP 资源或 FFmpeg 支持的任何资源。
注意:要列出您构建的 FFmpeg 所支持的资源类型,请使用 -protocols
命令
ffmpeg -protocols
要打开资源,请使用 FFMpeg\FFMpeg::open
方法。
$ffmpeg->open('video.mpeg');
可以解析两种类型的媒体:FFMpeg\Media\Audio
和 FFMpeg\Media\Video
。第三种类型 FFMpeg\Media\Frame
通过视频提供。
视频
FFMpeg\Media\Video
可以进行转码,即:更改编解码器、提取音频或视频。可以提取帧。
转码
您可以使用 FFMpeg\Media\Video:save
方法进行视频转码。您将传递一个 FFMpeg\Format\FormatInterface
。
请注意,音频和视频比特率在格式中设置。
$format = new Format\Video\X264(); $format->on('progress', function ($video, $format, $percentage) { echo "$percentage % transcoded"; }); $format -> setKiloBitrate(1000) -> setAudioChannels(2) -> setAudioKiloBitrate(256); $video->save($format, 'video.avi');
实时监控转码进度,请参阅下面的格式文档以获取更多信息。
提取图像
您可以使用 FFMpeg\Media\Video::frame
方法在任意时间码处提取一个帧。
此代码返回一个对应于第 42 秒的 FFMpeg\Media\Frame
实例。您可以传递任何 FFMpeg\Coordinate\TimeCode
作为参数,请参阅下面的专用文档以获取更多信息。
$frame = $video->frame(FFMpeg\Coordinate\TimeCode::fromSeconds(42)); $frame->save('image.jpg');
过滤器
您可以使用 FFMpeg\Media\Video::addFilter
方法在 FFMpeg\Media\Video
上应用过滤器。视频接受音频和视频过滤器。
您可以构建自己的过滤器,PHP-FFMpeg 中包含了一些过滤器,它们可以通过 FFMpeg\Media\Video::filters
方法访问。
过滤器是可链的
$video ->filters() ->resize($dimension, $mode, $useStandards) ->framerate($framerate, $gop) ->synchronize();
旋转
将视频旋转到指定的角度。
$video->filters()->rotate($angle);
$angle
参数必须是以下常量之一
FFMpeg\Filters\Video\RotateFilter::ROTATE_90
:顺时针 90°FFMpeg\Filters\Video\RotateFilter::ROTATE_180
:180°FFMpeg\Filters\Video\RotateFilter::ROTATE_270
: 顺时针旋转 270°
调整大小
将视频调整到指定大小。
$video->filters()->resize($dimension, $mode, $useStandards);
调整大小过滤器接受三个参数
$dimension
,一个FFMpeg\Coordinate\Dimension
实例$mode
,FFMpeg\Filters\Video\ResizeFilter::RESIZEMODE_*
常量之一$useStandards
,一个布尔值,用于强制使用最接近的宽高比标准。
水印
使用指定图像水印视频。
$video ->filters() ->watermark($watermarkPath, array( 'position' => 'relative', 'bottom' => 50, 'right' => 50, ));
水印过滤器接受两个参数
$watermarkPath
,水印文件的路径。 $coordinates
,一个数组,定义了您想要水印的位置。您可以使用如上所示的相对定位或绝对定位
$video ->filters() ->watermark($watermarkPath, array( 'position' => 'absolute', 'x' => 1180, 'y' => 620, ));
帧率
更改视频的帧率。
$video->filters()->framerate($framerate, $gop);
帧率过滤器接受两个参数
$framerate
,一个FFMpeg\Coordinate\Framerate
实例$gop
,一个 GOP 值(整数)
同步
同步音频和视频。
某些容器可能使用导致输出不同步的延迟。此过滤器解决了此问题。
$video->filters()->synchronize();
剪辑
在所需点剪辑视频。
$video->filters()->clip(FFMpeg\Coordinate\TimeCode::fromSeconds(30), FFMpeg\Coordinate\TimeCode::fromSeconds(15));
剪辑过滤器接受两个参数
$start
,一个FFMpeg\Coordinate\TimeCode
实例,指定剪辑的起点$duration
,可选,一个FFMpeg\Coordinate\TimeCode
实例,指定剪辑的持续时间
音频
FFMpeg\Media\Audio
可以进行转码,即:更改编解码器、提取音频或视频。可以提取帧。
转码
您可以使用 FFMpeg\Media\Audio:save
方法转码音频。您将传递一个 FFMpeg\Format\FormatInterface
。
请注意,音频千比特率在音频格式中设置。
$ffmpeg = FFMpeg\FFMpeg::create(); $audio = $ffmpeg->open('track.mp3'); $format = new FFMpeg\Format\Audio\Flac(); $format->on('progress', function ($audio, $format, $percentage) { echo "$percentage % transcoded"; }); $format -> setAudioChannels(2) -> setAudioKiloBitrate(256); $audio->save($format, 'track.flac');
实时监控转码进度,请参阅下面的格式文档以获取更多信息。
过滤器
您可以使用 FFMpeg\Media\Audio::addFilter
方法在 FFMpeg\Media\Audio
上应用过滤器。它只接受音频过滤器。
您可以构建自己的过滤器,PHP-FFMpeg 中包含一些。它们可以通过 FFMpeg\Media\Audio::filters
方法访问。
重采样
重采样音频文件。
$audio->filters()->resample($rate);
重采样过滤器接受两个参数
$rate
,一个有效的音频采样率值(整数)
帧
帧是视频在特定时间码处的图像;请参阅关于帧提取的上述文档。
您可以使用 FFMpeg\Media\Frame::save
方法保存帧。
$frame->save('target.jpg');
此方法有一个可选的布尔参数。将其设置为 true 以获取准确的图像;它需要更多时间来执行。
格式
格式实现了 FFMpeg\Format\FormatInterface
。要保存到视频文件,请使用 FFMpeg\Format\VideoInterface
,并使用 FFMpeg\Format\AudioInterface
保存音频文件。
格式还可以扩展 FFMpeg\Format\ProgressableInterface
以获取实时转码信息。
预定义的格式已通过事件提供进度信息。
$format = new Format\Video\X264(); $format->on('progress', function ($video, $format, $percentage) { echo "$percentage % transcoded"; }); $video->save($format, 'video.avi');
为事件提供的回调可以是任何可调用的。
创建自己的格式
创建格式的最简单方法是扩展抽象的 FFMpeg\Format\Video\DefaultVideo
和 FFMpeg\Format\Audio\DefaultAudio
,并实现以下方法。
class CustomWMVFormat extends FFMpeg\Format\Video\DefaultVideo { public function __construct($audioCodec = 'wmav2', $videoCodec = 'wmv2') { $this ->setAudioCodec($audioCodec) ->setVideoCodec($videoCodec); } public function supportBFrames() { return false; } public function getAvailableAudioCodecs() { return array('wmav2'); } public function getAvailableVideoCodecs() { return array('wmv2'); } }
坐标
FFMpeg 使用许多时间和空间坐标的单位。
FFMpeg\Coordinate\AspectRatio
表示宽高比。FFMpeg\Coordinate\Dimension
表示尺寸。FFMpeg\Coordinate\FrameRate
表示帧率。FFMpeg\Coordinate\Point
表示点。FFMpeg\Coordinate\TimeCode
表示时间码。
FFProbe
FFMpeg\FFProbe
在内部由 FFMpeg\FFMpeg
用于探查媒体。您也可以使用它来提取媒体元数据。
$ffprobe = FFMpeg\FFProbe::create(); $ffprobe ->streams('/path/to/video/mp4') // extracts streams informations ->videos() // filters video streams ->first() // returns the first video stream ->get('codec_name'); // returns the codec_name property
$ffprobe = FFMpeg\FFProbe::create(); $ffprobe ->format('/path/to/video/mp4') // extracts file informations ->get('duration'); // returns the duration property
##与 Silex 微框架一起使用
服务提供商易于设置
$app = new Silex\Application(); $app->register(new FFMpeg\FFMpegServiceProvider()); $video = $app['ffmpeg']->open('video.mpeg');
可用的选项如下
$app->register(new FFMpeg\FFMpegServiceProvider(), array( 'ffmpeg.configuration' => array( 'ffmpeg.threads' => 4, 'ffmpeg.timeout' => 300, 'ffmpeg.binaries' => '/opt/local/ffmpeg/bin/ffmpeg', 'ffprobe.timeout' => 30, 'ffprobe.binaries' => '/opt/local/ffmpeg/bin/ffprobe', ), 'ffmpeg.logger' => $logger, ));
API 浏览器
浏览 API
许可证
本项目遵循MIT许可证。