Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.10.x will end 8 November 2021 (12 months).
  • Bug fixes for security issues in 3.10.x will end 9 May 2022 (18 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.
<?php

namespace PhpOffice\PhpSpreadsheet\Worksheet;

> use GdImage; class MemoryDrawing extends BaseDrawing > use PhpOffice\PhpSpreadsheet\Exception; { >
// Rendering functions const RENDERING_DEFAULT = 'imagepng'; const RENDERING_PNG = 'imagepng'; const RENDERING_GIF = 'imagegif'; const RENDERING_JPEG = 'imagejpeg'; // MIME types const MIMETYPE_DEFAULT = 'image/png'; const MIMETYPE_PNG = 'image/png'; const MIMETYPE_GIF = 'image/gif'; const MIMETYPE_JPEG = 'image/jpeg'; /** * Image resource. *
< * @var resource
> * @var null|GdImage|resource
*/ private $imageResource; /** * Rendering function. * * @var string */ private $renderingFunction; /** * Mime type. * * @var string */ private $mimeType; /** * Unique name. * * @var string */ private $uniqueName;
> /** @var null|resource */ /** > private $alwaysNull; * Create a new MemoryDrawing. >
*/ public function __construct() { // Initialise values
< $this->imageResource = null;
$this->renderingFunction = self::RENDERING_DEFAULT; $this->mimeType = self::MIMETYPE_DEFAULT;
< $this->uniqueName = md5(rand(0, 9999) . time() . rand(0, 9999));
> $this->uniqueName = md5(mt_rand(0, 9999) . time() . mt_rand(0, 9999)); > $this->alwaysNull = null;
// Initialize parent parent::__construct(); }
> public function __destruct() /** > { * Get image resource. > if ($this->imageResource) { * > $rslt = @imagedestroy($this->imageResource); * @return resource > // "Fix" for Scrutinizer */ > $this->imageResource = $rslt ? null : $this->alwaysNull; public function getImageResource() > } { > } return $this->imageResource; > } > public function __clone() > { /** > parent::__clone(); * Set image resource. > $this->cloneResource(); * > } * @param resource $value > * > private function cloneResource(): void * @return MemoryDrawing > { */ > if (!$this->imageResource) { public function setImageResource($value) > return; { > } $this->imageResource = $value; > > $width = (int) imagesx($this->imageResource); if ($this->imageResource !== null) { > $height = (int) imagesy($this->imageResource); // Get width/height > $this->width = imagesx($this->imageResource); > if (imageistruecolor($this->imageResource)) { $this->height = imagesy($this->imageResource); > $clone = imagecreatetruecolor($width, $height); } > if (!$clone) { > throw new Exception('Could not clone image resource'); return $this; > } } > > imagealphablending($clone, false); /** > imagesavealpha($clone, true); * Get rendering function. > } else { * > $clone = imagecreate($width, $height); * @return string > if (!$clone) { */ > throw new Exception('Could not clone image resource'); public function getRenderingFunction() > } { > return $this->renderingFunction; > // If the image has transparency... } > $transparent = imagecolortransparent($this->imageResource); > if ($transparent >= 0) { /** > $rgb = imagecolorsforindex($this->imageResource, $transparent); * Set rendering function. > if (empty($rgb)) { * > throw new Exception('Could not get image colors'); * @param string $value see self::RENDERING_* > } * > * @return MemoryDrawing > imagesavealpha($clone, true); */ > $color = imagecolorallocatealpha($clone, $rgb['red'], $rgb['green'], $rgb['blue'], $rgb['alpha']); public function setRenderingFunction($value) > if ($color === false) { { > throw new Exception('Could not get image alpha color'); $this->renderingFunction = $value; > } > return $this; > imagefill($clone, 0, 0, $color); } > } > } /** > * Get mime type. > //Create the Clone!! * > imagecopy($clone, $this->imageResource, 0, 0, 0, 0, $width, $height); * @return string > */ > $this->imageResource = $clone; public function getMimeType() > } { >
< * @return resource
> * @return null|GdImage|resource
< * @param resource $value
> * @param GdImage|resource $value
< * @return MemoryDrawing
> * @return $this
< $this->width = imagesx($this->imageResource); < $this->height = imagesy($this->imageResource);
> $this->width = (int) imagesx($this->imageResource); > $this->height = (int) imagesy($this->imageResource);
< * @return MemoryDrawing
> * @return $this
* @param string $value see self::MIMETYPE_* *
< * @return MemoryDrawing
> * @return $this
*/ public function setMimeType($value) { $this->mimeType = $value; return $this; } /** * Get indexed filename (using image index).
< * < * @return string
*/
< public function getIndexedFilename()
> public function getIndexedFilename(): string
{ $extension = strtolower($this->getMimeType()); $extension = explode('/', $extension); $extension = $extension[1]; return $this->uniqueName . $this->getImageIndex() . '.' . $extension; } /** * Get hash code. * * @return string Hash code */ public function getHashCode() { return md5( $this->renderingFunction . $this->mimeType . $this->uniqueName . parent::getHashCode() . __CLASS__ ); } }