>백엔드 개발 >PHP 튜토리얼 >PHP 이미지 워터마크 기능 코드(이미지 및 텍스트 지원)

PHP 이미지 워터마크 기능 코드(이미지 및 텍스트 지원)

WBOY
WBOY원래의
2016-07-25 08:51:561071검색
  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입니다.
  11. * $textColor 텍스트 색상, 값은 16진수 색상 값입니다. #FF0000(빨간색);
  12. * http://bbs.it-home.org
  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(!empty($waterImage) && file_exists($waterImage))
  25. {
  26. $isWaterImage = TRUE;
  27. $water_info = getimagesize($ waterImage );
  28. $water_w= $water_info[0];//워터마크 이미지 너비 가져오기
  29. $water_h= $water_info[1];//워터마크 이미지 높이 가져오기
  30. switch($ water_info[2 ])//워터마크 이미지 형식 가져오기
  31. {
  32. case 1:$water_im = imagecreatefromgif($waterImage);break
  33. case 2:$water_im = imagecreatefromjpeg($waterImage); break;
  34. 사례 3:$water_im = imagecreatefrompng($waterImage);break;
  35. default:die($formatMsg)
  36. }
  37. }
  38. //배경 이미지 읽기
  39. (!empty( $groundImage) && file_exists($groundImage))
  40. {
  41. $ground_info = getimagesize($groundImage)
  42. $ground_w= $ground_info[0];//배경 너비 가져오기 image
  43. $ground_h = $ground_info[1];//배경 이미지 높이 가져오기
  44. switch($ground_info[2])//배경 이미지 형식 가져오기
  45. {
  46. case 1:$ground_im = imagecreatefromgif($groundImage) ;break;
  47. 케이스 2:$ground_im = imagecreatefromjpeg($groundImage);break
  48. 케이스 3:$ground_im = imagecreatefrompng($groundImage);break
  49. default:die($formatMsg);
  50. }
  51. }
  52. else
  53. {
  54. die("워터마킹해야 할 사진이 없습니다!")
  55. }
  56. //워터마크 위치
  57. if($isWaterImage) //사진 워터마크
  58. $w = $water_w;
  59. $h = $water_h
  60. $label = "사진"; 🎜>}
  61. else//텍스트 워터마크
  62. {
  63. $temp = imagettfbbox(ceil($textFont*2.5),0,"./cour.ttf",$waterText);//범위 가져오기 TrueType 글꼴을 사용하는 텍스트
  64. $w = $ temp[2] - $temp[6]
  65. $h = $temp[3] - $temp[7]
  66. unset($temp);
  67. $label = "텍스트 영역";
  68. }
  69. if( ($ground_w<$w) || ($ground_h<$h) )
  70. {
  71. echo "길이 또는 너비 워터마크를 추가해야 하는 이미지의 수가 워터마크보다 큽니다.".$label. "워터마크를 생성하기에는 너무 어립니다! ";
  72. return;
  73. }
  74. switch($waterPos)
  75. {
  76. case 0://random
  77. $posX = rand(0,($ground_w - $w)) ;
  78. $posY = rand(0,($ground_h - $h));
  79. break
  80. 왼쪽 상단은 1://1입니다
  81. $posY; = 0;
  82. break;
  83. case 2://2는 상단 중앙에 있습니다.
  84. $posX = ($ground_w - $w) / 2
  85. $posY = 0;
  86. 케이스 3://3이 오른쪽 상단
  87. $posX = $ground_w - $w;
  88. $posY = 0
  89. break
  90. 가운데; left
  91. $posX = 0;
  92. $posY = ($ground_h - $h) / 2
  93. break
  94. case 5://5가 중앙에 위치함
  95. $posX = ($ground_w - $w) / 2;
  96. $posY = ($ground_h - $h) / 2
  97. break
  98. case 6://6은 오른쪽 중간
  99. $posX = $ ground_w - $ w;
  100. $posY = ($ground_h - $h) / 2;
  101. break
  102. case 7://7은 왼쪽 하단
  103. $posX = 0; posY = $ground_h - $h;
  104. break;
  105. case 8://8은 하단 중앙에 위치합니다.
  106. $posX = ($ground_w - $w) / 2; $ h;
  107. break;
  108. case 9://9는 오른쪽 하단
  109. $ground_w - $w
  110. $posY = $ground_h -
  111. break; 🎜>default://random
  112. $posX = rand(0,($ground_w - $w))
  113. $posY = rand(0,($ground_h - $h))
  114. break ;
  115. }
  116. //이미지의 색상 혼합 모드 설정
  117. imagealphablending($ground_im, true)
  118. if($isWaterImage)//이미지 워터마크
  119. {
  120. imagecopy($ ground_im , $water_im, $posX, $posY, 0, 0, $water_w,$water_h);//워터마크를 대상 파일에 복사
  121. }
  122. else//텍스트 워터마크
  123. {
  124. if( !empty($textColor) && (strlen($textColor)==7) )
  125. {
  126. $R = hexdec(substr($textColor,1,2))
  127. $G = hexdec(substr ( $textColor,3,2));
  128. $B = hexdec(substr($textColor,5));
  129. }
  130. else
  131. {
  132. die("워터마크 텍스트 색상 형식 정확하지 않습니다!");
  133. }
  134. imagestring( $ground_im, $textFont, $posX, $posY, $waterText, imagecolorallocate($ground_im, $R, $G, $B));
  135. }
  136. //워터마크 이미지 생성
  137. @unlink($groundImage);
  138. switch($ground_info[2])//배경 이미지 형식 가져오기
  139. {
  140. case 1:imagegif($ground_im, $groundImage);break;
  141. 케이스 2:imagejpeg($ground_im,$groundImage);break
  142. 케이스 3:imagepng($ground_im,$groundImage);break
  143. default:die($errorMsg) ;
  144. }
  145. //메모리 해제
  146. if(isset($water_info)) unset($water_info)
  147. if(isset($water_im)) imagedestroy($water_im); ($ground_info);
  148. imagedestroy($ground_im);
  149. }

  150. //------

  151. if(isset($_FILES) && ! 비어 있음($_FILES['userfile']) && $_FILES['userfile']['size']>0)
  152. {
  153. $uploadfile = "./".time()."_". $_FILES['userfile']['name'];
  154. if (copy($_FILES['userfile']['tmp_name'], $uploadfile))
  155. {
  156. echo "확인
    ";
  157. //텍스트 워터마크
  158. imageWaterMark($uploadfile,0,"","your water text",9,"#EBEBEB");
  159. //이미지 워터마크
  160. //$waterImage ="./images/watermark.gif";//워터마크 이미지 경로
  161. //imageWaterMark($uploadfile,9,$waterImage)
  162. echo "";
  163. }
  164. else
  165. {
  166. echo "실패
    ";
  167. }
  168. }
  169. ?>
  170. < ;form enctype="multipart/form-data" method="POST">
  171. 파일:
코드 복사

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.