主頁 > 網(wǎng)站建設(shè) > 建站知識(shí) > 原創(chuàng)dedecms縮略圖系列教程:解決dedecms縮略圖縮放

原創(chuàng)dedecms縮略圖系列教程:解決dedecms縮略圖縮放

POST TIME:2017-11-13 00:19

背景:dedecms生成縮略圖的原理不夠靈活導(dǎo)致縮略圖變形,比如后臺(tái)設(shè)置縮略圖的尺碼為:120*90即為3:2的圖片,但是假如內(nèi)容里的大圖尺碼為300*300即1:1,這樣生成出來的圖片就會(huì)變形,嚴(yán)重影響網(wǎng)站美觀,本文介紹通過修改dedecms生成縮略源碼方法解決定問題

打開“include/image.func.php”文件,該文件在dedecms5.6,5.7中所在的目錄不一樣,5.6中文件在/include/下,5.7中文件在/include/helpers/,如果你懶的找可以直接在網(wǎng)站根目錄搜索image.func.php文件

如果你使用的是dedecms5.7,打開目錄/include/helpers/找到image.helper.php文件

如果你使用的是dedecms5.6,打開目錄/include/找到image.func.php文件

5.7版image.helper.php修改方法

替換

/**

* 縮圖片自動(dòng)生成函數(shù),來源支持bmp、gif、jpg、png

* 但生成的小圖只用jpg或png格式

*

* @access public

* @param string $srcFile 圖片路徑

* @param string $toW 轉(zhuǎn)換到的寬度

* @param string $toH 轉(zhuǎn)換到的高度

* @param string $toFile 輸出文件到

* @return string

*/

/**

* 獲得GD的版本

*

* @access public

* @return int

*/

中間的代碼為:

if(!function_exists('ImageResize'))
{
functionImageResize($srcFile,$toW,$toH,$toFile="")
{
global$cfg_photo_type;
if($toFile=="")
{
$toFile=$srcFile;
}
$info="";
$srcInfo=GetImageSize($srcFile,$info);
switch($srcInfo[2])
{
case1:
if(!$cfg_photo_type['gif'])
{
returnfalse;
}
$im=imagecreatefromgif($srcFile);
break;
case2:
if(!$cfg_photo_type['jpeg'])
{
returnfalse;
}
$im=imagecreatefromjpeg($srcFile);
break;
case3:
if(!$cfg_photo_type['png'])
{
returnfalse;
}
$im=imagecreatefrompng($srcFile);
break;
case6:
if(!$cfg_photo_type['bmp'])
{
returnfalse;
}
$im=imagecreatefromwbmp($srcFile);
break;
}
$srcW=ImageSX($im);
$srcH=ImageSY($im);
if($srcW<=$toW&&$srcH<=$toH)
{
returntrue;
}
//縮略生成并裁剪
$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);
}
//裁剪圖片成標(biāo)準(zhǔn)縮略圖
$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])
{
case1:
imagegif($new_imgx,$toFile);
break;
case2:
imagejpeg($new_imgx,$toFile,85);
break;
case3:
imagepng($new_imgx,$toFile);
break;
case6:
imagebmp($new_imgx,$toFile);
break;
default:
returnfalse;
}
imagedestroy($new_imgx);
imagedestroy($ni);
}
imagedestroy($im);
returntrue;
}
}

修改好后保存文件即可,趕緊添加個(gè)帶圖片的文章試試吧,如果你不愿意修改可直接

5.6版image.func.php修改方法

替換

//縮圖片自動(dòng)生成函數(shù),來源支持bmp、gif、jpg、png

//獲得GD的版本

中間的代碼為:

functionImageResize($srcFile,$toW,$toH,$toFile="")
{
global$cfg_photo_type;
if($toFile=="")
{
$toFile=$srcFile;
}
$info="";
$srcInfo=GetImageSize($srcFile,$info);
switch($srcInfo[2])
{
case1:
if(!$cfg_photo_type['gif'])
{
returnfalse;
}
$im=imagecreatefromgif($srcFile);
break;
case2:
if(!$cfg_photo_type['jpeg'])
{
returnfalse;
}
$im=imagecreatefromjpeg($srcFile);
break;
case3:
if(!$cfg_photo_type['png'])
{
returnfalse;
}
$im=imagecreatefrompng($srcFile);
break;
case6:
if(!$cfg_photo_type['bmp'])
{
returnfalse;
}
$im=imagecreatefromwbmp($srcFile);
break;
}
$srcW=ImageSX($im);
$srcH=ImageSY($im);
if($srcW<=$toW&&$srcH<=$toH)
{
returntrue;
}
//縮略生成并裁剪
$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);
}
//裁剪圖片成標(biāo)準(zhǔn)縮略圖
$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])
{
case1:
imagegif($new_imgx,$toFile);
break;
case2:
imagejpeg($new_imgx,$toFile,85);
break;
case3:
imagepng($new_imgx,$toFile);
break;
case6:
imagebmp($new_imgx,$toFile);
break;
default:
returnfalse;
}
imagedestroy($new_imgx);
imagedestroy($ni);
}
imagedestroy($im);
returntrue;
}

可以直接

因dedecms版本的不同代碼有所不一樣,如果有問題可以找跟版網(wǎng)幫忙解決





相關(guān)文章推薦:

1.原創(chuàng)dedecms縮略圖系列教程:dede自定義多尺寸縮略圖

2.dedecms后臺(tái)文章列表頁顯示文章縮略圖

3.dedecms列表頁有縮略圖顯示圖文列表沒有則文字列表

4.dedecms利用[field:global.autoindex /]打造文章排行榜代碼

5.dedecms添加文章提示/templets/plus/win_templet.htm Not Found!



上一篇:dedecms添加文章提示/templets/plus/win_templet.htm Not F

下一篇:dedecms制作Html+Css代碼運(yùn)行框jQuery版

收縮
  • 微信客服
  • 微信二維碼
  • 電話咨詢

  • 400-1100-266