mirror of
				https://github.com/mosbth/cimage.git
				synced 2025-10-24 20:36:07 +02:00 
			
		
		
		
	Enable to set JPEG image as interlaced, implement feature #177.
This commit is contained in:
		
							
								
								
									
										17
									
								
								CImage.php
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								CImage.php
									
									
									
									
									
								
							| @@ -423,6 +423,13 @@ class CImage | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |      * Use interlaced progressive mode for JPEG images. | ||||||
|  |      */ | ||||||
|  |     private $interlace = false; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|      * Image copy strategy, defaults to RESAMPLE. |      * Image copy strategy, defaults to RESAMPLE. | ||||||
|      */ |      */ | ||||||
| @@ -838,6 +845,7 @@ class CImage | |||||||
|             'blur'        => null, |             'blur'        => null, | ||||||
|             'convolve'       => null, |             'convolve'       => null, | ||||||
|             'rotateAfter' => null, |             'rotateAfter' => null, | ||||||
|  |             'interlace' => null, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => null, |             'outputFormat' => null, | ||||||
| @@ -1402,6 +1410,7 @@ class CImage | |||||||
|         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; |         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; | ||||||
|         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; |         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; | ||||||
|         $lossy        = $this->lossy        ? "_l"                       : null; |         $lossy        = $this->lossy        ? "_l"                       : null; | ||||||
|  |         $interlace    = $this->interlace    ? "_i"                       : null; | ||||||
|  |  | ||||||
|         $saveAs = $this->normalizeFileExtension(); |         $saveAs = $this->normalizeFileExtension(); | ||||||
|         $saveAs = $saveAs ? "_$saveAs" : null; |         $saveAs = $saveAs ? "_$saveAs" : null; | ||||||
| @@ -1468,7 +1477,7 @@ class CImage | |||||||
|             . $quality . $filters . $sharpen . $emboss . $blur . $palette |             . $quality . $filters . $sharpen . $emboss . $blur . $palette | ||||||
|             . $optimize . $compress |             . $optimize . $compress | ||||||
|             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor |             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor | ||||||
|             . $convolve . $copyStrat . $lossy . $saveAs; |             . $convolve . $copyStrat . $lossy . $interlace . $saveAs; | ||||||
|  |  | ||||||
|         return $this->setTarget($file, $base); |         return $this->setTarget($file, $base); | ||||||
|     } |     } | ||||||
| @@ -2440,6 +2449,12 @@ class CImage | |||||||
|  |  | ||||||
|             case 'jpeg': |             case 'jpeg': | ||||||
|             case 'jpg': |             case 'jpg': | ||||||
|  |                 // Set as interlaced progressive JPEG | ||||||
|  |                 if ($this->interlace) { | ||||||
|  |                     $this->Log("Set JPEG image to be interlaced."); | ||||||
|  |                     $res = imageinterlace($this->image, true); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); |                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); | ||||||
|                 imagejpeg($this->image, $this->cacheFileName, $this->quality); |                 imagejpeg($this->image, $this->cacheFileName, $this->quality); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,6 +5,15 @@ Revision history | |||||||
| [](https://scrutinizer-ci.com/g/mosbth/cimage/build-status/master) | [](https://scrutinizer-ci.com/g/mosbth/cimage/build-status/master) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | v0.8.0 (2020-06-08) | ||||||
|  | ------------------------------------- | ||||||
|  |  | ||||||
|  | * Enable to set JPEG image as interlaced, implement feature #177. | ||||||
|  | * Add function getValue() to read from querystring. | ||||||
|  | * Set PHP 7.0 as precondition (to prepare to update the codebase). | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| v0.7.23 (2020-05-06) | v0.7.23 (2020-05-06) | ||||||
| ------------------------------------- | ------------------------------------- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -920,6 +920,18 @@ if ($cacheControl) { | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * interlace - Enable configuration for interlaced progressive JPEG images. | ||||||
|  |  */ | ||||||
|  | $interlaceConfig  = getConfig('interlace', null); | ||||||
|  | $interlaceValue   = getValue('interlace', null); | ||||||
|  | $interlaceDefined = getDefined('interlace', true, null); | ||||||
|  | $interlace = $interlaceValue ?? $interlaceDefined ?? $interlaceConfig; | ||||||
|  | verbose("interlace (configfile) = ", $interlaceConfig); | ||||||
|  | verbose("interlace = ", $interlace); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Prepare a dummy image and use it as source image. |  * Prepare a dummy image and use it as source image. | ||||||
|  */ |  */ | ||||||
| @@ -1081,6 +1093,7 @@ if (is_callable($hookBeforeCImage)) { | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
| @@ -1169,6 +1182,7 @@ $img->log("Incoming arguments: " . print_r(verbose(), 1)) | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
|   | |||||||
| @@ -485,6 +485,17 @@ return array( | |||||||
|             "scale" => 14, |             "scale" => 14, | ||||||
|             "luminanceStrategy" => 3, |             "luminanceStrategy" => 3, | ||||||
|             "customCharacterSet" => null, |             "customCharacterSet" => null, | ||||||
|         ); |         ), */ | ||||||
|     },*/ |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Default options using interlaced progressive JPEG images. Set to true to | ||||||
|  |      * always render jpeg images as interlaced. This setting can be overridden | ||||||
|  |      * by using `?interlace=true` or `?interlace=false`. | ||||||
|  |      * | ||||||
|  |      * Default values are: | ||||||
|  |      *  interlace:  false | ||||||
|  |      */ | ||||||
|  |      /*'interlace' => false,*/ | ||||||
| ); | ); | ||||||
|   | |||||||
| @@ -158,6 +158,25 @@ function getDefined($key, $defined, $undefined) | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Get value of input from query string or else $undefined. | ||||||
|  |  * | ||||||
|  |  * @param mixed $key       as string or array of string values to look for in $_GET. | ||||||
|  |  * @param mixed $undefined value to return when $key has no, or empty value in $_GET. | ||||||
|  |  * | ||||||
|  |  * @return mixed value as or $undefined. | ||||||
|  |  */ | ||||||
|  | function getValue($key, $undefined) | ||||||
|  | { | ||||||
|  |     $val = get($key); | ||||||
|  |     if (is_null($val) || $val === "") { | ||||||
|  |         return $undefined; | ||||||
|  |     } | ||||||
|  |     return $val; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Get value from config array or default if key is not set in config array. |  * Get value from config array or default if key is not set in config array. | ||||||
|  * |  * | ||||||
| @@ -183,7 +202,7 @@ function getConfig($key, $default) | |||||||
|  * |  * | ||||||
|  * @return void or array. |  * @return void or array. | ||||||
|  */ |  */ | ||||||
| function verbose($msg = null) | function verbose($msg = null, $arg = "") | ||||||
| { | { | ||||||
|     global $verbose, $verboseFile; |     global $verbose, $verboseFile; | ||||||
|     static $log = array(); |     static $log = array(); | ||||||
| @@ -196,7 +215,15 @@ function verbose($msg = null) | |||||||
|         return $log; |         return $log; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     $log[] = $msg; |     if (is_null($arg)) { | ||||||
|  |         $arg = "null"; | ||||||
|  |     } elseif ($arg === false) { | ||||||
|  |         $arg = "false"; | ||||||
|  |     } elseif ($arg === true) { | ||||||
|  |         $arg = "true"; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     $log[] = $msg . $arg; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1533,6 +1560,13 @@ class CImage | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |      * Use interlaced progressive mode for JPEG images. | ||||||
|  |      */ | ||||||
|  |     private $interlace = false; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|      * Image copy strategy, defaults to RESAMPLE. |      * Image copy strategy, defaults to RESAMPLE. | ||||||
|      */ |      */ | ||||||
| @@ -1948,6 +1982,7 @@ class CImage | |||||||
|             'blur'        => null, |             'blur'        => null, | ||||||
|             'convolve'       => null, |             'convolve'       => null, | ||||||
|             'rotateAfter' => null, |             'rotateAfter' => null, | ||||||
|  |             'interlace' => null, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => null, |             'outputFormat' => null, | ||||||
| @@ -2512,6 +2547,7 @@ class CImage | |||||||
|         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; |         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; | ||||||
|         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; |         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; | ||||||
|         $lossy        = $this->lossy        ? "_l"                       : null; |         $lossy        = $this->lossy        ? "_l"                       : null; | ||||||
|  |         $interlace    = $this->interlace    ? "_i"                       : null; | ||||||
|  |  | ||||||
|         $saveAs = $this->normalizeFileExtension(); |         $saveAs = $this->normalizeFileExtension(); | ||||||
|         $saveAs = $saveAs ? "_$saveAs" : null; |         $saveAs = $saveAs ? "_$saveAs" : null; | ||||||
| @@ -2578,7 +2614,7 @@ class CImage | |||||||
|             . $quality . $filters . $sharpen . $emboss . $blur . $palette |             . $quality . $filters . $sharpen . $emboss . $blur . $palette | ||||||
|             . $optimize . $compress |             . $optimize . $compress | ||||||
|             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor |             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor | ||||||
|             . $convolve . $copyStrat . $lossy . $saveAs; |             . $convolve . $copyStrat . $lossy . $interlace . $saveAs; | ||||||
|  |  | ||||||
|         return $this->setTarget($file, $base); |         return $this->setTarget($file, $base); | ||||||
|     } |     } | ||||||
| @@ -3550,6 +3586,12 @@ class CImage | |||||||
|  |  | ||||||
|             case 'jpeg': |             case 'jpeg': | ||||||
|             case 'jpg': |             case 'jpg': | ||||||
|  |                 // Set as interlaced progressive JPEG | ||||||
|  |                 if ($this->interlace) { | ||||||
|  |                     $this->Log("Set JPEG image to be interlaced."); | ||||||
|  |                     $res = imageinterlace($this->image, true); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); |                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); | ||||||
|                 imagejpeg($this->image, $this->cacheFileName, $this->quality); |                 imagejpeg($this->image, $this->cacheFileName, $this->quality); | ||||||
|  |  | ||||||
| @@ -5316,6 +5358,18 @@ if ($cacheControl) { | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * interlace - Enable configuration for interlaced progressive JPEG images. | ||||||
|  |  */ | ||||||
|  | $interlaceConfig  = getConfig('interlace', null); | ||||||
|  | $interlaceValue   = getValue('interlace', null); | ||||||
|  | $interlaceDefined = getDefined('interlace', true, null); | ||||||
|  | $interlace = $interlaceValue ?? $interlaceDefined ?? $interlaceConfig; | ||||||
|  | verbose("interlace (configfile) = ", $interlaceConfig); | ||||||
|  | verbose("interlace = ", $interlace); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Prepare a dummy image and use it as source image. |  * Prepare a dummy image and use it as source image. | ||||||
|  */ |  */ | ||||||
| @@ -5477,6 +5531,7 @@ if (is_callable($hookBeforeCImage)) { | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
| @@ -5565,6 +5620,7 @@ $img->log("Incoming arguments: " . print_r(verbose(), 1)) | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
|   | |||||||
| @@ -158,6 +158,25 @@ function getDefined($key, $defined, $undefined) | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Get value of input from query string or else $undefined. | ||||||
|  |  * | ||||||
|  |  * @param mixed $key       as string or array of string values to look for in $_GET. | ||||||
|  |  * @param mixed $undefined value to return when $key has no, or empty value in $_GET. | ||||||
|  |  * | ||||||
|  |  * @return mixed value as or $undefined. | ||||||
|  |  */ | ||||||
|  | function getValue($key, $undefined) | ||||||
|  | { | ||||||
|  |     $val = get($key); | ||||||
|  |     if (is_null($val) || $val === "") { | ||||||
|  |         return $undefined; | ||||||
|  |     } | ||||||
|  |     return $val; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Get value from config array or default if key is not set in config array. |  * Get value from config array or default if key is not set in config array. | ||||||
|  * |  * | ||||||
| @@ -183,7 +202,7 @@ function getConfig($key, $default) | |||||||
|  * |  * | ||||||
|  * @return void or array. |  * @return void or array. | ||||||
|  */ |  */ | ||||||
| function verbose($msg = null) | function verbose($msg = null, $arg = "") | ||||||
| { | { | ||||||
|     global $verbose, $verboseFile; |     global $verbose, $verboseFile; | ||||||
|     static $log = array(); |     static $log = array(); | ||||||
| @@ -196,7 +215,15 @@ function verbose($msg = null) | |||||||
|         return $log; |         return $log; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     $log[] = $msg; |     if (is_null($arg)) { | ||||||
|  |         $arg = "null"; | ||||||
|  |     } elseif ($arg === false) { | ||||||
|  |         $arg = "false"; | ||||||
|  |     } elseif ($arg === true) { | ||||||
|  |         $arg = "true"; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     $log[] = $msg . $arg; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1533,6 +1560,13 @@ class CImage | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |      * Use interlaced progressive mode for JPEG images. | ||||||
|  |      */ | ||||||
|  |     private $interlace = false; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|      * Image copy strategy, defaults to RESAMPLE. |      * Image copy strategy, defaults to RESAMPLE. | ||||||
|      */ |      */ | ||||||
| @@ -1948,6 +1982,7 @@ class CImage | |||||||
|             'blur'        => null, |             'blur'        => null, | ||||||
|             'convolve'       => null, |             'convolve'       => null, | ||||||
|             'rotateAfter' => null, |             'rotateAfter' => null, | ||||||
|  |             'interlace' => null, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => null, |             'outputFormat' => null, | ||||||
| @@ -2512,6 +2547,7 @@ class CImage | |||||||
|         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; |         $rotateBefore = $this->rotateBefore ? "_rb{$this->rotateBefore}" : null; | ||||||
|         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; |         $rotateAfter  = $this->rotateAfter  ? "_ra{$this->rotateAfter}"  : null; | ||||||
|         $lossy        = $this->lossy        ? "_l"                       : null; |         $lossy        = $this->lossy        ? "_l"                       : null; | ||||||
|  |         $interlace    = $this->interlace    ? "_i"                       : null; | ||||||
|  |  | ||||||
|         $saveAs = $this->normalizeFileExtension(); |         $saveAs = $this->normalizeFileExtension(); | ||||||
|         $saveAs = $saveAs ? "_$saveAs" : null; |         $saveAs = $saveAs ? "_$saveAs" : null; | ||||||
| @@ -2578,7 +2614,7 @@ class CImage | |||||||
|             . $quality . $filters . $sharpen . $emboss . $blur . $palette |             . $quality . $filters . $sharpen . $emboss . $blur . $palette | ||||||
|             . $optimize . $compress |             . $optimize . $compress | ||||||
|             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor |             . $scale . $rotateBefore . $rotateAfter . $autoRotate . $bgColor | ||||||
|             . $convolve . $copyStrat . $lossy . $saveAs; |             . $convolve . $copyStrat . $lossy . $interlace . $saveAs; | ||||||
|  |  | ||||||
|         return $this->setTarget($file, $base); |         return $this->setTarget($file, $base); | ||||||
|     } |     } | ||||||
| @@ -3550,6 +3586,12 @@ class CImage | |||||||
|  |  | ||||||
|             case 'jpeg': |             case 'jpeg': | ||||||
|             case 'jpg': |             case 'jpg': | ||||||
|  |                 // Set as interlaced progressive JPEG | ||||||
|  |                 if ($this->interlace) { | ||||||
|  |                     $this->Log("Set JPEG image to be interlaced."); | ||||||
|  |                     $res = imageinterlace($this->image, true); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); |                 $this->Log("Saving image as JPEG to cache using quality = {$this->quality}."); | ||||||
|                 imagejpeg($this->image, $this->cacheFileName, $this->quality); |                 imagejpeg($this->image, $this->cacheFileName, $this->quality); | ||||||
|  |  | ||||||
| @@ -5316,6 +5358,18 @@ if ($cacheControl) { | |||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * interlace - Enable configuration for interlaced progressive JPEG images. | ||||||
|  |  */ | ||||||
|  | $interlaceConfig  = getConfig('interlace', null); | ||||||
|  | $interlaceValue   = getValue('interlace', null); | ||||||
|  | $interlaceDefined = getDefined('interlace', true, null); | ||||||
|  | $interlace = $interlaceValue ?? $interlaceDefined ?? $interlaceConfig; | ||||||
|  | verbose("interlace (configfile) = ", $interlaceConfig); | ||||||
|  | verbose("interlace = ", $interlace); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Prepare a dummy image and use it as source image. |  * Prepare a dummy image and use it as source image. | ||||||
|  */ |  */ | ||||||
| @@ -5477,6 +5531,7 @@ if (is_callable($hookBeforeCImage)) { | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
| @@ -5565,6 +5620,7 @@ $img->log("Incoming arguments: " . print_r(verbose(), 1)) | |||||||
|             'blur'      => $blur, |             'blur'      => $blur, | ||||||
|             'convolve'  => $convolve, |             'convolve'  => $convolve, | ||||||
|             'rotateAfter' => $rotateAfter, |             'rotateAfter' => $rotateAfter, | ||||||
|  |             'interlace' => $interlace, | ||||||
|  |  | ||||||
|             // Output format |             // Output format | ||||||
|             'outputFormat' => $outputFormat, |             'outputFormat' => $outputFormat, | ||||||
|   | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
		Reference in New Issue
	
	Block a user