主頁(yè) > 網(wǎng)站建設(shè) > 建站知識(shí) > 快速解決dede織夢(mèng)縮略圖變形

快速解決dede織夢(mèng)縮略圖變形

POST TIME:2018-04-22 19:25

DedeCms縮略圖變形尤其體現(xiàn)在圖文資訊欄目里,默認(rèn)的是img的HTML代碼里限制圖片的高和寬,但DEDECMS 實(shí)際的縮略圖大小則是按照比例縮小的,未必和HTML代碼里限制的相同,最終導(dǎo)致了DEDECMS 縮略圖變形,這個(gè)只有通過上傳時(shí)對(duì)DEDECMS縮略圖進(jìn)行裁剪,保證其不變性.  dede默認(rèn)只生成一個(gè)規(guī)格大小的縮略圖,而往往在一個(gè)站不同頁(yè)面內(nèi)需要的縮略圖大小不一致,比例不一致,這就造成了縮略圖不清晰,失真,下面提供的方法就完美解決了這個(gè)問題。

使用方法:

一、要獲得清晰的dede縮略圖就要有足夠大的圖片并準(zhǔn)確的剪裁,而下面的方法就是根據(jù)縮略圖來(lái)進(jìn)行剪裁的(因原圖部分網(wǎng)站有水印),所以就必須要保證 原來(lái)的縮略圖足夠大,所以要進(jìn)行一下設(shè)置:系統(tǒng)-附件設(shè)置,把縮略圖默認(rèn)寬度、默認(rèn)高度設(shè)為大于等于你全站所有調(diào)用縮略圖的最大尺寸,手工剪裁也請(qǐng)剪裁得 足夠大(不需要手工剪裁了)

二、打開include/extend.func.php (注:這個(gè)文件就是為二次開發(fā)準(zhǔn)備的,用于功能方法擴(kuò)展)

在最后一個(gè) ?> 前加入以下代碼

 function thumb($imgurl, $width, $height, $bg = true) 
{ 
global $cfg_mainsite,$cfg_multi_site; 
$thumb = eregi("http://",$imgurl)?str_replace($cfg_mainsite,'',$imgurl):$imgurl; 
list($thumbname,$extname) = explode('.',$thumb); 
$newthumb = $thumbname.'_'.$width.'_'.$height.'.'.$extname; 
if(!$thumbname || !$extname || !file_exists(DEDEROOT.$thumb)) return $imgurl; 
if(!file_exists(DEDEROOT.$newthumb)) 
{ 
include_once DEDEINC.'/image.func.php'; 
if($bg==true) 
{ 
ImageResizeNew(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb); 
} 
else 
{ 
ImageResize(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb); 
} 
} 
return $cfg_multi_site=='Y'?$cfg_mainsite.$newthumb:$newthumb; 
}

調(diào)用方法:
標(biāo)簽 : [field:picname function='thumb(@me,$width,$height,$bg)'/]

參數(shù)說(shuō)明:

$width:縮略圖寬度(整數(shù))

$height:縮略圖高度(整數(shù))

$bg:是否用空白填補(bǔ),默認(rèn)自動(dòng)填補(bǔ),背景填充顏色在系統(tǒng)-附件設(shè)置里(true/false)

舉例:

調(diào)用長(zhǎng)寬為100像素的縮略圖:[field:picname function='thumb(@me,100,100)'/]

保留原有比例,不自動(dòng)填充(不建議):[field:picname function='thumb(@me,100,100,false)'/]



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

  • 400-1100-266