Le 'jpeg_quality'
funzioni di hook del filtro accettano due argomenti: $jpeg_quality
e $function
quale è la funzione all'interno dell'hook del filtro viene attivata e può essere image_resize
o wp_crop_image
. Pertanto, non è possibile impostare in modo selettivo la qualità delle .jpeg
immagini in base alle dimensioni dell'immagine da questa funzione di aggancio del filtro.
Tuttavia, è ancora possibile agganciarsi a un gancio di azione successivo nel processo di caricamento degli allegati e regolare la .jpeg
qualità dell'immagine delle immagini caricate in quel punto in base alle loro dimensioni specifiche in base alle proprie esigenze. Innanzitutto impostare il jpeg_quality
massimo per preservare la qualità dell'immagine originale, quindi agganciare al gancio di added_post_meta
azione (che viene attivato alla fine dell'inserimento dei metadati degli allegati) per regolare la qualità, come segue:
// set the quality to maximum
add_filter('jpeg_quality', create_function('$quality', 'return 100;'));
add_action('added_post_meta', 'ad_update_jpeg_quality', 10, 4);
function ad_update_jpeg_quality($meta_id, $attach_id, $meta_key, $attach_meta) {
if ($meta_key == '_wp_attachment_metadata') {
$post = get_post($attach_id);
if ($post->post_mime_type == 'image/jpeg' && is_array($attach_meta['sizes'])) {
$pathinfo = pathinfo($attach_meta['file']);
$uploads = wp_upload_dir();
$dir = $uploads['basedir'] . '/' . $pathinfo['dirname'];
foreach ($attach_meta['sizes'] as $size => $value) {
$image = $dir . '/' . $value['file'];
$resource = imagecreatefromjpeg($image);
if ($size == 'spalsh') {
// set the jpeg quality for 'spalsh' size
imagejpeg($resource, $image, 100);
} elseif ($size == 'spalsh1') {
// set the jpeg quality for the 'splash1' size
imagejpeg($resource, $image, 30);
} else {
// set the jpeg quality for the rest of sizes
imagejpeg($resource, $image, 10);
}
// or you can skip a paticular image size
// and set the quality for the rest:
// if ($size == 'splash') continue;
imagedestroy($resource);
}
}
}
}
Il codice sopra avrà effetto solo sulle immagini appena caricate. Se desideri aggiornare la qualità delle immagini caricate in precedenza, puoi utilizzare i register_activation_hook
plug-in. Crea un nuovo file php nella wp-content/plugins
directory e chiamalo come preferisci ( update-jpeg-quality.php
ad esempio) e aggiungi il seguente codice:
<?php
/*
Plugin Name: Update JPEG Quality
Plugin URI: http://wordpress.stackexchange.com/questions/74103/set-jpeg-compression-for-specific-custom-image-sizes
Description: This plugin will change the jpeg image quality according to its size.
Author: Ahmad M
Version: 1.0
Author URI: http://wordpress.stackexchange.com/users/12961/ahmad-m
*/
register_activation_hook(__FILE__, 'ad_modify_jpeg_quality');
function ad_modify_jpeg_quality() {
$attachments = get_posts(array(
'numberposts' => -1,
'post_type' => 'attachment',
'post_mime_type' => 'image/jpeg'
));
if (empty($attachments)) return;
$uploads = wp_upload_dir();
foreach ($attachments as $attachment) {
$attach_meta = wp_get_attachment_metadata($attachment->ID);
if (!is_array($attach_meta['sizes'])) break;
$pathinfo = pathinfo($attach_meta['file']);
$dir = $uploads['basedir'] . '/' . $pathinfo['dirname'];
foreach ($attach_meta['sizes'] as $size => $value) {
$image = $dir . '/' . $value['file'];
$resource = imagecreatefromjpeg($image);
if ($size == 'spalsh') {
// set the jpeg quality for 'spalsh' size
imagejpeg($resource, $image, 100);
} elseif ($size == 'spalsh1') {
// set the jpeg quality for the 'splash1' size
imagejpeg($resource, $image, 30);
} else {
// set the jpeg quality for the rest of sizes
imagejpeg($resource, $image, 10);
}
imagedestroy($resource);
}
}
}
?>
Ora visita la tua pagina Plugin e premi activate
il Update JPEG Quality
plugin. Ciò scorrerà in sequenza tutte le .jpeg
immagini caricate in precedenza e ne regolerà la qualità in base ai valori e alle condizioni specificati nel plug-in. Quindi puoi disattivare ed eliminare in modo sicuro questo plugin. Si prega di testare sull'ambiente di test prima di applicare al sito di produzione .