原创dedecms缩略图系列教程:dede自定义多尺寸缩略图

我们的时代成了读图世代,随着瀑布流布局的大行其道,图片在网站关的重要性日渐上升,然而缩略图作为文章的入口显的更加重要,上篇AB织梦模板网介绍了织梦dedecms解决缩略图变形的问题,本篇将介绍缩略图的另一个运用:dedecms多尺寸缩略图的调用

dedecms系统本身只支持一种尺寸的缩略图调用,即[field:litpic/],缩略图的尺寸在网站后台:DedeCMS系统配置参数》附件设置中可以设置大小,但一种尺寸的缩略图势必不能满足我们的需求,比如说我们网站经常会用到幻灯图片展示,幻灯图片的尺寸一般都是比较大的,如果用缩略图来作就不太合适,再如网站有生活风景,人物摄影这两个栏目,两类图片的比例是不相同的,如果保有一种尺寸的缩略图这样就显的很难看,下面介绍dedecms实现多种尺寸缩略图调用的方法

打开/include/extend.func.php,在文件末尾添加以下代码

function M_mkdirs($dir)  

{  

if(!is_dir($dir))  

{  

if(!M_mkdirs(dirname($dir))){  

return false;  

}  

if(!mkdir($dir,0777)){  

return false;  

}  

}  

return true;  

}  

if (!function_exists('qmtx3Thumb')) 

function qmtx3Thumb($aid, $width, $height, $n=0, $bg = false) 

{

global $cfg_basehost,$cfg_multi_site,$dsql;

$query= "SELECT body FROM `dede_addonarticle` where aid='$aid'";

$row = $dsql->GetOne($query); 

$preg = "/<img.*?src=['"](.+?)['"].*?>/i";

preg_match_all($preg, $row['body'], $match);

$imgurl = $match[1][0];

if($n==='L'){

$imgurl = end($match[1]);

}

if(!$imgurl) return '/images/defaultpic.gif';

$thumb = str_replace($cfg_basehost,'',$imgurl);

if(strpos($thumb, 'http://') === 0){

return '/images/defaultpic2.gif';

}

list($thumbname,$extname) = explode('.',$thumb); 

$newImgdir = DEDEROOT.str_replace('uploads', 'uploads/diylitpic', str_replace($cfg_basehost, '', dirname($imgurl)));

$newthumb = str_replace('uploads', 'uploads/diylitpic', $thumbname).'_'.$width.'_'.$height.'.'.$extname;

$mdsure = M_mkdirs($newImgdir);

if($mdsure){

if(!$thumbname || !$extname || !file_exists(DEDEROOT.$thumb)) return $imgurl; 

if(!file_exists(DEDEROOT.$newthumb)){ 

include_once DEDEINC.'/image.func.php'; 

if($bg==true) 

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

else 

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

return $cfg_multi_site=='Y'?$cfg_basehost.$newthumb:$newthumb; 

}else{

return '创建目录失败';

}

}

以上定义一个多级目录创建函数M_mkdirs和一个缩略图生成函数qmtx3Thumb($aid, $width, $height, $n=0, $bg = false) 

qmtx3Thumb有5个参数$aid为文档id,$width, $height为生成图片的宽、高,$n代表用内容的第几张大图生成缩略图,这里默认为0即第一张,$bg为是否强制缩略图大小一般为false

然后在模板中需要调用缩略图的地方中调用

{dede:arclist}

<img width="200" height="200" src="[field:id function='qmtx3Thumb(@me, 200, 200)'/]" />

{/dede:arclist}

注:如果你之前的缩略图就是变形的,请移动“



【免责声明】:

本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

【关于转载】:

本站尊重互联网版权体系,本站部分图片、文章大部分转载于互联网、所有内容不代表本站观点、不对文章中的任何观点负责、转载的目的只用于给网民提供信息阅读,无任何商业用途,所有内容版权归原作者所有
如本站(文章、内容、图片、视频)任何资料有侵权,先说声抱歉;麻烦您请联系请后台提交工单,我们会立即删除、维护您的权益。非常感谢您的理解。

【附】:

二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

注:本站资源来自网络转载,版权归原作者和公司所有,如果有侵犯到您的权益,请第一时间联系我们处理!

-----------------------------------------------------------------------------------------------------------

【版权声明】:

一、本站致力于为源码爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、如有内容侵犯您的版权或其他利益的,请编辑邮件并加以说明发送到站长邮箱。站长会进行审查之后,情况属实的会在三个工作日内为您删除。
-----------------------------------------------------------------------------------------------------------


内容投诉
源码村资源网 » 原创dedecms缩略图系列教程:dede自定义多尺寸缩略图
您需要 登录账户 后才能发表评论

发表评论

欢迎 访客 发表评论