>  기사  >  백엔드 개발  >  PHP 이미지 워터마크 클래스, PHP는 이미지에 워터마크 기능 코드를 추가합니다.

PHP 이미지 워터마크 클래스, PHP는 이미지에 워터마크 기능 코드를 추가합니다.

WBOY
WBOY원래의
2016-07-25 08:51:52844검색
  1. /*

  2. * 기능: php 이미지 워터마크(워터마크는 이미지 또는 텍스트를 지원합니다)
  3. * 매개변수:
  4. * $groundimage 배경 이미지, 즉 워터마크가 필요한 이미지는 현재 gif, jpg, png 형식만 지원합니다.
  5. * $waterPos 워터마크 위치는 10가지 상태이며 0은 임의의 위치;
  6. * 1은 상단이 왼쪽에 있음을 의미하고, 2는 상단이 중앙에 있음을 의미하고, 3은 상단이 오른쪽에 있음을 의미합니다.
  7. * 4는 중앙에 왼쪽에 있음을 의미합니다. 가운데는 중앙, 6은 가운데가 오른쪽
  8. * 7은 아래쪽이 왼쪽, 8은 아래쪽이 중앙, 9는 아래쪽이 오른쪽을 의미합니다. $waterImage 이미지 워터마크, 즉 워터마크로 사용되는 이미지는 현재 GIF, JPG, PNG 형식만 지원합니다.
  9. * $waterText 텍스트 워터마크, 즉 텍스트는 워터마크로 사용되며 ASCII 코드를 지원하지 않습니다. 중국어 지원;
  10. * $textFont 텍스트 크기, 값은 1, 2, 3, 4 또는 5, 기본값은 5입니다.
  11. * $textColor 텍스트 색상, 값은 16진수 색상 값, 기본값은 #FF0000(빨간색) ;
  12. *
  13. * 참고: GD 2.0 지원, FreeType 지원, GIF 읽기, GIF 생성, JPG, PNG
  14. * $waterImage와 $waterText를 동시에 사용하지 않는 것이 가장 좋습니다. 그 중 하나를 선택하면 $waterImage가 먼저 사용됩니다.
  15. * $waterImage가 유효하면 $waterString, $stringFont 및 $stringColor 매개변수가 적용되지 않습니다.
  16. * 워터마크가 적용된 이미지의 파일명은 $groundImage와 동일합니다.
  17. * 작성자: longware @ 2004-11-3 14:15:13
  18. */
  19. 함수 imageWaterMark($groundImage,$waterPos=0,$waterImage=””,$waterText=””,$ textFont=5,$textColor=”#FF0000″)
  20. {
  21. $isWaterImage = FALSE;
  22. $formatMsg = “이 파일 형식은 아직 지원되지 않는 이미지 처리 소프트웨어를 사용하여 이미지를 GIF로 변환하세요. 또는 JPG, PNG 형식입니다.”;
  23. //워터마크 파일 읽기
  24. if(!emptyempty($waterImage) && file_exists($waterImage))
  25. {
  26. $isWaterImage = TRUE; );
  27. $water_w = $water_info[0];//워터마크 이미지 너비 가져오기
  28. $water_h = $water_info[1];//워터마크 이미지 높이 가져오기
  29. switch($ water_info[2 ])//워터마크 이미지 형식 가져오기
  30. {
  31. case 1:$water_im = imagecreatefromgif($waterImage);break
  32. case 2:$water_im = imagecreatefromjpeg($waterImage); break;
  33. 사례 3:$water_im = imagecreatefrompng($waterImage);break;
  34. default:die($formatMsg)
  35. }
  36. }//배경 이미지 읽기
  37. if (!emptyempty( $groundImage) && file_exists($groundImage))
  38. {
  39. $ground_info = getimagesize($groundImage)
  40. $ground_w = $ground_info[0];//배경 너비 가져오기 image
  41. $ground_h = $ground_info[1];//배경 이미지 높이 가져오기
  42. switch($ground_info[2])//배경 이미지 형식 가져오기
  43. {
  44. case 1:$ground_im = imagecreatefromgif($groundImage) ;break;
  45. 케이스 2:$ground_im = imagecreatefromjpeg($groundImage);break
  46. 케이스 3:$ground_im = imagecreatefrompng($groundImage);break
  47. default:die($formatMsg);
  48. }
  49. }
  50. else
  51. {
  52. die("워터마크를 적용해야 할 사진이 존재하지 않습니다! ”);
  53. }
  54. //워터마크 위치
  55. if($isWaterImage)//사진 워터마크
  56. {
  57. $w = $water_w
  58. $h = $water_h; >$label = "그림";
  59. }
  60. else//텍스트 워터마크
  61. {
  62. $temp = imagettfbbox(ceil($textFont*5),0,"./cour.ttf" , $waterText);//트루타입 글꼴을 사용하여 텍스트 범위 가져오기
  63. $w = $temp[2] - $temp[6]
  64. $h = $temp[3] - $temp[7] ;
  65. unset($temp);
  66. $label = "텍스트 영역";
  67. }
  68. if( ($ground_w<$w) || ($ground_h<$h) )
  69. {
  70. echo "워터마크를 적용해야 하는 이미지의 길이나 폭이 ".$label." 워터마크보다 작아서 워터마크를 생성할 수 없습니다! ”;
  71. return;
  72. }
  73. 스위치($waterPos)
  74. {
  75. case 0://random
  76. $posX = rand(0,($ground_w - $w)) ;
  77. $posY = rand(0,($ground_h - $h));
  78. break
  79. 왼쪽 상단은 1://1입니다
  80. $posY; = 0;
  81. break;
  82. case 2://2는 상단 중앙에 있습니다.
  83. $posX = ($ground_w - $w) / 2
  84. $posY = 0;
  85. 케이스 3://3이 오른쪽 상단
  86. $posX = $ground_w - $w;
  87. $posY = 0
  88. break
  89. 가운데; left
  90. $posX = 0;
  91. $posY = ($ground_h - $h) / 2
  92. break
  93. case 5://5가 중앙에 위치함
  94. $posX = ($ground_w - $w) / 2;
  95. $posY = ($ground_h - $h) / 2
  96. break
  97. case 6://6은 오른쪽 중간
  98. $posX = $ ground_w - $ w;
  99. $posY = ($ground_h - $h) / 2;
  100. break
  101. case 7://7은 왼쪽 하단
  102. $posX = 0; posY = $ground_h - $h;
  103. break;
  104. case 8://8은 하단 중앙에 위치합니다.
  105. $posX = ($ground_w - $w) / 2; $ h;
  106. break;
  107. case 9://9는 오른쪽 하단
  108. $ground_w - $w
  109. $posY = $ground_h -
  110. break; 🎜>default://random
  111. $posX = rand(0,($ground_w - $w))
  112. $posY = rand(0,($ground_h - $h))
  113. break ;
  114. }
  115. //이미지의 색상 혼합 모드 설정
  116. imagealphablending($ground_im, true)
  117. if($isWaterImage)//이미지 워터마크
  118. {
  119. imagecopy($ ground_im , $water_im, $posX, $posY, 0, 0, $water_w,$water_h);//워터마크를 대상 파일에 복사
  120. }
  121. else//텍스트 워터마크
  122. {
  123. if( !emptyempty($textColor) && (strlen($textColor)==7) )
  124. {
  125. $R = hexdec(substr($textColor,1,2))
  126. $G = hexdec (substr( $textColor,3,2));
  127. $B = hexdec(substr($textColor,5))
  128. }
  129. else
  130. {
  131. die("워터마크 텍스트 색상 형식이 잘못되었습니다!");
  132. }
  133. imagestring( $ground_im, $textFont, $posX, $posY, $waterText, imagecolorallocate($ground_im, $R, $G, $B));
  134. }
  135. //生成水印后의 사진
  136. @unlink($groundImage);
  137. switch($ground_info[2])//取得背景图 Images 格式
  138. {
  139. case 1:imagegif($ground_im,$groundImage);break;
  140. 사례 2:imagejpeg($ground_im,$groundImage);break;
  141. 사례 3:imagepng($ground_im,$groundImage);break;
  142. 기본값:die($errorMsg);
  143. }
  144. //释放内存
  145. if(isset($water_info)) unset($water_info);
  146. if(isset($water_im)) imagedestroy($water_im);
  147. 설정 해제($ground_info);
  148. imagedestroy($ground_im);
  149. }
  150. //- bbs.it-home.org
  151. $id=$_REQUEST['id'];
  152. $num = count($_FILES['userfile']['name']);
  153. print_r($_FILES['userfile']);
  154. print_r($_FILES['사용자 파일']['이름']);
  155. 에코 $num;
  156. 에코 “
    ”;
  157. if(isset($id)){
  158. for($i=0;$i<$id;$i ){
  159. if(isset($_FILES) && !emptyempty($_FILES[' userfile']) && $_FILES['userfile']['size']>0)
  160. {
  161. $uploadfile = “./”.time().”_”.$_FILES['userfile' ][이름][$i];
  162. 에코 “
    ”;
  163. echo $uploadfile;
  164. if (copy($_FILES['userfile']['tmp_name'][$i], $uploadfile))
  165. {
  166. echo “확인
    ”; $waterImage=”logo_ok1.gif”;//WaterMark($uploadfile,9,$waterImage)
  167. echo “";
  168. }
  169. else
  170. {
  171. echo “실패
    ”;
  172. }
  173. }
  174. }
  175. }
  176. ?>
  177. for($a=0;$a<$id;$a ){
  178. echo “문서: <입력 이름=”userfile[]” type=”file”> ;
    ”;

  179. }

  180. ?>
  181. <입력 유형=”제출” 값=”上传”>
  182. 复主代码
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.