Merge pull request #495 from Shaked/master
allow to set frame file type instead of hardcoded jpg
This commit is contained in:
		
				commit
				
					
						3d0753cc54
					
				
			
		
					 2 changed files with 49 additions and 8 deletions
				
			
		|  | @ -35,6 +35,10 @@ class ExtractMultipleFramesFilter implements VideoFilterInterface | |||
|     private $priority; | ||||
|     private $frameRate; | ||||
|     private $destinationFolder; | ||||
|     private $frameFileType = 'jpg'; | ||||
| 
 | ||||
|     /** @var array */ | ||||
|     private static $supportedFrameFileTypes = ['jpg', 'jpeg', 'png']; | ||||
| 
 | ||||
|     public function __construct($frameRate = self::FRAMERATE_EVERY_SEC, $destinationFolder = __DIR__, $priority = 0) | ||||
|     { | ||||
|  | @ -49,6 +53,20 @@ class ExtractMultipleFramesFilter implements VideoFilterInterface | |||
|         $this->destinationFolder = $destinationFolder; | ||||
|     } | ||||
| 
 | ||||
| 	/** | ||||
| 	 * @param string $frameFileType | ||||
| 	 * @throws \FFMpeg\Exception\InvalidArgumentException | ||||
| 	 * @return ExtractMultipleFramesFilter | ||||
| 	 */ | ||||
|     public function setFrameFileType($frameFileType) { | ||||
|     	if (in_array($frameFileType, self::$supportedFrameFileTypes)) { | ||||
|     		$this->frameFileType = $frameFileType; | ||||
|     		return $this; | ||||
|     	} | ||||
| 
 | ||||
|     	throw new InvalidArgumentException('Invalid frame file type, use: ' . implode(',', self::$supportedFrameFileTypes)); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|  | @ -117,7 +135,7 @@ class ExtractMultipleFramesFilter implements VideoFilterInterface | |||
|             // Set the parameters
 | ||||
|             $commands[] = '-vf'; | ||||
|             $commands[] = 'fps=' . $this->frameRate; | ||||
|             $commands[] = $this->destinationFolder . 'frame-%'.$nbDigitsInFileNames.'d.jpg'; | ||||
|             $commands[] = $this->destinationFolder . 'frame-%'.$nbDigitsInFileNames.'d.' . $this->frameFileType; | ||||
|         } | ||||
|         catch (RuntimeException $e) { | ||||
|             throw new RuntimeException('An error occured while extracting the frames: ' . $e->getMessage() . '. The code: ' . $e->getCode()); | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ class ExtractMultipleFramesFilterTest extends TestCase | |||
|     /** | ||||
|      * @dataProvider provideFrameRates | ||||
|      */ | ||||
|     public function testApply($frameRate, $destinationFolder, $duration, $modulus, $expected) | ||||
|     public function testApply($frameRate, $frameFileType,$destinationFolder, $duration, $modulus, $expected) | ||||
|     { | ||||
|         $video = $this->getVideoMock(); | ||||
|         $pathfile = '/path/to/file'.mt_rand(); | ||||
|  | @ -34,18 +34,41 @@ class ExtractMultipleFramesFilterTest extends TestCase | |||
|             ->will($this->returnValue($streams)); | ||||
| 
 | ||||
|         $filter = new ExtractMultipleFramesFilter($frameRate, $destinationFolder); | ||||
|         $filter->setFrameFileType($frameFileType); | ||||
|         $this->assertEquals($expected, $filter->apply($video, $format)); | ||||
|     } | ||||
| 
 | ||||
|     public function provideFrameRates() | ||||
|     { | ||||
|         return array( | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_SEC, '/', 100, 2, array('-vf', 'fps=1/1', '/frame-%03d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_2SEC, '/', 100, 2, array('-vf', 'fps=1/2', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_5SEC, '/', 100, 2, array('-vf', 'fps=1/5', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_10SEC, '/', 100, 2, array('-vf', 'fps=1/10', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_30SEC, '/', 100, 2, array('-vf', 'fps=1/30', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_60SEC, '/', 100, 2, array('-vf', 'fps=1/60', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/1', '/frame-%03d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_2SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/2', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_5SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/5', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_10SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/10', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_30SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/30', '/frame-%02d.jpg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_60SEC, 'jpg', '/', 100, 2, array('-vf', 'fps=1/60', '/frame-%02d.jpg')), | ||||
| 
 | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/1', '/frame-%03d.jpeg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_2SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/2', '/frame-%02d.jpeg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_5SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/5', '/frame-%02d.jpeg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_10SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/10', '/frame-%02d.jpeg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_30SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/30', '/frame-%02d.jpeg')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_60SEC, 'jpeg', '/', 100, 2, array('-vf', 'fps=1/60', '/frame-%02d.jpeg')), | ||||
| 
 | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/1', '/frame-%03d.png')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_2SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/2', '/frame-%02d.png')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_5SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/5', '/frame-%02d.png')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_10SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/10', '/frame-%02d.png')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_30SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/30', '/frame-%02d.png')), | ||||
|             array(ExtractMultipleFramesFilter::FRAMERATE_EVERY_60SEC, 'png', '/', 100, 2, array('-vf', 'fps=1/60', '/frame-%02d.png')), | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @expectedException \FFMpeg\Exception\InvalidArgumentException | ||||
|      */ | ||||
|     public function testInvalidFrameFileType() { | ||||
|         $filter = new ExtractMultipleFramesFilter('1/1', '/'); | ||||
|         $filter->setFrameFileType('webm'); | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue