Improve the reliability of the crop returned by `image_get_intermediate_size()`.
Add a bunch of unit tests to `tests/image/intermediate_size.php`. Props joemcgill, ericlewis, kitchin, SergeyBiryukov, chipbennett. Fixes #17626. Built from https://develop.svn.wordpress.org/trunk@33807 git-svn-id: http://core.svn.wordpress.org/trunk@33775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
e49980bdc1
commit
0d3f30ba61
|
@ -607,35 +607,42 @@ function image_get_intermediate_size( $post_id, $size = 'thumbnail' ) {
|
||||||
|
|
||||||
// get the best one for a specified set of dimensions
|
// get the best one for a specified set of dimensions
|
||||||
if ( is_array($size) && !empty($imagedata['sizes']) ) {
|
if ( is_array($size) && !empty($imagedata['sizes']) ) {
|
||||||
$areas = array();
|
$candidates = array();
|
||||||
|
|
||||||
foreach ( $imagedata['sizes'] as $_size => $data ) {
|
foreach ( $imagedata['sizes'] as $_size => $data ) {
|
||||||
// already cropped to width or height; so use this size
|
// If there's an exact match to an existing image size, short circuit.
|
||||||
if ( ( $data['width'] == $size[0] && $data['height'] <= $size[1] ) || ( $data['height'] == $size[1] && $data['width'] <= $size[0] ) ) {
|
if ( $data['width'] == $size[0] && $data['height'] == $size[1] ) {
|
||||||
$file = $data['file'];
|
$file = $data['file'];
|
||||||
list($width, $height) = image_constrain_size_for_editor( $data['width'], $data['height'], $size );
|
list($width, $height) = image_constrain_size_for_editor( $data['width'], $data['height'], $size );
|
||||||
return compact( 'file', 'width', 'height' );
|
return compact( 'file', 'width', 'height' );
|
||||||
}
|
}
|
||||||
// add to lookup table: area => size
|
// If it's not an exact match but it's at least the dimensions requested.
|
||||||
$areas[$data['width'] * $data['height']] = $_size;
|
if ( $data['width'] >= $size[0] && $data['height'] >= $size[1] ) {
|
||||||
|
$candidates[ $data['width'] * $data['height'] ] = $_size;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if ( !$size || !empty($areas) ) {
|
|
||||||
|
if ( ! empty( $candidates ) ) {
|
||||||
// find for the smallest image not smaller than the desired size
|
// find for the smallest image not smaller than the desired size
|
||||||
ksort($areas);
|
ksort( $candidates );
|
||||||
foreach ( $areas as $_size ) {
|
foreach ( $candidates as $_size ) {
|
||||||
$data = $imagedata['sizes'][$_size];
|
$data = $imagedata['sizes'][$_size];
|
||||||
if ( $data['width'] >= $size[0] || $data['height'] >= $size[1] ) {
|
|
||||||
// Skip images with unexpectedly divergent aspect ratios (crops)
|
// Skip images with unexpectedly divergent aspect ratios (crops)
|
||||||
// First, we calculate what size the original image would be if constrained to a box the size of the current image in the loop
|
// First, we calculate what size the original image would be if constrained to a box the size of the current image in the loop
|
||||||
$maybe_cropped = image_resize_dimensions($imagedata['width'], $imagedata['height'], $data['width'], $data['height'], false );
|
$maybe_cropped = image_resize_dimensions($imagedata['width'], $imagedata['height'], $data['width'], $data['height'], false );
|
||||||
// If the size doesn't match within one pixel, then it is of a different aspect ratio, so we skip it, unless it's the thumbnail size
|
// If the size doesn't match within one pixel, then it is of a different aspect ratio, so we skip it, unless it's the thumbnail size
|
||||||
if ( 'thumbnail' != $_size && ( !$maybe_cropped || ( $maybe_cropped[4] != $data['width'] && $maybe_cropped[4] + 1 != $data['width'] ) || ( $maybe_cropped[5] != $data['height'] && $maybe_cropped[5] + 1 != $data['height'] ) ) )
|
if ( 'thumbnail' != $_size &&
|
||||||
continue;
|
( ! $maybe_cropped
|
||||||
// If we're still here, then we're going to use this size
|
|| ( $maybe_cropped[4] != $data['width'] && $maybe_cropped[4] + 1 != $data['width'] )
|
||||||
$file = $data['file'];
|
|| ( $maybe_cropped[5] != $data['height'] && $maybe_cropped[5] + 1 != $data['height'] )
|
||||||
list($width, $height) = image_constrain_size_for_editor( $data['width'], $data['height'], $size );
|
) ) {
|
||||||
return compact( 'file', 'width', 'height' );
|
continue;
|
||||||
}
|
}
|
||||||
|
// If we're still here, then we're going to use this size
|
||||||
|
$file = $data['file'];
|
||||||
|
list( $width, $height ) = image_constrain_size_for_editor( $data['width'], $data['height'], $size );
|
||||||
|
return compact( 'file', 'width', 'height' );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.4-alpha-33806';
|
$wp_version = '4.4-alpha-33807';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue