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