Для мене це завжди було помилкою - відсутність розміру зображень на вимогу та подальша кількість файлів, з якими ви можете закінчитися, якщо у вас велика кількість розмірів!
Я бачу логіку ваших зусиль - біда полягає 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
дзвінки в розмір за потребою, тому слідкуйте за цим простором!