• By Nacho
  • 1 de agosto de 2024

Crear miniaturas de imagen con thumb_resize() en PHP

Crear miniaturas de imagen con thumb_resize() en PHP

Crear miniaturas de imagen con thumb_resize() en PHP 1024 683 Nacho

Dificultad Media

La función thumb_resize() en PHP se utiliza para redimensionar imágenes, creando versiones más pequeñas de las mismas, comúnmente conocidas como miniaturas o thumbnails. Esto es especialmente útil en galerías de imágenes, tiendas en línea y cualquier sitio web donde se necesite mostrar imágenes de manera optimizada. La función thumb_resize() es una herramienta versátil y esencial para el manejo de imágenes en PHP.

Crear miniaturas de imágenes mejora la velocidad de carga de tu sitio web y reduce el consumo de ancho de banda. Además, permite presentar una vista previa de las imágenes sin necesidad de cargar el archivo completo, mejorando la experiencia del usuario.

Implementación de thumb_resize() en PHP

Veamos cómo implementar la función thumb_resize() paso a paso. Para empezar, necesitamos usar las funciones de la biblioteca GD de PHP, que permite manipular imágenes.

Ejemplo de la función thumb_resize()

A continuación, te presento un ejemplo práctico de cómo podrías definir y utilizar la función thumb_resize():

<?php
function thumb_resize($source_image_path, $thumbnail_image_path, $thumbnail_width, $thumbnail_height) {
    list($source_width, $source_height, $source_type) = getimagesize($source_image_path);
    if ($source_type === IMAGETYPE_JPEG) {
        $source_gd_image = imagecreatefromjpeg($source_image_path);
    } elseif ($source_type === IMAGETYPE_PNG) {
        $source_gd_image = imagecreatefrompng($source_image_path);
    } elseif ($source_type === IMAGETYPE_GIF) {
        $source_gd_image = imagecreatefromgif($source_image_path);
    } else {
        return false;
    }
    $source_aspect_ratio = $source_width / $source_height;
    $thumbnail_aspect_ratio = $thumbnail_width / $thumbnail_height;
    if ($source_width <= $thumbnail_width && $source_height <= $thumbnail_height) {
        $thumbnail_width = $source_width;
        $thumbnail_height = $source_height;
    } elseif ($thumbnail_aspect_ratio > $source_aspect_ratio) {
        $thumbnail_width = (int) ($thumbnail_height * $source_aspect_ratio);
    } else {
        $thumbnail_height = (int) ($thumbnail_width / $source_aspect_ratio);
    }
    $thumbnail_gd_image = imagecreatetruecolor($thumbnail_width, $thumbnail_height);
    imagecopyresampled($thumbnail_gd_image, $source_gd_image, 0, 0, 0, 0, $thumbnail_width, $thumbnail_height, $source_width, $source_height);
    imagejpeg($thumbnail_gd_image, $thumbnail_image_path, 90);
    imagedestroy($source_gd_image);
    imagedestroy($thumbnail_gd_image);
    return true;
}
?>

Cómo utilizar thumb_resize() en un proyecto

Para utilizar la función thumb_resize(), primero asegúrate de tener una imagen de origen y especifica la ruta donde se guardará la miniatura.

Ejemplo práctico

<?php
$source_image = 'uploads/imagen.jpg';
$thumbnail_image = 'thumbnails/imagen_thumb.jpg';
$thumbnail_width = 100;
$thumbnail_height = 100;

if(thumb_resize($source_image, $thumbnail_image, $thumbnail_width, $thumbnail_height)) {
  echo "Miniatura creada con éxito.";
} else {
  echo "Error al crear la miniatura.";
}
?>

Supongamos que tienes una imagen llamada imagen.jpg en el directorio uploads/ y deseas crear una miniatura de 100×100 píxeles en el directorio

Este script llamará a la función thumb_resize(), redimensionará la imagen y guardará la miniatura en el directorio especificado.

Mejores prácticas y consideraciones

Para asegurar que la función thumb_resize() funcione de manera óptima, considera las siguientes prácticas:

Validación y manejo de errores

Siempre valida las entradas y maneja posibles errores. Verifica que los archivos de imagen existan y sean accesibles antes de procesarlos.

<?php 
if (!file_exists($source_image)) {
  die("El archivo de origen no existe.");
}
?>

Optimización de calidad

Ajusta la calidad de las miniaturas según tus necesidades. En el ejemplo proporcionado, la calidad se establece en 90 (en una escala de 0 a 100). Puedes modificar este valor para equilibrar calidad y tamaño del archivo.

Soporte para otros formatos

La función thumb_resize() puede ampliarse para soportar otros formatos de imagen como BMP o WebP. Solo necesitas añadir los casos correspondientes en el bloque condicional de la función.

if ($source_type === IMAGETYPE_WEBP) {
$source_gd_image = imagecreatefromwebp($source_image_path);
}

 

Dejar una Respuesta