WordPress как на ладони
rgbcode is looking for WordPress developers. Очень Удобный и Быстрый Хостинг для сайтов на WordPress. Пользуюсь сам и вам рекомендую!

image_downsize()WP 2.5.0

Получает массив данных картинки указанного размера: УРЛ, ширина и высота картинки-вложения.

Эта функция является ядром для wp_get_attachment_image_src(). Только ей нельзя передать третий параметр $icon. Она получает УРЛ и размеры именно вложения, которое является картинкой.

Получает УРЛ оригинальной картинки или её уменьшенной копии. Функция не создает уменьшенную копию картинки, а лишь получает УРЛ готовой уменьшенной картинки наиболее подходящей под указанные размеры. Если указаны произвольные размеры в массиве, подбирает подходящую картинку и пропорциональные ей размеры. См. примеры.

Работает на основе: wp_get_attachment_url(), image_get_intermediate_size()
1 раз — 0.001024 сек (очень медленно) | 50000 раз — 6.16 сек (быстро) | PHP 7.0.8, WP 4.6
Хуки из функции

Возвращает

Массив|false. Массив с данными о картинке или false если не удалось получить картинку.

Массив возвращается следующего формата:

array(
	[0] => url     // УРЛ картинки
	[1] => width   // ширина картинки
	[2] => height  // высота картинки
	[3] => true    // true, если получен УРЛ уменьшенной копии картинки, а не оригинала
)

Использование

image_downsize( $id, $size );
$id(число) (обязательный)
ID вложения-картинки, данные которой нужно получить.
$size(строка)

Размер картинки, данные о которой нужно получить. Отличаться будет ссылка. В этом параметре можно указывать зарегистрированные в WP размеры, по умолчанию это:

  • thumbnail — миниатюра (обычно 150х150) кадрированная.
  • medium — средний размер, не кадрирован. (По умолчанию).
  • large — большой размер, не кадрирован.
  • full — Оригинал картинки. Если создана «scaled» картинка, то будет получена она.

array( 32, 32 ) — также, можно указать размер в массиве в виде двух значений (ширина, высота). В этом случае будет подобран наиболее подходящий размер из имеющихся, затем картинка будет сжата/растянута до указанных размеров.

С версии 2.5. этот параметр не влияет на размер медиа иконок (иконок для файлов), они всегда показываются в оригинальном размере.

По умолчанию: 'medium'

Примеры

0

#1 Функция получения УРЛ картинки среднего размера

Давайте напишем функцию аналогичную которая будет получать средний (medium) размер картинки-вложения, ID которой мы укажем в параметре $id:

function wp_get_attachment_medium_url( $id ){
	$medium_array = image_downsize( $id, 'medium' );
	$medium_path = $medium_array[0];

	return $medium_path;
}
0

#2 Как работает функция

Предположим у нас есть вложение с ID 55 - это картинка: http://wp-kama.ru/wp-content/uploads/2014/02/wix.png с размерами 500х258 пикселей. В настройках медиафайлов у нас стоят размеры для картинок: 80х80, 300х300, 1000х1000. Значит, при загрузке этой картинки, ВП создал 2 уменьшенные копии: 80х80, 300х300.

Теперь смотрите, что будет получать функция при указании разных размеров:

$img = image_downsize( 55, 'full' );
/*
Array
(
	[0] => http://wp-kama.ru/wp-content/uploads/2014/02/wix.png
	[1] => 500
	[2] => 258
	[3] =>
)
*/

$img = image_downsize( 55, 'thumbnail' );
/*
Array
(
	[0] => http://wp-kama.ru/wp-content/uploads/2014/02/wix-80x80.png
	[1] => 80
	[2] => 80
	[3] => 1
)
*/

$img = image_downsize( 55 );
/*
Array
(
	[0] => http://wp-kama.ru/wp-content/uploads/2014/02/wix-300x258.png
	[1] => 300
	[2] => 258
	[3] => 1
)
*/

$img = image_downsize( 55, array(100, 90) );
/*
Array
(
	[0] => http://wp-kama.ru/wp-content/uploads/2014/02/wix.png
	[1] => 100
	[2] => 51
	[3] =>
)
*/

$img = image_downsize( 55, array(100, 80) );
/*
Array
(
	[0] => http://wp-kama.ru/wp-content/uploads/2014/02/wix-80x80.png
	[1] => 80
	[2] => 80
	[3] => 1
)
*/

Список изменений

С версии 2.5.0 Введена.

Код image_downsize() WP 6.6.2

function image_downsize( $id, $size = 'medium' ) {
	$is_image = wp_attachment_is_image( $id );

	/**
	 * Filters whether to preempt the output of image_downsize().
	 *
	 * Returning a truthy value from the filter will effectively short-circuit
	 * down-sizing the image, returning that value instead.
	 *
	 * @since 2.5.0
	 *
	 * @param bool|array   $downsize Whether to short-circuit the image downsize.
	 * @param int          $id       Attachment ID for image.
	 * @param string|int[] $size     Requested image size. Can be any registered image size name, or
	 *                               an array of width and height values in pixels (in that order).
	 */
	$out = apply_filters( 'image_downsize', false, $id, $size );

	if ( $out ) {
		return $out;
	}

	$img_url          = wp_get_attachment_url( $id );
	$meta             = wp_get_attachment_metadata( $id );
	$width            = 0;
	$height           = 0;
	$is_intermediate  = false;
	$img_url_basename = wp_basename( $img_url );

	/*
	 * If the file isn't an image, attempt to replace its URL with a rendered image from its meta.
	 * Otherwise, a non-image type could be returned.
	 */
	if ( ! $is_image ) {
		if ( ! empty( $meta['sizes']['full'] ) ) {
			$img_url          = str_replace( $img_url_basename, $meta['sizes']['full']['file'], $img_url );
			$img_url_basename = $meta['sizes']['full']['file'];
			$width            = $meta['sizes']['full']['width'];
			$height           = $meta['sizes']['full']['height'];
		} else {
			return false;
		}
	}

	// Try for a new style intermediate size.
	$intermediate = image_get_intermediate_size( $id, $size );

	if ( $intermediate ) {
		$img_url         = str_replace( $img_url_basename, $intermediate['file'], $img_url );
		$width           = $intermediate['width'];
		$height          = $intermediate['height'];
		$is_intermediate = true;
	} elseif ( 'thumbnail' === $size && ! empty( $meta['thumb'] ) && is_string( $meta['thumb'] ) ) {
		// Fall back to the old thumbnail.
		$imagefile = get_attached_file( $id );
		$thumbfile = str_replace( wp_basename( $imagefile ), wp_basename( $meta['thumb'] ), $imagefile );

		if ( file_exists( $thumbfile ) ) {
			$info = wp_getimagesize( $thumbfile );

			if ( $info ) {
				$img_url         = str_replace( $img_url_basename, wp_basename( $thumbfile ), $img_url );
				$width           = $info[0];
				$height          = $info[1];
				$is_intermediate = true;
			}
		}
	}

	if ( ! $width && ! $height && isset( $meta['width'], $meta['height'] ) ) {
		// Any other type: use the real image.
		$width  = $meta['width'];
		$height = $meta['height'];
	}

	if ( $img_url ) {
		// We have the actual image size, but might need to further constrain it if content_width is narrower.
		list( $width, $height ) = image_constrain_size_for_editor( $width, $height, $size );

		return array( $img_url, $width, $height, $is_intermediate );
	}

	return false;
}
3 комментария
    Войти