wherewhat/php-ffmpeg

FFMpeg PHP,一个用于与 AVconv / ffmpeg 通信的面向对象库

0.6.0 2015-01-30 19:07 UTC

README

#PHP FFmpeg

Build Status

SensioLabsInsight

一个用于使用 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\AudioFFMpeg\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 实例
  • $modeFFMpeg\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\DefaultVideoFFMpeg\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许可证