织梦DedeCMS实现缩略图不拉伸变形的方法

      织梦cms目前几个最新版本的缩略图生成方式都是采用缩小或拉伸的方式进行完整显示,如果使用的图片和缩略图所显示的比例不一致的话,会使得缩略图拉伸变形。如果不改变织梦目前的缩略图显示方式的话,又想缩略图不拉伸变形显示,就得制作一个和显示缩略图位置大小一致或者图片比例一致且大于缩略图的分辨率就会不拉伸变形了。

      我们可以通过下面方法修改实现,对图片进行按宽或高进行放缩,超过缩略图大小的部分再进行裁剪,这样生成的缩略图的显示效果要比原来的要好得多了。同时也可以采取之际制作好分辨率一致的缩略图进行显示。

      于是重新修改了一下DedeCms v5.6缩略图生成方法。

      默认dedecms5.6默认生成的缩略图,缩略图大小设置为:100*100(直接把图片缩小了)

      看起来很不美观,影响了图片的观赏性

      DedeCMS v5.6缩略图裁剪优化方法

      修改如下:
      打开/includes/image.func.php文件,
      //缩图片自动生成函数,来源支持bmp、gif、jpg、png
      //但生成的小图只用jpg或png格式
      找到代码第44行function ImageResize
      至
      //获得GD的版本之间的代码,用如下的代码覆盖(大家请注意备份)。

 function ImageResize($srcFile,$toW,$toH,$toFile="")
{
global $cfg_photo_type;
if($toFile=="")
{
   $toFile = $srcFile;
}
$info = "";
$srcInfo = GetImageSize($srcFile,$info);
switch ($srcInfo[2])
{
   case 1:
    if(!$cfg_photo_type['gif'])
    {
     return false;
    }
    $im = imagecreatefromgif($srcFile);
    break;
   case 2:
    if(!$cfg_photo_type['jpeg'])
    {
     return false;
    }
    $im = imagecreatefromjpeg($srcFile);
    break;
   case 3:
    if(!$cfg_photo_type['png'])
    {
     return false;
    }
    $im = imagecreatefrompng($srcFile);
    break;
   case 6:
    if(!$cfg_photo_type['bmp'])
    {
     return false;
    }
    $im = imagecreatefromwbmp($srcFile);
    break;
}
$srcW=ImageSX($im);
$srcH=ImageSY($im);
if($srcW<=$toW && $srcH<=$toH )
{
   return true;
}
//缩略生成并裁剪
$newW = $toH * $srcW / $srcH;
           $newH = $toW * $srcH / $srcW;
if($newH >= $toH)
{
   $ftoW = $toW;
   $ftoH = $newH;
}
else
{
                     $ftoW = $newW;
   $ftoH = $toH;
}
           if($srcW>$toW||$srcH>$toH)
{
   if(function_exists("imagecreatetruecolor"))
   {
    @$ni = imagecreatetruecolor($ftoW,$ftoH);
    if($ni)
    {
     imagecopyresampled($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);
    }
    else
    {
     $ni=imagecreate($ftoW,$ftoH);
     imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);
    }
   }
   else
   {
    $ni=imagecreate($ftoW,$ftoH);
    imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH);
   }
   //裁剪图片成标准缩略图
   $new_imgx = imagecreatetruecolor($toW,$toH);
   if($newH >= $toH)
   {
    imagecopyresampled($new_imgx,$ni,0,0,0,($newH - $toH)/2,$toW,$toH,$toW,$toH);
   }
   else
   {
    imagecopyresampled($new_imgx,$ni,0,0,($newW - $toW)/2,0,$toW,$toH,$toW,$toH);
   }
   switch ($srcInfo[2])
   {
    case 1:
     imagegif($new_imgx,$toFile);
     break;
    case 2:
     imagejpeg($new_imgx,$toFile,85);
     break;
    case 3:
     imagepng($new_imgx,$toFile);
     break;
    case 6:
     imagebmp($new_imgx,$toFile);
     break;
    default:
     return false;
   }
   imagedestroy($new_imgx);
   imagedestroy($ni);
}
imagedestroy($im);
return true;
}

支付宝扫码打赏 微信扫码打赏

如果本文对你有帮助,欢迎打赏本站

喜欢 ()or分享
    匿名评论
  • 评论
人参与,条评论