織夢俠
WWW.2L3.NET

dedecms縮略圖失真模糊終極完美解決辦法

文章來自:織夢俠 本文鏈接:http://www.xtjinzuan.com/zqzb/3091.html

由于dede默認只生成一個規格大小的縮略圖,而往往在一個站不同頁面內需要的縮略圖大小不一致,比例不一致,這就造成了縮略圖不清晰,失真,下面提供的方法就完美解決了這個問題。

使用方法:
一、要獲得清晰的縮略圖就要有足夠大的圖片并準確的剪裁,而下面的方法就是根據縮略圖來進行剪裁的(因原圖部分網站有水印),所以就必須要保證原來的縮略圖足夠大,所以要進行一下設置:系統-附件設置,把縮略圖默認寬度、默認高度設為大于等于你全站所有調用縮略圖的最大尺寸,手工剪裁也請剪裁得足夠大(不需要手工剪裁了)

二、打開include/extend.func.php (注:這個文件就是為二次開發準備的,用于功能方法擴展)

在最后一個 ?> 前加入以下代碼
 
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;
 }
 
調用方法:
標簽 : [field:picname function='thumb(@me,$width,$height,$bg)'/]
參數說明:
$width:縮略圖寬度(整數)
$height:縮略圖高度(整數)
$bg:是否用空白填補,默認自動填補,背景填充顏色在系統-附件設置里(true/false)

舉例:
調用長寬為100像素的縮略圖:[field:picname function='thumb(@me,100,100)'/]
保留原有比例,不自動填充(不建議):[field:picname function='thumb(@me,100,100,false)'/]

(如果您覺得本站不錯,請告訴身邊的朋友,或轉載到論壇、百度知道、貼吧等,記得帶網址喲!)

轉載請注明文章來自織夢俠[秩名]作者的-dedecms縮略圖失真模糊終極完美解決辦法
聯系作者
取消
這個作者很懶什么也沒留下!
打賞作者
取消

本文作者無償奉獻,就打賞給我們織夢俠吧!

掃碼支付
掃碼打賞,建議金額1-10元

打開支付寶掃一掃,即可進行掃碼打賞哦

提醒:打賞金額將直接進入對方賬號,無法退款,請您謹慎操作。

蜗牛扑克