To zawsze było dla mnie problemem - brakiem zmiany rozmiaru obrazu na żądanie i kolejną liczbą plików, z którymi możesz skończyć, jeśli masz dużo rozmiarów!
Widzę logikę twoich wysiłków - problem polega na tym, add_image_size
że naprawdę wchodzi w grę dopiero w momencie przesłania. Jako taki is_page_template(..)
zawsze będzie false
.
Szybki Google wykopał Aqua Resizer , skrypt zaprojektowany w celu rozwiązania tego problemu. Zamiast używać add_image_size
, używasz aq_resize
bezpośrednio w swoim motywie, a jeśli rozmiar obrazu nie istnieje, jest on tworzony i buforowany w locie.
W rzeczywistości zastosowałem podobną, choć inną, technikę w kilku witrynach o wielu rozmiarach obrazu. Nadal oszczędzasz na generowaniu WordPressa, generując każdy rozmiar dla każdego przesłanego obrazu - są one generowane w locie (i buforowane), kiedy i kiedy są wymagane. Różni się tym, że możesz po prostu korzystać ze wszystkich standardowych funkcji obrazu WP i tagów szablonów, tak jak zwykle!
Ponadto, jak wspomniano @Waqas, użycie Aqua Resizer pozostawi osierocone pliki po usunięciu obrazu z biblioteki multimediów. Dzięki mojej technice wszystkie pliki zostaną usunięte, ponieważ są zapisywane w bazie danych i rozpoznawane przez 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 );
A w praktyce:
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!
Mam zamiar przekształcić to w wtyczkę, która automatycznie konwertuje wszystkie add_image_size
połączenia na zmiany rozmiaru na żądanie, więc uważaj na to miejsce!