當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ImageHelper::getPngImageInfo方法代碼示例

本文整理匯總了PHP中ImageHelper::getPngImageInfo方法的典型用法代碼示例。如果您正苦於以下問題:PHP ImageHelper::getPngImageInfo方法的具體用法?PHP ImageHelper::getPngImageInfo怎麽用?PHP ImageHelper::getPngImageInfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ImageHelper的用法示例。


在下文中一共展示了ImageHelper::getPngImageInfo方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: _getSaveOptions

	/**
	 * Get save options.
	 *
	 * @param int|null $quality
	 * @param string   $extension
	 * @return array
	 */
	private function _getSaveOptions($quality = null, $extension = null)
	{
		// Because it's possible for someone to set the quality to 0.
		$quality = ($quality === null || $quality === false ? $this->_quality : $quality);
		$extension = (!$extension ? $this->getExtension() : $extension);

		switch ($extension)
		{
			case 'jpeg':
			case 'jpg':
			{
				return array('jpeg_quality' => $quality, 'flatten' => true);
			}

			case 'gif':
			{
				$options = array('animated' => $this->_isAnimatedGif);

				if ($this->_isAnimatedGif)
				{
					// Imagine library does not provide this value and arbitrarily divides it by 10, when assigning,
					// so we have to improvise a little
					$options['animated.delay'] = $this->_image->getImagick()->getImageDelay() * 10;
				}

				return $options;
			}

			case 'png':
			{
				// Valid PNG quality settings are 0-9, so normalize and flip, because we're talking about compression
				// levels, not quality, like jpg and gif.
				$normalizedQuality = round(($quality * 9) / 100);
				$normalizedQuality = 9 - $normalizedQuality;

				if ($normalizedQuality < 0)
				{
					$normalizedQuality = 0;
				}

				if ($normalizedQuality > 9)
				{
					$normalizedQuality = 9;
				}

				$options = array('png_compression_level' => $normalizedQuality, 'flatten' => false);
				$pngInfo = ImageHelper::getPngImageInfo($this->_imageSourcePath);

				// Even though a 2 channel PNG is valid (Grayscale with alpha channel), Imagick doesn't recognize it as
				// a valid format: http://www.imagemagick.org/script/formats.php
				// So 2 channel PNGs get converted to 4 channel.

				if (is_array($pngInfo) && isset($pngInfo['channels']) && $pngInfo['channels'] !== 2)
				{
					$format = 'png'.(8 * $pngInfo['channels']);
				}
				else
				{
					$format = 'png32';
				}

				$options['png_format'] = $format;

				return $options;
			}

			default:
			{
				return array();
			}
		}
	}
開發者ID:harish94,項目名稱:Craft-Release,代碼行數:79,代碼來源:Image.php

示例2: _getSaveOptions

 /**
  * Get save options.
  *
  * @param int|null $quality
  * @param string   $extension
  * @return array
  */
 private function _getSaveOptions($quality = null, $extension = null)
 {
     // Because it's possible for someone to set the quality to 0.
     $quality = $quality === null || $quality === false ? $this->_quality : $quality;
     $extension = !$extension ? $this->getExtension() : $extension;
     switch ($extension) {
         case 'jpeg':
         case 'jpg':
             return array('jpeg_quality' => $quality, 'flatten' => true);
         case 'gif':
             $options = array('animated' => $this->_isAnimatedGif);
             return $options;
         case 'png':
             // Valid PNG quality settings are 0-9, so normalize and flip, because we're talking about compression
             // levels, not quality, like jpg and gif.
             $normalizedQuality = round($quality * 9 / 100);
             $normalizedQuality = 9 - $normalizedQuality;
             if ($normalizedQuality < 0) {
                 $normalizedQuality = 0;
             }
             if ($normalizedQuality > 9) {
                 $normalizedQuality = 9;
             }
             $options = array('png_compression_level' => $normalizedQuality, 'flatten' => false);
             $pngInfo = ImageHelper::getPngImageInfo($this->_imageSourcePath);
             // Even though a 2 channel PNG is valid (Grayscale with alpha channel), Imagick doesn't recognize it as
             // a valid format: http://www.imagemagick.org/script/formats.php
             // So 2 channel PNGs get converted to 4 channel.
             if (is_array($pngInfo) && isset($pngInfo['channels']) && $pngInfo['channels'] !== 2) {
                 $format = 'png' . 8 * $pngInfo['channels'];
             } else {
                 $format = 'png32';
             }
             $options['png_format'] = $format;
             return $options;
         default:
             return array();
     }
 }
開發者ID:codeforamerica,項目名稱:oakland-beta,代碼行數:46,代碼來源:Image.php


注:本文中的ImageHelper::getPngImageInfo方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。