WP_Image_Editor_Imagick::make_subsize( array $size_data ): array|WP_Error

In this article

Create an image sub-size and return the image meta data value for it.

Parameters

$size_dataarrayrequired
Array of size data.
  • width int
    The maximum width in pixels.
  • height int
    The maximum height in pixels.
  • crop bool|array
    Whether to crop the image to exact dimensions.

Return

array|WP_Error The image data array for inclusion in the sizes array in the image meta, WP_Error object on error.

Source

public function make_subsize( $size_data ) {
	if ( ! isset( $size_data['width'] ) && ! isset( $size_data['height'] ) ) {
		return new WP_Error( 'image_subsize_create_error', __( 'Cannot resize the image. Both width and height are not set.' ) );
	}

	$orig_size  = $this->size;
	$orig_image = $this->image->getImage();

	if ( ! isset( $size_data['width'] ) ) {
		$size_data['width'] = null;
	}

	if ( ! isset( $size_data['height'] ) ) {
		$size_data['height'] = null;
	}

	if ( ! isset( $size_data['crop'] ) ) {
		$size_data['crop'] = false;
	}

	if ( ( $this->size['width'] === $size_data['width'] ) && ( $this->size['height'] === $size_data['height'] ) ) {
		return new WP_Error( 'image_subsize_create_error', __( 'The image already has the requested size.' ) );
	}

	$resized = $this->resize( $size_data['width'], $size_data['height'], $size_data['crop'] );

	if ( is_wp_error( $resized ) ) {
		$saved = $resized;
	} else {
		$saved = $this->_save( $this->image );

		$this->image->clear();
		$this->image->destroy();
		$this->image = null;
	}

	$this->size  = $orig_size;
	$this->image = $orig_image;

	if ( ! is_wp_error( $saved ) ) {
		unset( $saved['path'] );
	}

	return $saved;
}

Changelog

VersionDescription
5.3.0Introduced.

User Contributed Notes

You must log in before being able to contribute a note or feedback.