POST TIME:2017-11-13 00:45
跟版網(wǎng)編輯:dedecms默認縮略圖的情況是等比例但尺寸不對或尺寸一直單被填充背景色,今天給出的策略方案是先縮放后裁剪。
織夢的縮略圖變形的問題一直為很多人所詬病,不過這個可以自己修改縮略圖解決,只是工程量非常的大。即使是織夢DedeCMS5.7版本,也會存在縮略圖變形失真的問題??棄鬌edeCMS縮略圖生成方式都是采用縮小或拉伸的方式進行完整顯示,如果使用的圖片和縮略圖所顯示的比例不一致的話,會使得縮略圖拉伸變形。No牛網(wǎng)的方法是對圖片進行按寬或高進行放縮,超過縮略圖大小的部分再進行裁剪,這樣生成的縮略圖的顯示效果要比原來的要好得多了。不過因為是剪裁的,會造成有些圖片重要的部分也被剪掉了,如No牛網(wǎng)做的一個美女圖片站,有些圖片一剪裁,手或者腳就“斷”了,所以這個方法僅供大家參考一下。
如何解決織夢DedeCMS5.7縮略圖變形的問題呢?還是修改織夢獲取縮略圖的函數(shù)。DedeCMS5.7的函數(shù)是在/include/helpers/文件夾中的image.helper.php里面。修改之前,一定要先對對應(yīng)的文件進行備份,防止造成無法預(yù)料的程序錯誤。先找到如下的代碼:
- $srcW=ImageSX($im);
- $srcH=ImageSY($im);
- if($srcW<=$toW&&$srcH<=$toH)
- returnTRUE;
- $toWH=$toW/$toH;
- $srcWH=$srcW/$srcH;
- if($toWH<=$srcWH){
- $ftoW=$toW;
- $ftoH=$ftoW*($srcH/$srcW);
- }
- else
- {
- $ftoH=$toH;
- $ftoW=$ftoH*($srcW/$srcH);
- }
把這部分代碼修改為如下的代碼:
- $srcW=ImageSX($im);
- $srcH=ImageSY($im);
- if($srcW<=$toW&&$srcH<=$toH)
- returnTRUE;
- $toWH=$toW/$toH;
- $srcWH=$srcW/$srcH;
- $ftoH=$toH;$ftoW=$toW;
- if($toWH<=$srcWH){
- $src_Y=0;
- $src_X=($srcW-$srcH*$toWH)/2;
- $srcW=$srcH*$toWH;
- }
- else
- {
- $src_X=0;
- $src_Y=($srcH-$srcW/$toWH)/2;
- $srcH=$srcW/$toWH;
- }
對比兩部分代碼,我們就能看到區(qū)別所在了。多了判斷圖片的面積等內(nèi)容,這樣就可以實現(xiàn)對圖片進行按寬或高進行放縮,超過縮略圖大小的部分再進行裁剪的功能。經(jīng)過這樣處理得到的縮略圖比織夢默認的縮略圖要清晰很多,除了上面已經(jīng)提到的缺點外。你也可以和No牛網(wǎng)在織夢DedeCms批量提取第一張圖片為縮略圖中提到的批量提取縮略圖的方法結(jié)合使用,這樣就可以解決你網(wǎng)站的縮略圖失真變形、無法獲取縮略圖等的問題了。
跟版網(wǎng)編輯:已經(jīng)經(jīng)過測試,dedecms v5.7版本測試通過!
本文來源:No牛網(wǎng)