rinald_未来往事

ueditor1.4上传图片水印

PHP
ueditor上传图片加水印,ueditor1.4.3 水印,ueditor1.4.3 图片水印,ueditor 1.4.3上传图片添加水印,ueditor图片水印控制

打开UEditor压缩包下php目录中的上传类文件:Uploader.class.php
在上传文件的主要方法下添加调用水印处理方法:

  1. /**
  2. * 上传文件的主处理方法
  3. * @return mixed
  4. */
  5. private function upFile()
  6. {
  7. ……………………
  8. ……………………
  9. $this->stateInfo = $this->stateMap[0]; //(大概在122行)
  10. //在下面加入如下调用水印的处理方法:
  11. $this->imageWaterMark($this->filePath,9,'../img/watermark.png'); //注释见本文下面imageWaterMark()函数方法
  12. ……………………
  13. 欢迎来访未来往事<http://fity.cn>
  14. }
水印处理方法/函数:
  1. /**
  2. * 功能:PHP图片水印 (水印支持图片或文字)
  3. * 参数:
  4. * $groundImage 背景图片,即需要加水印的图片,暂只支持GIF,JPG,PNG格式;
  5. * $waterPos水印位置,有10种状态,0为随机位置;
  6. * 1为顶端居左,2为顶端居中,3为顶端居右;
  7. * 4为中部居左,5为中部居中,6为中部居右;
  8. * 7为底端居左,8为底端居中,9为底端居右;
  9. * $waterImage图片水印,即作为水印的图片,暂只支持GIF,JPG,PNG格式;
  10. * $waterText文字水印,即把文字作为为水印,支持ASCII码,不支持中文;
  11. * $textFont文字大小,值为1、2、3、4或5,默认为5;
  12. * $textColor文字颜色,值为十六进制颜色值,默认为#FF0000(红色);
  13. *
  14. * 注意:Support GD 2.0,Support FreeType、GIF Read、GIF Create、JPG 、PNG
  15. * $waterImage 和 $waterText 最好不要同时使用,选其中之一即可,优先使用 $waterImage。
  16. * 当$waterImage有效时,参数$waterString、$stringFont、$stringColor均不生效。
  17. * 加水印后的图片的文件名和 $groundImage 一样。
  18. * Author: 未来往事<http://fity.cn - rinald@fity.cn>
  19. */
  20. private function imageWaterMark($groundImage,$waterPos=0,$waterImage="",$waterText="",$textFont=5,$textColor="#FF0000")
  21. {
  22. $isWaterImage = FALSE;
  23. $formatMsg = "暂不支持该文件格式,请用图片处理软件将图片转换为GIF、JPG、PNG格式。";
  24. //读取水印文件
  25. if(!empty($waterImage) && file_exists($waterImage))
  26. {
  27. $isWaterImage = TRUE;
  28. $water_info = getimagesize($waterImage);
  29. $water_w = $water_info[0];//取得水印图片的宽
  30. $water_h = $water_info[1];//取得水印图片的高
  31. switch($water_info[2])//取得水印图片的格式
  32. {
  33. case 1:$water_im = imagecreatefromgif($waterImage);break;
  34. case 2:$water_im = imagecreatefromjpeg($waterImage);break;
  35. case 3:$water_im = imagecreatefrompng($waterImage);break;
  36. default:die($formatMsg);
  37. }
  38. }
  39. //读取背景图片
  40. if(!empty($groundImage) && file_exists($groundImage))
  41. {
  42. $ground_info = getimagesize($groundImage);
  43. $ground_w = $ground_info[0];//取得背景图片的宽
  44. $ground_h = $ground_info[1];//取得背景图片的高
  45. switch($ground_info[2])//取得背景图片的格式
  46. {
  47. case 1:$ground_im = imagecreatefromgif($groundImage);break;
  48. case 2:$ground_im = imagecreatefromjpeg($groundImage);break;
  49. case 3:$ground_im = imagecreatefrompng($groundImage);break;
  50. default:die($formatMsg);
  51. }
  52. }
  53. else
  54. {
  55. die("需要加水印的图片不存在!");
  56. }
  57. //水印位置
  58. if($isWaterImage)//图片水印
  59. {
  60. $w = $water_w;
  61. $h = $water_h;
  62. $label = "图片的";
  63. }
  64. else//文字水印
  65. {
  66. $temp = imagettfbbox(ceil($textFont*5),0,"./cour.ttf",$waterText);//取得使用 TrueType 字体的文本的范围
  67. $w = $temp[2] - $temp[6];
  68. $h = $temp[3] - $temp[7];
  69. unset($temp);
  70. $label = "文字区域";
  71. }
  72. if( ($ground_w<$w) || ($ground_h<$h) )
  73. {
  74. echo "需要加水印的图片的长度或宽度比水印".$label."还小,无法生成水印!";
  75. return;
  76. }
  77. switch($waterPos)
  78. {
  79. case 0://随机
  80. $posX = rand(0,($ground_w - $w));
  81. $posY = rand(0,($ground_h - $h));
  82. break;
  83. case 1://1为顶端居左
  84. $posX = 0;
  85. $posY = 0;
  86. break;
  87. case 2://2为顶端居中
  88. $posX = ($ground_w - $w) / 2;
  89. $posY = 0;
  90. break;
  91. case 3://3为顶端居右
  92. $posX = $ground_w - $w;
  93. $posY = 0;
  94. break;
  95. case 4://4为中部居左
  96. $posX = 0;
  97. $posY = ($ground_h - $h) / 2;
  98. break;
  99. case 5://5为中部居中
  100. $posX = ($ground_w - $w) / 2;
  101. $posY = ($ground_h - $h) / 2;
  102. break;
  103. case 6://6为中部居右
  104. $posX = $ground_w - $w;
  105. $posY = ($ground_h - $h) / 2;
  106. break;
  107. case 7://7为底端居左
  108. $posX = 0;
  109. $posY = $ground_h - $h;
  110. break;
  111. case 8://8为底端居中
  112. $posX = ($ground_w - $w) / 2;
  113. $posY = $ground_h - $h;
  114. break;
  115. case 9://9为底端居右
  116. $posX = $ground_w - $w - 10; // -10 是距离右侧10px 可以自己调节
  117. $posY = $ground_h - $h - 10; // -10 是距离底部10px 可以自己调节
  118. break;
  119. default://随机
  120. $posX = rand(0,($ground_w - $w));
  121. $posY = rand(0,($ground_h - $h));
  122. break;
  123. }
  124. //设定图像的混色模式
  125. imagealphablending($ground_im, true);
  126. if($isWaterImage)//图片水印
  127. {
  128. imagecopy($ground_im, $water_im, $posX, $posY, 0, 0, $water_w,$water_h);//拷贝水印到目标文件
  129. }
  130. else//文字水印
  131. {
  132. if( !emptyempty($textColor) && (strlen($textColor)==7) )
  133. {
  134. $R = hexdec(substr($textColor,1,2));
  135. $G = hexdec(substr($textColor,3,2));
  136. $B = hexdec(substr($textColor,5));
  137. }
  138. else
  139. {
  140. die("水印文字颜色格式不正确!");
  141. }
  142. imagestring ( $ground_im, $textFont, $posX, $posY, $waterText, imagecolorallocate($ground_im, $R, $G, $B));
  143. }
  144. //生成水印后的图片
  145. @unlink($groundImage);
  146. switch($ground_info[2])//取得背景图片的格式
  147. {
  148. case 1:imagegif($ground_im,$groundImage);break;
  149. case 2:imagejpeg($ground_im,$groundImage);break;
  150. case 3:imagepng($ground_im,$groundImage);break;
  151. default:die($errorMsg);
  152. }
  153. //释放内存
  154. if(isset($water_info)) unset($water_info);
  155. if(isset($water_im)) imagedestroy($water_im);
  156. unset($ground_info);
  157. imagedestroy($ground_im);
  158. }
  159. 欢迎来访未来往事<http://fity.cn>
