>백엔드 개발 >PHP 튜토리얼 >PHP 그림은 자동으로 워터마크 코드를 추가하고, PHP 그림 워터마크 기능 코드를 추가합니다.

PHP 그림은 자동으로 워터마크 코드를 추가하고, PHP 그림 워터마크 기능 코드를 추가합니다.

WBOY
WBOY원래의
2016-07-25 08:51:531020검색
  1. /*
  2. * 기능: php 이미지 워터마크(워터마크는 이미지 또는 텍스트를 지원합니다)
  3. * 매개변수:
  4. * $groundimage 배경 이미지, 즉 워터마크가 필요한 이미지는 현재 gif, jpg 및 png 형식만 지원합니다.
  5. *$waterpos 워터마크 위치는 10가지이며 0은 임의 위치입니다. *1은 왼쪽 상단, 2는 상단이 중앙에 있음을 의미하고 3은 상단이 오른쪽에 있음을 의미합니다.
  6. *4는 중앙이 왼쪽에 있음을 의미하고 5는 중앙에 있음을 의미하며 6은 중앙에 있음을 의미합니다.
  7. *7은 하단이 왼쪽, 8은 하단이 중앙, 9는 하단이 끝입니다.
  8. *$waterimage 이미지 워터마크, 즉, 워터마크로 사용되는 이미지는 현재 gif, jpg, png 형식만 지원합니다.
  9. *$watertext 텍스트 워터마크, 즉 텍스트는 워터마크로 사용되며, ASCII 코드는 지원되지 않습니다.
  10. *$ textfont 텍스트 크기, 값은 1, 2, 3, 4 또는 5, 기본값은 5입니다.
  11. *$textcolor 텍스트 색상, 값은 16진수 색상 값, 기본값은 #ff0000(빨간색)입니다. * 참고: gd 2.0 지원, freetype 지원, gif 읽기, gif 만들기, jpg, png
  12. *$waterimage와 $watertext는 동시에 사용하지 않는 것이 가장 좋습니다. 예, $waterimage가 선호됩니다. .
  13. *$waterimage가 유효한 경우 $waterstring, $stringfont 및 $stringcolor 매개변수는 적용되지 않습니다.
  14. *워터마크가 적용된 이미지의 파일명은 $groundimage와 동일합니다.
  15. * 작성자: longware @ 2004-11-3 14:15:13
  16. */
  17. function imagewatermark($groundimage,$waterpos=0,$waterimage="",$watertext="",$ textfont=5,$textcolor="#ff0000")
  18. {
  19. $iswaterimage = false;
  20. $formatmsg = "이 파일 형식은 아직 지원되지 않습니다. 이미지 처리 소프트웨어를 사용하여 이미지를 gif로 변환하세요. 또는 jpg, png 형식.";
  21. //워터마크 파일 읽기
  22. if(!empty($waterimage) && file_exists($waterimage))
  23. {
  24. $iswaterimage = true;
  25. $water_info = getimagesize($ waterimage );
  26. $water_w = $water_info[0];//워터마크 이미지 너비 가져오기
  27. $water_h = $water_info[1];//워터마크 이미지 높이 가져오기
  28. switch($ water_info[2 ])//워터마크 이미지 형식 가져오기
  29. {
  30. case 1:$water_im = imagecreatefromgif($waterimage);break
  31. case 2:$water_im = imagecreatefromjpeg($waterimage); break;
  32. 사례 3:$water_im = imagecreatefrompng($waterimage);break;
  33. default:die($formatmsg)
  34. }
  35. }//배경 이미지 읽기
  36. (!empty( $groundimage) && file_exists($groundimage))
  37. {
  38. $ground_info = getimagesize($groundimage)
  39. $ground_w = $ground_info[0];//배경 너비 가져오기 image
  40. $ground_h = $ground_info[1];//배경 이미지 높이 가져오기
  41. switch($ground_info[2])//배경 이미지 형식 가져오기
  42. {
  43. case 1:$ground_im = imagecreatefromgif($groundimage) ;break;
  44. 케이스 2:$ground_im = imagecreatefromjpeg($groundimage);break
  45. 케이스 3:$ground_im = imagecreatefrompng($groundimage);break
  46. default:die($formatmsg);
  47. }
  48. }
  49. else
  50. {
  51. die("워터마킹해야 할 사진이 없습니다!")
  52. }
  53. //워터마크 위치
  54. if($iswaterimage) //그림 워터마크
  55. $w = $water_w;
  56. $h = $water_h
  57. $label = "그림"; 🎜>}
  58. else//텍스트 워터마크
  59. {
  60. $temp = imagettfbbox(ceil($textfont*2.5),0,"./cour.ttf",$watertext);//범위 가져오기 트루타입 글꼴을 사용하는 텍스트
  61. $w = $ temp[2] - $temp[6]
  62. $h = $temp[3] - $temp[7]
  63. unset($temp);
  64. $label = "텍스트 영역";
  65. }
  66. if( ($ground_w<$w) || ($ground_h<$h) )
  67. {
  68. echo "길이 또는 너비 워터마크를 추가해야 하는 이미지의 수가 워터마크보다 큽니다.".$label. "워터마크를 생성하기에는 너무 어립니다! ";
  69. return;
  70. }
  71. switch($waterpos)
  72. {
  73. case 0://random
  74. $posx = rand(0,($ground_w - $w)) ;
  75. $posy = rand(0,($ground_h - $h));
  76. break
  77. case 1://1은 왼쪽 상단입니다
  78. $posy = 0;
  79. break;
  80. case 2://2는 상단 중앙에 있습니다.
  81. $posx = ($ground_w - $w) / 2
  82. $posy = 0;
  83. case 3://3이 오른쪽 상단
  84. $posx = $ground_w - $w;
  85. $posy = 0
  86. break
  87. 가운데; left
  88. $posx = 0;
  89. $posy = ($ground_h - $h) / 2
  90. break
  91. case 5://5가 중앙에 위치함
  92. $posx = ($ground_w - $w) / 2;
  93. $posy = ($ground_h - $h) / 2
  94. break
  95. case 6://6은 오른쪽 중간
  96. $posx = $ ground_w - $ w
  97. $posy = ($ground_h - $h) / 2;
  98. break
  99. case 7://7은 왼쪽 하단
  100. $posx = 0; posy = $ground_h - $h;
  101. break;
  102. case 8://8은 하단 중앙에 위치합니다.
  103. $posx = ($ground_w - $w) / 2; $ h;
  104. break;
  105. 오른쪽 하단
  106. $posx = $ground_w - $w
  107. break
  108. default://random
  109. $posx = rand(0,($ground_w - $w))
  110. $posy = rand(0,($ground_h - $h))
  111. break ;
  112. }
  113. //이미지의 색상 혼합 모드 설정
  114. imagealphablending($ground_im, true)
  115. if($iswaterimage)//이미지 워터마크
  116. {
  117. imagecopy($ ground_im , $water_im, $posx, $posy, 0, 0, $water_w,$water_h);//워터마크를 대상 파일에 복사
  118. }
  119. else//텍스트 워터마크
  120. {
  121. if( !empty($textcolor) && (strlen($textcolor)==7) )
  122. {
  123. $r = hexdec(substr($textcolor,1,2))
  124. $g = hexdec(substr ( $textcolor,3,2));
  125. $b = hexdec(substr($textcolor,5));
  126. }
  127. else
  128. {
  129. die("워터마크 텍스트 색상 형식 정확하지 않습니다!");
  130. }
  131. imagestring( $ground_im, $textfont, $posx, $posy, $watertext, imagecolorallocate($ground_im, $r, $g, $b));
  132. }
  133. //워터마크 이미지 생성
  134. @unlink($groundimage);
  135. switch($ground_info[2])//배경 이미지 형식 가져오기
  136. {
  137. case 1:imagegif($ground_im, $groundimage);break;
  138. 케이스 2:imagejpeg($ground_im,$groundimage);break
  139. 케이스 3:imagepng($ground_im,$groundimage);break
  140. default:die($errormsg) ;
  141. }
  142. //메모리 해제
  143. if(isset($water_info)) unset($water_info)
  144. if(isset($water_im)) imagedestroy($water_im); ($ground_info);
  145. imagedestroy($ground_im);
  146. }
  147. //-------
  148. if(isset($_files) && !empty($_files['userfile ']) && $_files['userfile']['size']>0)
  149. {
  150. $uploadfile = "./".time()."_".$_files['userfile'] ['이름'];
  151. if (copy($_files['userfile']['tmp_name'], $uploadfile))
  152. {
  153. echo "ok
    "// 텍스트 워터마크
  154. imagewatermark($uploadfile,0,"","http://blog.csdn.net/longware/",5,"#ff0000")
  155. //이미지 워터마크
  156. // $waterimage="./hanweb_shuiyin.gif";//워터마크 이미지 경로
  157. //imagewatermark($uploadfile,0,$waterimage)
  158. echo "";
  159. else
  160. {
  161. echo "fail
    "
  162. }
  163. ?> 🎜>
  164. 파일:
  165. 코드 복사
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.