设为首页 - 加入收藏
您的当前位置:主页 > CMS教程 > 织梦CMS > 正文

织梦CMS5.7生成缩略图大小自适应调用尺寸及缩略图自动裁剪

来源:网络收集 点击数: 时间:2018-02-08

 温馨提示:修改前请做好备份事情。

-------
A.首先在网站后台系统中设置网站缩略图尺寸大小和模板中调用图片最大尺寸同样。
B.再打开文件"include/helpers/extend.helpes.php"在最下面加上以下代码

  1. if ( ! function_exists('thumb')) 

  2. function thumb($imgurl, $width, $height, $bg = true) 

  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. include_once DEDEINC.'/image.func.php'; 

  10. if($bg==true) 

  11. ImageResizeNew(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb); 

  12. else 

  13. ImageResize(DEDEROOT.$thumb, $width, $height, DEDEROOT.$newthumb); 

  14. return $cfg_multi_site=='Y'?$cfg_mainsite.$newthumb:$newthumb; 

  15. }


调用方法:
标签 : [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)'/]


----

C.再到 include/helpers/image.helpes.php 中写入以下代码

/** 

  1. * 缩图片自动生成函数,来源支持bmp、gif、jpg、png 

  2. * 但生成的小图只用jpg或png格式 

  3. * @access public 

  4. * @param string $srcFile

  5. * @param string $toW 转换到的宽度 

  6. * @param string $toH 转换到的高度

  7. * @param string $toFile 输出文件到 

  8. * @return string 

  9. */ 

  10. if ( ! function_exists('ImageResize')) 

  11. function ImageResize($srcFile, $toW, $toH, $toFile="") 

  12. global $cfg_photo_type; 

  13. if($toFile=="") 

  14. $toFile = $srcFile; 

  15. $info = ""; 

  16. $srcInfo = GetImageSize($srcFile,$info); 

  17. switch ($srcInfo[2]) 

  18. case 1: 

  19. if(!$cfg_photo_type['gif']) 

  20. return false; 

  21. $im = imagecreatefromgif($srcFile); 

  22. break; 

  23. case 2: 

  24. if(!$cfg_photo_type['jpeg']) 

  25. return false; 

  26. $im = imagecreatefromjpeg($srcFile); 

  27. break; 

  28. case 3: 

  29. if(!$cfg_photo_type['png']) 

  30. return false; 

  31. $im = imagecreatefrompng($srcFile); 

  32. break; 

  33. case 6: 

  34. if(!$cfg_photo_type['bmp']) 

  35. return false; 

  36. $im = imagecreatefromwbmp($srcFile); 

  37. break; 

  38. $srcW=ImageSX($im); 

  39. $srcH=ImageSY($im); 

  40. if($srcW<=$toW && $srcH<=$toH ) 

  41. return true; 

  42. //缩略生成并裁剪 

  43. $newW = $toH * $srcW / $srcH; 

  44. $newH = $toW * $srcH / $srcW; 

  45. if($newH >= $toH) 

  46. $ftoW = $toW; 

  47. $ftoH = $newH; 

  48. else 

  49. $ftoW = $newW; 

  50. $ftoH = $toH; 

  51. if($srcW>$toW||$srcH>$toH) 

  52. if(function_exists("imagecreatetruecolor")) 

  53. @$ni = imagecreatetruecolor($ftoW,$ftoH); 

  54. if($ni) 

  55. imagecopyresampled($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH); 

  56. else 

  57. $ni=imagecreate($ftoW,$ftoH); 

  58. imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH); 

  59. else 

  60. $ni=imagecreate($ftoW,$ftoH); 

  61. imagecopyresized($ni,$im,0,0,0,0,$ftoW,$ftoH,$srcW,$srcH); 

  62. //裁剪图片成标准缩略图 

  63. $new_imgx = imagecreatetruecolor($toW,$toH); 

  64. if($newH >= $toH) 

  65. imagecopyresampled($new_imgx,$ni,0,0,0,($newH - $toH)/2,$toW,$toH,$toW,$toH); 

  66. else 

  67. imagecopyresampled($new_imgx,$ni,0,0,($newW - $toW)/2,0,$toW,$toH,$toW,$toH); 

  68. switch ($srcInfo[2]) 

  69. case 1: 

  70. imagegif($new_imgx,$toFile); 

  71. break; 

  72. case 2: 

  73. imagejpeg($new_imgx,$toFile,85); 

  74. break; 

  75. case 3: 

  76. imagepng($new_imgx,$toFile); 

  77. break; 

  78. case 6: 

  79. imagebmp($new_imgx,$toFile); 

  80. break; 

  81. default: 

  82. return false; 

  83. imagedestroy($new_imgx); 

  84. imagedestroy($ni); 

  85. imagedestroy($im); 

  86. return true; 

  87. }

A3站长网 站长网 站长网技术网 站长教程网 织梦CMS教程 织梦模板 帝国CMS模板 联系QQ:26991496 邮箱:26991496@qq.com

A3站长网:欢迎您!谢谢您的访问...

Top