forked from leftypol/leftypol
DefaultImageMetadataReader.php: remove
This commit is contained in:
parent
5fab806aa4
commit
74c79c0e95
1 changed files with 0 additions and 45 deletions
|
@ -1,45 +0,0 @@
|
|||
<?php
|
||||
namespace Vichan\Service\Media;
|
||||
|
||||
use Vichan\Data\Driver\Metadata\ExifReaderFactory;
|
||||
use Vichan\Data\ImageMetadata;
|
||||
|
||||
|
||||
/**
|
||||
* Do not use this if you can.
|
||||
*
|
||||
* Some formats may contain no image or may contain multiple images. In these cases, getimagesize() might not be
|
||||
* able to properly determine the image size. getimagesize() will return zero for width and height in these cases.
|
||||
*
|
||||
* The implementation only supports a limited subset of metadata for only the provided exif image formats readers.
|
||||
* It won't always be able to correct the orientation, but it will try.
|
||||
*/
|
||||
class DefaultImageMetadataReader implements ImageMetadataReader {
|
||||
private ExifReaderFactory $exif_reader_factory;
|
||||
|
||||
public function __construct(ExifReaderFactory $exif_reader_factory) {
|
||||
$this->exif_reader_factory = $exif_reader_factory;
|
||||
}
|
||||
|
||||
public function getMetadata(string $file_path): ImageMetadata {
|
||||
$ret = \getimagesize($file_path, $info);
|
||||
if ($ret === false) {
|
||||
throw new \RuntimeException("Could not read image sizes of '$file_path'");
|
||||
}
|
||||
if ($ret[2] == \IMAGETYPE_UNKNOWN) {
|
||||
throw new \RuntimeException("Error '$file_path' is not an image");
|
||||
}
|
||||
|
||||
$width = $ret[0];
|
||||
$height = $ret[1];
|
||||
$mime = $ret['mime'];
|
||||
$orientation = null;
|
||||
|
||||
$exif_reader = $this->exif_reader_factory->getReader($mime);
|
||||
if ($exif_reader !== null) {
|
||||
$orientation = $exif_reader->getOrientation($file_path);
|
||||
}
|
||||
|
||||
return new ImageMetadata($width, $height, $mime, $orientation);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue