En las imágenes trabajadas automáticamente con Php nos enfrentamos a la pérdida del color y la calidad de las mismas.
Buscando en php.net he conseguido una función que permite regenerar prácticamente una imagen con su color real, una de las principales deficiencias cuando usamos sistemas de Thumbnail.
Esta función es: imagecreatetruecolor($ancho, $alto); El resto del proceso ya lo conocemos.
header("Content-type: image/jpeg");
$src_img= @imagecreatefromjpeg(LA IMAGEN.JPG)
$dst_img = @imagecreatetruecolor($ANCHO,$ALTO);
@imagecopyresized($dst_img, $src_img, 0,0,0,0, $ANCHO, $ALTO, ImageSX($src_img), ImageSY($src_img));
@imagejpeg($dst_img);
@imagedestroy($dst_img);
Explicación:
En primer lugar enviamos una cabecera pura con el tipo de documento:
header();
Guardamos en la variable $src_img una nueva imagen creada de tipo JPEG apartir de LA IMAGEN.JPG que será la imagen que redimensionaremos o la editaremos.
Luego en la variable $dest_img, Creamos una imagen nueva con color REAL, esta será la que utilizaremos para mostrarla, nótese que no esta definidas las variables $ANCHO, $ALTO. Estas variables guardan el nuevo tamaño de la imagen que obviamente sera inferior a la original, por lo cual pueden ayudarse con la función getsizeimage(); que bueno devuelve un vector con los píxeles de X y Y , o en su efecto ImageSX() y ImageSY() para obtener en base a esos parámetros el nuevo tamaño uniforme y acorde con nuestra galería de imágenes.
Imagecopyresized(), bueno el nombre lo dice, copia solo partes de una imagen REDIMENSIONADA .
Luego mostramos la imagen con imagejpeg(); si queremos que se guarde en el directorio con sus respectivos permisos, agregaremos un nuevo parámetro:
@imagejpeg($dst_img,'NUEVAIMAGEN.JPG');
Destruimos la imagen para ahorrar memoria utilizada por imagecreatefromjpeg() y los procesos subsiguientes;
Y bueno, como ya sabemos, la @ (arroba) al comienzo de cada función sirve para evitar que se imprima el error en pantalla. Si es de su preferencia pueden quitarlas.
Esta función es: imagecreatetruecolor($ancho, $alto); El resto del proceso ya lo conocemos.
header("Content-type: image/jpeg");
$src_img= @imagecreatefromjpeg(LA IMAGEN.JPG)
$dst_img = @imagecreatetruecolor($ANCHO,$ALTO);
@imagecopyresized($dst_img, $src_img, 0,0,0,0, $ANCHO, $ALTO, ImageSX($src_img), ImageSY($src_img));
@imagejpeg($dst_img);
@imagedestroy($dst_img);
Explicación:
En primer lugar enviamos una cabecera pura con el tipo de documento:
header();
Guardamos en la variable $src_img una nueva imagen creada de tipo JPEG apartir de LA IMAGEN.JPG que será la imagen que redimensionaremos o la editaremos.
Luego en la variable $dest_img, Creamos una imagen nueva con color REAL, esta será la que utilizaremos para mostrarla, nótese que no esta definidas las variables $ANCHO, $ALTO. Estas variables guardan el nuevo tamaño de la imagen que obviamente sera inferior a la original, por lo cual pueden ayudarse con la función getsizeimage(); que bueno devuelve un vector con los píxeles de X y Y , o en su efecto ImageSX() y ImageSY() para obtener en base a esos parámetros el nuevo tamaño uniforme y acorde con nuestra galería de imágenes.
Imagecopyresized(), bueno el nombre lo dice, copia solo partes de una imagen REDIMENSIONADA .
Luego mostramos la imagen con imagejpeg(); si queremos que se guarde en el directorio con sus respectivos permisos, agregaremos un nuevo parámetro:
@imagejpeg($dst_img,'NUEVAIMAGEN.JPG');
Destruimos la imagen para ahorrar memoria utilizada por imagecreatefromjpeg() y los procesos subsiguientes;
Y bueno, como ya sabemos, la @ (arroba) al comienzo de cada función sirve para evitar que se imprima el error en pantalla. Si es de su preferencia pueden quitarlas.
Emmanuel García De Caro
Webmaster de Blasten.com