forked from Wavyzz/dolibarr
Amliore trs fortement la qualit des images lors de leur conversion par la fonction vignette.
This commit is contained in:
@@ -1261,13 +1261,15 @@ function img_allow($allow)
|
|||||||
function image_format_supported($file)
|
function image_format_supported($file)
|
||||||
{
|
{
|
||||||
// Case filename is not a format image
|
// Case filename is not a format image
|
||||||
if (! eregi('(\.png|\.jpg|\.jpeg)$',$file,$reg)) return -1;
|
if (! eregi('(\.gif|\.jpg|\.jpeg|\.png|\.bmp)$',$file,$reg)) return -1;
|
||||||
|
|
||||||
// Case filename is a format image but not supported by this PHP
|
// Case filename is a format image but not supported by this PHP
|
||||||
$imgfonction='';
|
$imgfonction='';
|
||||||
|
if (strtolower($reg[1]) == '.gif') $imgfonction = 'imagecreatefromgif';
|
||||||
if (strtolower($reg[1]) == '.png') $imgfonction = 'imagecreatefrompng';
|
if (strtolower($reg[1]) == '.png') $imgfonction = 'imagecreatefrompng';
|
||||||
if (strtolower($reg[1]) == '.jpg') $imgfonction = 'imagecreatefromjpeg';
|
if (strtolower($reg[1]) == '.jpg') $imgfonction = 'imagecreatefromjpeg';
|
||||||
if (strtolower($reg[1]) == '.jpeg') $imgfonction = 'imagecreatefromjpeg';
|
if (strtolower($reg[1]) == '.jpeg') $imgfonction = 'imagecreatefromjpeg';
|
||||||
|
if (strtolower($reg[1]) == '.bmp') $imgfonction = 'imagecreatefromwbmp';
|
||||||
if ($imgfonction)
|
if ($imgfonction)
|
||||||
{
|
{
|
||||||
if (! function_exists($imgfonction))
|
if (! function_exists($imgfonction))
|
||||||
@@ -1277,7 +1279,7 @@ function image_format_supported($file)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Case filename is a format image and supported by this PHP
|
// Filename is a format image and supported by this PHP
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3223,13 +3225,13 @@ function print_date_range($date_start,$date_end)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \brief Cr<43>ation d'une vignette <20> partir d'une image ($file)
|
* \brief Cr<43>ation de 2 vignettes <20> partir d'un fichier image (une small et un mini)
|
||||||
* \brief Les extension prise en compte sont jpg et png
|
* \brief Les extension prise en compte sont jpg et png
|
||||||
* \param file Chemin du fichier image <20> redimensionner
|
* \param file Chemin du fichier image <20> redimensionner
|
||||||
* \param maxWidth Largeur maximum que dois faire la miniature (160 par d<>faut)
|
* \param maxWidth Largeur maximum que dois faire la miniature (160 par d<>faut)
|
||||||
* \param maxHeight Hauteur maximum que dois faire l'image (120 par d<>faut)
|
* \param maxHeight Hauteur maximum que dois faire l'image (120 par d<>faut)
|
||||||
* \param extName Extension pour diff<66>rencier le nom de la vignette
|
* \param extName Extension pour diff<66>rencier le nom de la vignette
|
||||||
* \param quality Qualit<69> de compression jpeg
|
* \param quality Qualit<69> de compression (0=worst, 100=best)
|
||||||
* \return string Chemin de la vignette
|
* \return string Chemin de la vignette
|
||||||
*/
|
*/
|
||||||
function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $quality=50)
|
function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $quality=50)
|
||||||
@@ -3245,7 +3247,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $
|
|||||||
if (! $file)
|
if (! $file)
|
||||||
{
|
{
|
||||||
// Si le fichier n'a pas <20>t<EFBFBD> indiqu<71>
|
// Si le fichier n'a pas <20>t<EFBFBD> indiqu<71>
|
||||||
return 'Nom du fichier non renseign<67>.';
|
return 'Bad parameter file';
|
||||||
}
|
}
|
||||||
elseif (! file_exists($file))
|
elseif (! file_exists($file))
|
||||||
{
|
{
|
||||||
@@ -3268,11 +3270,12 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $
|
|||||||
$fichier = realpath($file); // Chemin canonique absolu de l'image
|
$fichier = realpath($file); // Chemin canonique absolu de l'image
|
||||||
$dir = dirname($file).'/'; // Chemin du dossier contenant l'image
|
$dir = dirname($file).'/'; // Chemin du dossier contenant l'image
|
||||||
$dirthumb = $dir.'thumbs/'; // Chemin du dossier contenant les vignettes
|
$dirthumb = $dir.'thumbs/'; // Chemin du dossier contenant les vignettes
|
||||||
|
|
||||||
$infoImg = getimagesize($fichier); // R<>cup<75>ration des infos de l'image
|
$infoImg = getimagesize($fichier); // R<>cup<75>ration des infos de l'image
|
||||||
$imgWidth = $infoImg[0]; // Largeur de l'image
|
$imgWidth = $infoImg[0]; // Largeur de l'image
|
||||||
$imgHeight = $infoImg[1]; // Hauteur de l'image
|
$imgHeight = $infoImg[1]; // Hauteur de l'image
|
||||||
|
|
||||||
// Si l'image est plus petite que la largeur et le hauteur max, on ne cr<63>e pas de vignette
|
// Si l'image est plus petite que la largeur et la hauteur max, on ne cr<63>e pas de vignette
|
||||||
if ($infoImg[0] < $maxWidth && $infoImg[1] < $maxHeight)
|
if ($infoImg[0] < $maxWidth && $infoImg[1] < $maxHeight)
|
||||||
{
|
{
|
||||||
// On cree toujours les vignettes
|
// On cree toujours les vignettes
|
||||||
@@ -3281,12 +3284,20 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $
|
|||||||
}
|
}
|
||||||
|
|
||||||
$imgfonction='';
|
$imgfonction='';
|
||||||
switch($infoImg[2]){
|
switch($infoImg[2])
|
||||||
case 2:
|
{
|
||||||
|
case 1: // IMG_GIF
|
||||||
|
$imgfonction = 'imagecreatefromgif';
|
||||||
|
break;
|
||||||
|
case 2: // IMG_JPG
|
||||||
$imgfonction = 'imagecreatefromjpeg';
|
$imgfonction = 'imagecreatefromjpeg';
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3: // IMG_PNG
|
||||||
$imgfonction = 'imagecreatefrompng';
|
$imgfonction = 'imagecreatefrompng';
|
||||||
|
break;
|
||||||
|
case 4: // IMG_WBMP
|
||||||
|
$imgfonction = 'imagecreatefromwbmp';
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if ($imgfonction)
|
if ($imgfonction)
|
||||||
{
|
{
|
||||||
@@ -3300,19 +3311,33 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $
|
|||||||
// On cr<63>e le r<>pertoire contenant les vignettes
|
// On cr<63>e le r<>pertoire contenant les vignettes
|
||||||
if (! file_exists($dirthumb))
|
if (! file_exists($dirthumb))
|
||||||
{
|
{
|
||||||
dolibarr_syslog("Product Create $dirthumb");
|
|
||||||
create_exdir($dirthumb);
|
create_exdir($dirthumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialisation des variables selon l'extension de l'image
|
// Initialisation des variables selon l'extension de l'image
|
||||||
switch($infoImg[2]){
|
switch($infoImg[2])
|
||||||
case 2:
|
{
|
||||||
$img = imagecreatefromjpeg($fichier); // Cr<43>ation d'une nouvelle image jpeg <20> partir du fichier
|
case 1: // Gif
|
||||||
$extImg = '.jpg'; // Extension de l'image
|
$img = imagecreatefromgif($fichier);
|
||||||
|
$extImg = '.gif'; // Extension de l'image
|
||||||
|
$newquality='NU';
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 2: // Jpg
|
||||||
$img = imagecreatefrompng($fichier); // Cr<43>ation d'une nouvelle image png <20> partir du fichier
|
$img = imagecreatefromjpeg($fichier);
|
||||||
|
$extImg = '.jpg'; // Extension de l'image
|
||||||
|
$newquality=$quality;
|
||||||
|
break;
|
||||||
|
case 3: // Png
|
||||||
|
$img = imagecreatefrompng($fichier);
|
||||||
$extImg = '.png';
|
$extImg = '.png';
|
||||||
|
$newquality=$quality-100;
|
||||||
|
$newquality=round(abs($quality-100)*9/100);
|
||||||
|
break;
|
||||||
|
case 4: // Bmp
|
||||||
|
$img = imagecreatefromwbmp($fichier);
|
||||||
|
$extImg = '.bmp';
|
||||||
|
$newquality='NU';
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialisation des dimensions de la vignette si elles sont sup<75>rieures <20> l'original
|
// Initialisation des dimensions de la vignette si elles sont sup<75>rieures <20> l'original
|
||||||
@@ -3332,36 +3357,74 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $
|
|||||||
$thumbHeight = $maxHeight;
|
$thumbHeight = $maxHeight;
|
||||||
$thumbWidth = $thumbHeight * $imgWhFact;
|
$thumbWidth = $thumbHeight * $imgWhFact;
|
||||||
}
|
}
|
||||||
|
$thumbHeight=round($thumbHeight);
|
||||||
|
$thumbWidth=round($thumbWidth);
|
||||||
|
|
||||||
$imgThumb = imagecreatetruecolor($thumbWidth, $thumbHeight); // Cr<EFBFBD>ation de la vignette
|
// Create empty image
|
||||||
|
$imgThumb = imagecreatetruecolor($thumbWidth, $thumbHeight);
|
||||||
|
|
||||||
|
// Activate antialiasing for better quality
|
||||||
|
if (function_exists('imageantialias'))
|
||||||
|
{
|
||||||
|
imageantialias($imgThumb, true);
|
||||||
|
}
|
||||||
|
|
||||||
// This is to keep transparent alpha channel if exists (PHP >= 4.2)
|
// This is to keep transparent alpha channel if exists (PHP >= 4.2)
|
||||||
if (function_exists('imagesavealpha'))
|
if (function_exists('imagesavealpha'))
|
||||||
{
|
{
|
||||||
imagesavealpha($imgThumb, true);
|
imagesavealpha($imgThumb, true);
|
||||||
$trans_colour = imagecolorallocatealpha($imgThumb, 0, 0, 0, 127);
|
|
||||||
imagefill($imgThumb, 0, 0, $trans_colour);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins<6E>re l'image de base redimensionn<6E>e
|
// Initialisation des variables selon l'extension de l'image
|
||||||
|
switch($infoImg[2])
|
||||||
|
{
|
||||||
|
case 1: // Gif
|
||||||
|
$trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 0); // 0, not 127 because transparent channel bugged with gif
|
||||||
|
break;
|
||||||
|
case 2: // Jpg
|
||||||
|
$trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 0);
|
||||||
|
break;
|
||||||
|
case 3: // Png
|
||||||
|
$trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 127); // Keep transparent channel
|
||||||
|
break;
|
||||||
|
case 4: // Bmp
|
||||||
|
$trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
imagefill($imgThumb, 0, 0, $trans_colour);
|
||||||
|
|
||||||
$fileName = eregi_replace('(\.jpeg|\.jpg|\.png)$','',$file); // On enleve extension quelquesoit la casse
|
dolibarr_syslog("vignette: convert image from ($imgWidth x $imgHeight) to ($thumbWidth x $thumbHeight) as $extImg, newquality=$newquality");
|
||||||
|
//imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins<6E>re l'image de base redimensionn<6E>e
|
||||||
|
imagecopyresampled($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins<6E>re l'image de base redimensionn<6E>e
|
||||||
|
|
||||||
|
$fileName = eregi_replace('(\.gif|\.jpeg|\.jpg|\.png|\.bmp)$','',$file); // On enleve extension quelquesoit la casse
|
||||||
$fileName = basename($fileName);
|
$fileName = basename($fileName);
|
||||||
$imgThumbName = $dirthumb.$fileName.$extName.$extImg; // Chemin complet du fichier de la vignette
|
$imgThumbName = $dirthumb.$fileName.$extName.$extImg; // Chemin complet du fichier de la vignette
|
||||||
|
|
||||||
//Cr<EFBFBD>ation du fichier de la vignette
|
// Check if permission are ok
|
||||||
$fp = fopen($imgThumbName, "w");
|
//$fp = fopen($imgThumbName, "w");
|
||||||
fclose($fp);
|
//fclose($fp);
|
||||||
|
|
||||||
// Renvoi la vignette cr<63><72>e
|
// Create image on disk
|
||||||
switch($infoImg[2]){
|
switch($infoImg[2])
|
||||||
case 2:
|
{
|
||||||
imagejpeg($imgThumb, $imgThumbName, $quality); // Renvoi d'une image jpeg avec une qualit<69> de 50 par d<>faut
|
case 1: // Gif
|
||||||
|
imagegif($imgThumb, $imgThumbName);
|
||||||
|
break;
|
||||||
|
case 2: // Jpg
|
||||||
|
imagejpeg($imgThumb, $imgThumbName, $newquality);
|
||||||
|
break;
|
||||||
|
case 3: // Png
|
||||||
|
imagepng($imgThumb, $imgThumbName, $newquality);
|
||||||
|
break;
|
||||||
|
case 4: // Bmp
|
||||||
|
image2wmp($imgThumb, $imgThumbName);
|
||||||
break;
|
break;
|
||||||
case 3:
|
|
||||||
imagepng($imgThumb, $imgThumbName);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Free memory
|
||||||
|
imagedestroy($imgThumb);
|
||||||
|
|
||||||
return $imgThumbName;
|
return $imgThumbName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user