Add `->get_quality()` method to `WP_Image_Editor` class.
Adds unit tests. Props markoheijnen. Fixes #28154. Built from https://develop.svn.wordpress.org/trunk@28879 git-svn-id: http://core.svn.wordpress.org/trunk@28678 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
a6a2183bf6
commit
cf95c6ecc2
|
@ -114,7 +114,7 @@ class WP_Image_Editor_GD extends WP_Image_Editor {
|
|||
$this->update_size( $size[0], $size[1] );
|
||||
$this->mime_type = $size['mime'];
|
||||
|
||||
return $this->set_quality( $this->quality );
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -394,7 +394,7 @@ class WP_Image_Editor_GD extends WP_Image_Editor {
|
|||
}
|
||||
}
|
||||
elseif ( 'image/jpeg' == $mime_type ) {
|
||||
if ( ! $this->make_image( $filename, 'imagejpeg', array( $image, $filename, $this->quality ) ) )
|
||||
if ( ! $this->make_image( $filename, 'imagejpeg', array( $image, $filename, $this->get_quality() ) ) )
|
||||
return new WP_Error( 'image_save_error', __('Image Editor Save Failed') );
|
||||
}
|
||||
else {
|
||||
|
@ -442,7 +442,7 @@ class WP_Image_Editor_GD extends WP_Image_Editor {
|
|||
return imagegif( $this->image );
|
||||
default:
|
||||
header( 'Content-Type: image/jpeg' );
|
||||
return imagejpeg( $this->image, null, $this->quality );
|
||||
return imagejpeg( $this->image, null, $this->get_quality() );
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -143,7 +143,7 @@ class WP_Image_Editor_Imagick extends WP_Image_Editor {
|
|||
if ( is_wp_error( $updated_size ) )
|
||||
return $updated_size;
|
||||
|
||||
return $this->set_quality( $this->quality );
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -160,7 +160,7 @@ class WP_Image_Editor_Imagick extends WP_Image_Editor {
|
|||
if ( is_wp_error( $quality_result ) ) {
|
||||
return $quality_result;
|
||||
} else {
|
||||
$quality = $this->quality;
|
||||
$quality = $this->get_quality();
|
||||
}
|
||||
|
||||
try {
|
||||
|
|
|
@ -16,7 +16,8 @@ abstract class WP_Image_Editor {
|
|||
protected $size = null;
|
||||
protected $mime_type = null;
|
||||
protected $default_mime_type = 'image/jpeg';
|
||||
protected $quality = 90;
|
||||
protected $quality = false;
|
||||
protected $default_quality = 90;
|
||||
|
||||
/**
|
||||
* Each instance handles a single file.
|
||||
|
@ -203,19 +204,15 @@ abstract class WP_Image_Editor {
|
|||
}
|
||||
|
||||
/**
|
||||
* Sets Image Compression quality on a 1-100% scale.
|
||||
* Gets the Image Compression quality on a 1-100% scale.
|
||||
*
|
||||
* @since 3.5.0
|
||||
* @since 4.0.0
|
||||
* @access public
|
||||
*
|
||||
* @param int $quality Compression Quality. Range: [1,100]
|
||||
* @return boolean|WP_Error True if set successfully; WP_Error on failure.
|
||||
* @return int $quality Compression Quality. Range: [1,100]
|
||||
*/
|
||||
public function set_quality( $quality = null ) {
|
||||
if ( $quality == null ) {
|
||||
$quality = $this->quality;
|
||||
}
|
||||
|
||||
public function get_quality() {
|
||||
if ( ! $this->quality ) {
|
||||
/**
|
||||
* Filter the default image compression quality setting.
|
||||
*
|
||||
|
@ -224,7 +221,7 @@ abstract class WP_Image_Editor {
|
|||
* @param int $quality Quality level between 1 (low) and 100 (high).
|
||||
* @param string $mime_type Image mime type.
|
||||
*/
|
||||
$quality = apply_filters( 'wp_editor_set_quality', $quality, $this->mime_type );
|
||||
$quality = apply_filters( 'wp_editor_set_quality', $this->default_quality, $this->mime_type );
|
||||
|
||||
if ( 'image/jpeg' == $this->mime_type ) {
|
||||
/**
|
||||
|
@ -240,13 +237,31 @@ abstract class WP_Image_Editor {
|
|||
*/
|
||||
$quality = apply_filters( 'jpeg_quality', $quality, 'image_resize' );
|
||||
|
||||
if ( ! $this->set_quality( $quality ) ) {
|
||||
$this->quality = $this->default_quality;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $this->quality;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets Image Compression quality on a 1-100% scale.
|
||||
*
|
||||
* @since 3.5.0
|
||||
* @access public
|
||||
*
|
||||
* @param int $quality Compression Quality. Range: [1,100]
|
||||
* @return boolean|WP_Error True if set successfully; WP_Error on failure.
|
||||
*/
|
||||
public function set_quality( $quality = null ) {
|
||||
// Allow 0, but squash to 1 due to identical images in GD, and for backwards compatibility.
|
||||
if ( $quality == 0 ) {
|
||||
$quality = 1;
|
||||
}
|
||||
}
|
||||
|
||||
if ( ( $quality >= 1 ) && ( $quality <= 100 ) ){
|
||||
if ( ( $quality >= 1 ) && ( $quality <= 100 ) ) {
|
||||
$this->quality = $quality;
|
||||
return true;
|
||||
} else {
|
||||
|
|
Loading…
Reference in New Issue