Это всегда было для меня ошибкой - отсутствие размера изображения по требованию и последующее количество файлов, которые вы можете получить, если у вас много размеров!
Я вижу логику ваших усилий - проблема в том, что add_image_size
действительно вступает в игру только в момент загрузки. Как таковой, is_page_template(..)
всегда будет false
.
Быстрый Google выкопал Aqua Resizer , скрипт, разработанный для решения этой проблемы. Вместо использования add_image_size
вы используете aq_resize
непосредственно в своей теме, и если размер изображения не существует, он создается и кэшируется на лету.
На самом деле я использовал похожую, хотя и разную технику на нескольких сайтах с изображениями разных размеров. Вы по-прежнему сохраняете издержки WordPress, генерируя каждый размер для каждого загружаемого изображения - они создаются на лету (и кэшируются) по мере необходимости. Отличие состоит в том, что вы можете просто использовать все стандартные функции изображения WP и теги шаблонов, как обычно!
Кроме того, как упомянул @Waqas, использование Aqua Resizer оставит потерянные файлы, когда вы удалите изображение из медиатеки. С моей техникой все файлы будут удалены, так как они сохраняются в базе данных и распознаются WordPress.
/**
* Resize internally-registered image sizes on-demand.
*
* @link http://wordpress.stackexchange.com/q/139624/1685
*
* @param mixed $null
* @param int $id
* @param mixed $size
* @return mixed
*/
function wpse_139624_image_downsize( $null, $id, $size ) {
static $sizes = array(
'post-thumbnail' => array(
'height' => 350,
'width' => 1440,
'crop' => true,
),
'standard_box' => array(
'height' => 215,
'width' => 450,
'crop' => true,
),
'default_image' => array(
'height' => 9999,
'width' => 691,
'crop' => false,
),
'gallery' => array(
'height' => 900,
'width' => 9999,
'crop' => false,
),
'gallery_thumb' => array(
'height' => 450,
'width' => 450,
'crop' => true,
),
);
if ( ! is_string( $size ) || ! isset( $sizes[ $size ] ) )
return $null;
if ( ! is_array( $data = wp_get_attachment_metadata( $id ) ) )
return $null;
if ( ! empty( $data['sizes'][ $size ] ) )
return $null;
if ( $data['height'] <= $sizes[ $size ]['height'] && $data['width'] <= $sizes[ $size ]['width'] )
return $null;
if ( ! $file = get_attached_file( $id ) )
return $null;
$editor = wp_get_image_editor( $file );
if ( ! is_wp_error( $editor ) ) {
$data['sizes'] += $editor->multi_resize(
array(
$size => $sizes[ $size ],
)
);
wp_update_attachment_metadata( $id, $data );
}
return $null;
}
add_filter( 'image_downsize', 'wpse_139624_image_downsize', 10, 3 );
И на практике:
wp_get_attachment_image( $id, 'gallery' ); // Resized if not already
wp_get_attachment_image_src( $id, 'standard_box' ); // Resized if not already
the_post_thumbnail(); // You get the idea!
// And so forth!
Я собираюсь превратить это в плагин, который автоматически преобразует все add_image_size
вызовы в изменение размера по требованию, так что следите за этим!