基于上述方法,你也可以在多图上传中添加相关选项让用户自定义选择水印添加的位置。
A simple example:


(1)使用UEditor编辑器的serverparam参数,参数作用:自定义请求参数
视图中添加允许用户自主选择是否添加水印的checkbox,代码:

  1. <input type="checkbox" name="wmid" id="wmid_fmdata[content]" checked="checked" onclick="cancelwm(this);" /><label for="wmid_fmdata[content]">水印</label> <span style="color:red;">(提示:每次上传前可选择是否使用水印)</span></span>

视图中添加如下代码追加向后台发出请求时添加wm参数:

  1. <!--实时添加水印功能开始-->
  2. ue.ready(function() { //页面初始化完成默认为加水印状态
  3. UE.getEditor('editor').execCommand('serverparam', 'wm', 1);
  4. });
  5. function cancelwm(t){
  6. if(t.checked){
  7. UE.getEditor('editor').execCommand('serverparam', 'wm', 1);
  8. }else{
  9. UE.getEditor('editor').execCommand('serverparam', 'wm', 0);
  10. }
  11. }
  12. 欢迎来访未来往事<http://fity.cn>

(2)action_upload.php附件上传控制代码文件中获取wm参数并初始化上传类:

  1. /*
  2. * 判断是否添加水印
  3. */
  4. $wm = $_GET['wm'];
  5. $up = new Uploader($fieldName, $config, $base64,$wm);

(3)Uploader.class.php类文件中处理是否添加水印,过程代码略。

原文作者:rinald
原文地址:http://fity.cn/post/561.html
互联网技术更新较快,本站很多文章具有实效性,我会及时更新原文,但转载的文章无法通知更新。为了不给读者造成困惑或误导,请您在转载时保留此出处信息,尊重别人也是尊重自己。

发表评论

必填

选填

选填

必填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。