Isso sempre foi um problema para mim - a falta de dimensionamento de imagens sob demanda e o número subseqüente de arquivos com os quais você pode terminar se tiver vários tamanhos!
Eu posso ver a lógica por trás de seus esforços - o problema é que add_image_size
só entra de fato no ponto de upload. Como tal, is_page_template(..)
sempre será false
.
Um rápido google descobriu o Aqua Resizer , um script criado para resolver esse problema. Em vez de usar add_image_size
, você usa aq_resize
diretamente no seu tema e, se não existir um tamanho para a imagem, ela será criada e armazenada em cache on-the-fly.
Na verdade, eu usei uma técnica semelhante, embora diferente, em vários sites com muitos tamanhos de imagem. Você ainda salva a sobrecarga do WordPress, gerando todos os tamanhos para cada imagem carregada - elas são geradas on-the-fly (e armazenadas em cache) como e quando solicitadas. Onde difere, é que você pode simplesmente usar todas as funções de imagem padrão do WP e tags de modelo como faria normalmente!
Além disso, como o @Waqas mencionou, o uso do Aqua Resizer deixará arquivos órfãos quando você excluir uma imagem da sua biblioteca de mídia. Com a minha técnica, todos os arquivos serão excluídos, pois são salvos no banco de dados e reconhecidos pelo 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 );
E na prática:
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!
Pretendo transformar isso em um plug-in que converterá automaticamente todas as add_image_size
chamadas em redimensionamento sob demanda. Portanto, observe este espaço!