欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 织梦教程 > 如何让dedecms的缩略图不变形

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:740

高端HTML5响应式企业通用网

2020-05-06   浏览:521

html5响应式外贸网站英文版

2020-05-08   浏览:510

HTML5自适应律师工作室类网

2020-04-04   浏览:504

HTML5影视传媒文化公司类网

2020-05-12   浏览:501

如何让dedecms的缩略图不变形

发布时间:2020-08-19  

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

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

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

      默认dedecms5.7默认生成的缩略图,缩略图大小设置为: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);

本文标签

: