最土团购添加图片自动水印的解决方法

   2015-08-02 0
核心提示:最土团购程序,是基于Web应用的B/S架构的团购网站建设解决方案的建站系统,它可以让用户高效、快速、低成本的构建个性化、专业化、强大功能的团购网站。
新版本已经支持自动水印了好像,如果不支持可以参考下面的方法
最土团购的程序,没有实现自动添加水印,其实这个功能并不难,只需要添加几行简单的代码就能实现。

  首先,需要一个添加水印的函数。网上遍地都是,我随便找来一个,如下:

复制代码
代码如下:

function setWater($imgSrc,$markImg,$markText,$TextColor,$markPos,$fontType,$markType)
{
$srcInfo = @getimagesize($imgSrc);
$srcImg_w = $srcInfo[0];
$srcImg_h = $srcInfo[1];
switch ($srcInfo[2])
{
case 1:
$srcim =imagecreatefromgif($imgSrc);
break;
case 2:
$srcim =imagecreatefromjpeg($imgSrc);
break;
case 3:
$srcim =imagecreatefrompng($imgSrc);
break;
default:
return;
}
if(!strcmp($markType,"img"))
{
if(!file_exists($markImg) || empty($markImg))
{
return;
}
$markImgInfo = @getimagesize($markImg);
$markImg_w = $markImgInfo[0];
$markImg_h = $markImgInfo[1];
if($srcImg_w < $markImg_w || $srcImg_h < $markImg_h)
{
return;
}
switch ($markImgInfo[2])
{
case 1:
$markim =imagecreatefromgif($markImg);
break;
case 2:
$markim =imagecreatefromjpeg($markImg);
break;
case 3:
$markim =imagecreatefrompng($markImg);
break;
default:
return;
}
$logow = $markImg_w;
$logoh = $markImg_h;
}
if(!strcmp($markType,"text"))
{
$fontSize = 30;
if(!empty($markText))
{
if(!file_exists($fontType))
{
return;
}
}
else {
return;
}
$box = @imagettfbbox($fontSize, 0, $fontType,$markText);
$logow = max($box[2], $box[4]) - min($box[0], $box[6]);
$logoh = max($box[1], $box[3]) - min($box[5], $box[7]);
}
if($markPos == 0)
{
$markPos = rand(1, 9);
}
switch($markPos)
{
case 1:
$x = +5;
$y = +5;
break;
case 2:
$x = ($srcImg_w - $logow) / 2;
$y = +5;
break;
case 3:
$x = $srcImg_w - $logow - 5;
$y = +15;
break;
case 4:
$x = +5;
$y = ($srcImg_h - $logoh) / 2;
break;
case 5:
$x = ($srcImg_w - $logow) / 2;
$y = ($srcImg_h - $logoh) / 2;
break;
case 6:
$x = $srcImg_w - $logow - 5;
$y = ($srcImg_h - $logoh) / 2;
break;
case 7:
$x = +5;
$y = $srcImg_h - $logoh - 5;
break;
case 8:
$x = ($srcImg_w - $logow) / 2;
$y = $srcImg_h - $logoh - 5;
break;
case 9:
$x = $srcImg_w - $logow - 5;
$y = $srcImg_h - $logoh -5;
break;
default:
return;
}
$dst_img = @imagecreatetruecolor($srcImg_w, $srcImg_h);
imagecopy ( $dst_img, $srcim, 0, 0, 0, 0, $srcImg_w, $srcImg_h);
if(!strcmp($markType,"img"))
{
imagecopy($dst_img, $markim, $x, $y, 0, 0, $logow, $logoh);
imagedestroy($markim);
}
if(!strcmp($markType,"text"))
{
$rgb = explode(',', $TextColor);
$color = imagecolorallocate($dst_img, $rgb[0], $rgb[1], $rgb[2]);
imagettftext($dst_img, $fontSize, 0, $x, $y, $color, $fontType,$markText);
}
switch ($srcInfo[2])
{
case 1:
imagegif($dst_img, $imgSrc);
break;
case 2:
imagejpeg($dst_img, $imgSrc);
break;
case 3:
imagepng($dst_img, $imgSrc);
break;
default:
return;
}
imagedestroy($dst_img);
imagedestroy($srcim);
} 

 把这个函数添加到/include/function/common.php文件中就行了,在需要用到的地方即可调用。

  最土团购系统上传图片,主要有两种方式,一个是团购项目里的封面图片或者商家的封面图片,也就是需要点击“浏览”按钮,上传的图片。还有一种图片,是文本编辑框里上传的图片。我们先来添加文本编辑框上传图片的代码。这段代码在根目录的upload.php文件里,在function uploadfile($inputname)函数中,大概91行的位置,找到

复制代码
代码如下:

else $msg=array(‘url’=>$target,’localname’=>$upfile['name'],’id’=>’1′);  

在这行代码下面添加水印代码

复制代码
代码如下:

if(option_yes('imgwater')){
$imgsrc = $attach_dir.'/'.$fname;
setWater($imgsrc,$_SERVER['DOCUMENT_ROOT'].'/static/img/logo_water.png','','#000000',9,'','img');
}  

这段代码里,大家需要关注的,只有

'/static/img/logo_water.png'  这个水印图片的位置,大家自己做好水印图片,放到指定位置即可,路径随便定义,只要这里写对就行了,我默认是放在了/static/img/目录下,图片文件名称为logo_water.png

  对于封面图片上传的代码,跟文本编辑框的上传代码是一样的,需要修改的代码在/include/function/common.php这个文件中,找到function upload_image($input, $image=null, $type=’team’, $scale=false)这个函数,再找到其中的return $image;这行,在第一return $image;前面,添加代码

复制代码
代码如下:

if(option_yes('imgwater')){
$imgsrc = $attach_dir.'/'.$fname;
setWater($imgsrc,$_SERVER['DOCUMENT_ROOT'].'/static/img/logo_water.png','','#000000',9,'','img');
}  

大家可以通过修改水印图片的路径,来更换不同的水印,以便与文本编辑框中的水印区别开。

  好了,现在代码基本添加完毕,最后,在后台还要添加一个配置水印功能是否开启。

  在/include/tempalte/文件夹下找到模板文件manage_system_option.html .大家照猫画虎,参考其他配置,将如下代码添加到文件中。

复制代码
代码如下:

<div class="field">
<label>图片添加水印</label>
<select name="option[imgwater]" style="float:left;">${Utility::Option($option_yn, option_yesv('imgwater'))}</select>
<span class="inputtip">是否开启图片添加水印功能</span>
</div>

  好了,添加水印的基本功能就实现了,大家去试试看吧。有什么不足的地方或者建议,可以给我留言。
 
标签: 水印
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

点击排行