ffmpeg-mappable-media/src/FFMpeg/Media/Frame.php

120 lines
2.7 KiB
PHP
Raw Normal View History

2013-06-25 10:03:20 +02:00
<?php
/*
* This file is part of PHP-FFmpeg.
*
* (c) Alchemy <info@alchemy.fr>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace FFMpeg\Media;
use Alchemy\BinaryDriver\Exception\ExecutionFailureException;
use FFMpeg\Filters\Frame\FrameFilterInterface;
use FFMpeg\Filters\Frame\FrameFilters;
use FFMpeg\Driver\FFMpegDriver;
use FFMpeg\FFProbe;
use FFMpeg\Exception\RuntimeException;
use FFMpeg\Coordinate\TimeCode;
2013-09-04 19:50:38 +02:00
use FFMpeg\Media\Video;
2013-06-25 10:03:20 +02:00
class Frame extends AbstractMediaType
{
/** @var TimeCode */
private $timecode;
2013-09-04 19:50:38 +02:00
/** @var Video */
private $video;
2013-06-25 10:03:20 +02:00
2013-09-04 19:50:38 +02:00
public function __construct(Video $video, FFMpegDriver $driver, FFProbe $ffprobe, TimeCode $timecode)
2013-06-25 10:03:20 +02:00
{
2013-09-04 19:50:38 +02:00
parent::__construct($video->getPathfile(), $driver, $ffprobe);
2013-06-25 10:03:20 +02:00
$this->timecode = $timecode;
2013-09-04 19:50:38 +02:00
$this->video = $video;
}
/**
* Returns the video related to the frame.
*
* @return Video
*/
public function getVideo()
{
return $this->video;
2013-06-25 10:03:20 +02:00
}
/**
* {@inheritdoc}
*
* @return FrameFilters
*/
public function filters()
{
return new FrameFilters($this);
}
/**
* {@inheritdoc}
*
* @return Frame
*/
public function addFilter(FrameFilterInterface $filter)
{
$this->filters->add($filter);
return $this;
}
/**
* @return TimeCode
*/
public function getTimeCode()
{
return $this->timecode;
}
/**
* Saves the frame in the given filename.
*
* Uses the `unaccurate method by default.`
*
2013-06-25 21:43:19 +02:00
* @param string $pathfile
2013-06-25 10:03:20 +02:00
* @param Boolean $accurate
*
* @return Frame
*
* @throws RuntimeException
*/
public function save($pathfile, $accurate = false)
2013-06-25 10:03:20 +02:00
{
/**
2013-06-25 10:40:20 +02:00
* might be optimized with http://ffmpeg.org/trac/ffmpeg/wiki/Seeking%20with%20FFmpeg
2013-06-25 10:03:20 +02:00
* @see http://ffmpeg.org/ffmpeg.html#Main-options
*/
if (!$accurate) {
$commands = array(
'-y', '-ss', (string) $this->timecode,
2013-06-25 10:03:20 +02:00
'-i', $this->pathfile,
'-vframes', '1',
'-f', 'image2', $pathfile
);
} else {
$commands = array(
'-y', '-i', $this->pathfile,
2013-06-25 10:03:20 +02:00
'-vframes', '1', '-ss', (string) $this->timecode,
'-f', 'image2', $pathfile
);
}
try {
$this->driver->command($commands);
} catch (ExecutionFailureException $e) {
$this->cleanupTemporaryFile($pathfile);
throw new RuntimeException('Unable to save frame', $e->getCode(), $e);
}
return $this;
}
}