找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1239|回复: 0

[分享] 解决dedecms缩略图变形问题 dede缩略图按比例裁剪

[复制链接]
发表于 2018-3-16 14:57:01 | 显示全部楼层 |阅读模式 来自 河南省新乡市
DECMS缩略图变形尤其体现在图文资讯栏目里,默认的是img的HTML代码里限制图片的高和宽,但DEDECMS 实际的缩略图大小则是按照比例缩小的,未必和HTML代码里限制的相同,最终导致了DEDECMS 缩略图变形,这个只有通过上传时对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)'/]

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-4-17 05:24 , Processed in 0.041965 second(s), 10 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表