實現DedeCMSv57縮略圖自動裁剪自動適應比例教程

2020-12-10


實現DedeCMSv57縮略圖自動裁剪自動適應比例教程。dedecms5.7縮略圖變形尤其體現在圖文資訊欄目里,默認的是img的HTML代碼里限制圖片的高和寬,但dedecms實際的縮略圖大小則是按照比例縮小的,未必和HTML代碼里限制的相同,最終導致了dedecms5.7縮略圖變形,這個只有通過上傳時對dedecms縮略圖進行裁剪,保證其不變性.

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

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

二、打開include/extend.func.php 在最后一個 ?> 前加入以下代碼:

  1. function thumb($imgurl, $width, $height, $bg = true)  
  2. {  
  3. global $cfg_mainsite,$cfg_multi_site;  
  4. $thumb = eregi("http://",$imgurl)?str_replace($cfg_mainsite,'',$imgurl):$imgurl;  
  5. list($thumbname,$extname) = explode('.',$thumb);  
  6. $newthumb = $thumbname.'_'.$width.'_'.$height.'.'.$extname;  
  7. if(!$thumbname || !$extname || !file_exists(DEDEROOT.$thumb)) return $imgurl;  
  8. if(!file_exists(DEDEROOT.$newthumb))  
  9. {  
  10. include_once DEDEINC.'/image.func.php';  
  11. if($bg==true)  
  12. {  
  13. ImageResizeNew(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb);  
  14. }  
  15. else 
  16. {  
  17. ImageResize(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb);  
  18. }  
  19. }  
  20. return $cfg_multi_site=='Y'?$cfg_mainsite.$newthumb:$newthumb;  
  21. }  

調用方法:標簽 : [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)'/]

0
首頁
案例
關于
聯系
凯时平台