>백엔드 개발 >PHP 튜토리얼 >사진에 중국어 워터마크를 추가하는 PHP 코드

사진에 중국어 워터마크를 추가하는 PHP 코드

WBOY
WBOY원래의
2016-07-25 09:08:09894검색
  1. Header("Content-type: image/png") /*이미지가 출력됨을 브라우저에 알립니다*/
  2. $ im = imagecreate(400, 300); /*이미지 크기 정의*/
  3. $gray = ImageColorAllocate($im, 235, 235, 235);
  4. $pink = ImageColorAllocate($im , 255, 128, 255);
  5. $fontfile = "simkai.ttf";
  6. /* $fontfile 글꼴 경로는 운영 체제에 따라 simhei.ttf(흑체), SIMKAI.TTF( italic), SIMFANG.TTF(송나라 모방), SIMSUN.TTC(송나라 및 신송나라) 및 GD에서 지원하는 기타 중국어 글꼴*/
  7. $str = iconv('GB2312','UTF-8', '중국어 워터마크'); /*gb2312 문자 세트를 UTF-8 문자로 변환*/
  8. ImageTTFText($im, 30, 0, 100, 200, $pink, $fontfile, $str);
  9. /* 중국어 워터마크 추가*/
  10. Imagepng($im);
  11. ImageDestroy($im);
  12. ?>
코드 복사

예 2:

  1. // ----------------------- //
  2. // 기능: 그림에 텍스트 추가
  3. // 매개 변수: $img 그림 파일 이름
  4. // $new_img 그림 파일 이름을 저장합니다. 비어 있으면 저장하지 않는다는 의미입니다. 그림
  5. // $ 텍스트 문자열 내용
  6. // text_size 문자열 크기
  7. // text_angle 글꼴 문자열 출력 각도
  8. // text_x 문자열 출력 x 좌표
  9. // text_y 문자열 출력 y 좌표
  10. / / $text_font 글꼴 파일명
  11. // $r,$g,$b 문자열 색상 RGB 값
  12. //-------------------- ----- //
  13. 함수 img_text($img, $new_img, $text, $text_size, $text_angle, $text_x, $text_y, $text_font, $r, $g, $b){
  14. $text=iconv("gb2312","UTF-8",$text);
  15. Header("콘텐츠 유형: image/gif");
  16. $im = @imagecreatefromstring(file_get_contents($img)) 또는 사망("이미지를 열지 못했습니다!");
  17. $color = ImageColorAllocate($im, $r,$g,$b);
  18. //ImageTTFText(int im, int size, int angle, int x , int y, int col, stringfontfile, string text):
  19. //이 함수는 TTF(TrueType Fonts) 글꼴 텍스트를 이미지에 씁니다.
  20. //매개변수: size는 글꼴의 크기입니다.
  21. // angle은 글꼴의 각도로, 시계 방향으로 계산됩니다. 0도는 가로(왼쪽에서 오른쪽으로), 90도는 아래쪽에서 텍스트입니다. top ;
  22. // 두 매개변수 x와 y는 텍스트의 좌표 값입니다(원점은 왼쪽 상단 모서리입니다)
  23. // col은 텍스트의 색상입니다. Fontfile은 글꼴 파일의 이름입니다.
  24. / /text는 문자열 내용입니다.
  25. ImageTTFText($im, $text_size, $text_angle, $text_x, $text_y, $color, $text_font, $text);
  26. if ($new_img==""):
  27. ImageGif($im ); // 이미지를 저장하지 않고 표시만 합니다.
  28. else:
  29. ImageGif($im,$new_img) // 이미지를 저장하지만 표시하지 않습니다.
  30. endif;
  31. ImageDestroy( $im); / /그래픽 종료, 메모리 공간 해제
  32. }
  33. ?>
코드 복사

예 3:

  1. /*
  2. * 기능: PHP 이미지 워터마크(워터마크는 이미지 또는 텍스트를 지원함)
  3. * 매개변수:
  4. * $groundImage 배경 이미지, 즉 워터마크가 필요한 이미지는 현재 GIF, JPG 및 PNG 형식만 지원합니다.
  5. * $waterPos 워터마크 위치는 10가지 상태이며 0은 임의 위치입니다. * 1은 왼쪽 상단, 2는 상단이 중앙, 3은 상단이 오른쪽을 의미합니다.
  6. * 4는 왼쪽 중앙, 5는 중앙, 6은 중앙입니다. right;
  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 Read, GIF Create, JPG, PNG 지원
  12. * $waterImage와 $waterText를 동시에 사용하지 않는 것이 가장 좋습니다. 예, $waterImage를 먼저 사용합니다.
  13. * $waterImage가 유효하면 $waterString, $stringFont 및 $stringColor 매개변수가 적용되지 않습니다.
  14. * 워터마크가 적용된 이미지의 파일명은 $groundImage와 동일합니다.
  15. * 작성자: longware @ 2004-11-3 14:15:13
  16. */
  17. 함수 imageWaterMark($groundImage,$waterPos=0,$waterImage=””,$waterText=””,$ textFont=5,$textColor=”#FF0000″)
  18. {
  19. $isWaterImage = FALSE;
  20. $formatMsg = “이 파일 형식은 아직 지원되지 않습니다. 이미지 처리 소프트웨어를 사용하여 이미지를 GIF로 변환하세요. 또는 JPG, PNG 형식.”;
  21. //워터마크 파일 읽기
  22. if(!emptyempty($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. //배경 이미지 읽기
  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;
  59. $label = "그림";
  60. }
  61. else//텍스트 워터마크
  62. {
  63. $temp = imagettfbbox(ceil($textFont*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. 반환;
  73. }
  74. 스위치($waterPos)
  75. {
  76. case 0://random
  77. $posX = rand(0,($ground_w - $w)) ;
  78. $posY = rand(0,($ground_h - $h));
  79. break;
  80. case 1://1은 왼쪽 상단
  81. $posX = 0;
  82. $posY = 0;
  83. break;
  84. case 2://2는 상단 중앙에 있습니다
  85. $posX = ($ground_w - $w) / 2;
  86. $posY = 0;
  87. break;
  88. 케이스 3://3이 오른쪽 상단
  89. $posX = $ground_w - $w;
  90. $posY = 0;
  91. break;
  92. 케이스 4://4가 가운데 left
  93. $posX = 0;
  94. $posY = ($ground_h - $h) / 2;
  95. break;
  96. case 5://5가 중앙에 위치함
  97. $posX = ($ground_w - $w) / 2;
  98. $posY = ($ground_h - $h) / 2;
  99. break;
  100. case 6://6이 오른쪽 가운데
  101. $posX = $ground_w - $ w;
  102. $posY = ($ground_h - $h) / 2;
  103. break;
  104. case 7://7은 왼쪽 하단
  105. $posX = 0;
  106. $posY = $ground_h - $h;
  107. break;
  108. case 8://8은 하단 중앙에 위치함
  109. $posX = ($ground_w - $w) / 2;
  110. $posY = $ground_h - $ h;
  111. break;
  112. case 9://9는 오른쪽 하단
  113. $posX = $ground_w - $w;
  114. $posY = $ground_h - $h;
  115. break;
  116. default://random
  117. $posX = rand(0,($ground_w - $w));
  118. $posY = rand(0,($ground_h - $h));
  119. break ;
  120. }
  121. //이미지의 색상 혼합 모드 설정
  122. imagealphablending($ground_im, true);
  123. if($isWaterImage)//이미지 워터마크
  124. {
  125. imagecopy( $ground_im , $water_im, $posX, $posY, 0, 0, $water_w,$water_h);//워터마크를 대상 파일에 복사
  126. }
  127. else//텍스트 워터마크
  128. {
  129. if ( !emptyempty($textColor) && (strlen($textColor)==7) )
  130. {
  131. $R = hexdec(substr($textColor,1,2));
  132. $G = hexdec( substr( $textColor,3,2));
  133. $B = hexdec(substr($textColor,5));
  134. }
  135. else
  136. {
  137. die("워터마크 텍스트 색상 형식이 잘못되었습니다!”);
  138. }
  139. imagestring( $ground_im, $textFont, $posX, $posY, $waterText, imagecolorallocate($ground_im, $R, $G, $B));
  140. }
  141. //생성수印后적 사진
  142. @unlink($groundImage);
  143. switch($ground_info[2])//取得背景图 Images 格式
  144. {
  145. 사례 1:imagegif($ground_im, $groundImage);break;
  146. 사례 2:imagejpeg($ground_im,$groundImage);break;
  147. 사례 3:imagepng($ground_im,$groundImage);break;
  148. default:die($errorMsg) ;
  149. }
  150. //释放内存
  151. if(isset($water_info)) unset($water_info);
  152. if(isset($water_im)) imagedestroy($water_im);
  153. unset ($ground_info);
  154. imagedestroy($ground_im);
  155. }
  156. //——————————————————————————— ——
  157. $id=$_REQUEST['id'];
  158. $num = count($_FILES['userfile']['name']);
  159. print_r($_FILES['userfile'] );
  160. print_r($_FILES['userfile']['name']);
  161. echo $num;
  162. echo “
    ”;
  163. if(isset($id)) {
  164. for($i=0;$i<$id;$i ){
  165. if(isset($_FILES) && !emptyempty($_FILES['userfile']) && $_FILES['userfile' ]['size']>0)
  166. {
  167. $uploadfile = “./”.time().”_”.$_FILES['userfile'][name][$i];
  168. echo “
    ”;
  169. echo $uploadfile;
  170. if (copy($_FILES['userfile']['tmp_name'][$i], $uploadfile))
  171. {
  172. echo “확인
    ”;
  173. //文字水印
  174. //imageWaterMark($uploadfile,5,”",”HTTP://www.lvye.info”,5,”#cccccc“) ;
  175. //图 Images 印
  176. $waterImage=”logo_ok1.gif”;//WaterMark($uploadfile,9,$waterImage);
  177. echo “”;
  178. }
  179. else
  180. {
  181. echo “실패
    ”;
  182. }
  183. }
  184. }
  185. }
  186. ?>
  187. for($a=0; $a<$id;$a ){
  188. echo “文件:
    ”;
  189. }
  190. ?>
  191. <입력 유형=”제출” 값=”上传”>
复主代码

예 4, 중국어 워터마크 추가:

  1. /*-------------

  2. ** 설명 : 지정된 이미지에 하단 워터마크를 추가하는 데 사용되는 사용자 정의 클래스입니다(이미지 표시 영역을 차지하지 않음)
  3. 를 호출하려면 개체를 만들어야 합니다. **참고: 1. gd 라이브러리 지원 및 iconv가 필요합니다. 지원 (php5에는 이미 포함되어 있으며 필요하지 않습니다.) Loading)
  4. 2. jpg/jpeg/gif/png 세 가지 유형의 이미지에만 적합하며, 그 외 유형은 처리되지 않습니다.
  5. 3. 이미지가 있는 디렉터리는 쓰기 가능해야 합니다.
  6. 4. 호출 예:
  7. $objImg = new MyWaterDownChina();
  8. $objImg->Path = "images/";
  9. $objImg ->FileName = "1.jpg";
  10. $objImg->Text = "HAHAKONGJIAN[url]HTTP://HI.BAIDU.COM/LYSONCN[/url]";
  11. $objImg-> ;Font = "./font/simhei.ttf";
  12. $objImg-> ;Run();
  13. **멤버 함수:
  14. ------------* /
  15. class MyWaterDownChina{
  16. var $Path = "./"; / /이 클래스를 호출하는 페이지를 기준으로 그림이 있는 디렉터리의 상대 경로
  17. var $FileName = ""; //그림 이름(예: "1.jpg"
  18. var $Text = ""; //그림은 다음과 같아야 합니다. 추가된 워터마크 텍스트는 중국어를 지원합니다.
  19. var $TextColor = "#ffffff"; //텍스트 색상, gif 이미지의 경우 글꼴 색상은 검정색만 가능합니다.
  20. var $TextBgColor = "#000000" // 텍스트 배경 막대 색상
  21. var $Font = "c:// windows//fonts//simhei.ttf"; //글꼴 저장 디렉터리, 상대 경로
  22. var $OverFlag = true; //원본 이미지를 덮어쓸지 여부, 기본값은 덮어쓰기입니다. 덮어쓰지 않을 경우 "_water_down" "1.jpg" => "1_water_down.jpg"
  23. var $BaseWidth = 200; //그림 워터마크 앞의 너비는 최소한 >=200이어야 합니다. 텍스트가 추가됩니다.
  24. //----------------
  25. //함수: 클래스 생성자(php5.0 이상)
  26. //매개변수: 없음
  27. // 반환: 없음
  28. 함수 __construct(){;}
  29. //---------------
  30. //함수: 클래스 소멸자(php5 .0 이상)
  31. //매개변수: 없음
  32. //반환: 없음
  33. function __destruct(){;}
  34. //-------------

  35. //Function: 개체에 함수를 실행하고 그림에 워터마크를 추가합니다

  36. //매개변수: 없음
  37. //Return: 없음
  38. function Run()
  39. {
  40. if($this->FileName == "" || $this->Text == "")
  41. return;
  42. //GD 라이브러리 설치 여부 감지
  43. if( false = = function_exists("gd_info"))
  44. {
  45. echo "시스템에 GD 라이브러리가 설치되어 있지 않아 이미지에 워터마크를 추가할 수 없습니다.";
  46. return;
  47. }
  48. //Set 입력, 출력 이미지 경로 이름
  49. $arr_in_name =explod(".",$this->FileName);
  50. //
  51. $inImg = $this->Path.$this->FileName ;
  52. $outImg = $inImg;
  53. $tmpImg = $this->Path.$arr_in_name[0]."_tmp.".$arr_in_name[1] //일시적으로 처리된 사진, 매우 중요
  54. if(!$this->OverFlag)
  55. $outImg = $this->Path.$arr_in_name[0]."_water_down.".$arr_in_name[1];
  56. //사진이 있는지 확인하세요. 존재합니다
  57. if(!file_exists($inImg))
  58. return ;
  59. //이미지 속성 가져오기
  60. $groundImageType = @getimagesize($inImg);
  61. $imgWidth = $groundImageType [0];
  62. $imgHeight = $groundImageType[1];
  63. $imgType = $groundImageType[2];
  64. if($imgWidth < $this->BaseWidth) //더 작은 경우 기본 너비보다 크면 처리되지 않습니다
  65. return;
  66. //이미지가 jpg/jpeg/gif/png가 아닌 경우 처리되지 않습니다
  67. switch($imgType)
  68. {
  69. 사례 1:
  70. $image = imagecreatefromgif($inImg) ;
  71. $this->TextBgColor = "#ffffff"; //gif 이미지의 글꼴은 검정색만 가능하므로 배경색은 흰색으로 설정됨
  72. break;
  73. 사례 2:
  74. $image = imagecreatefromjpeg($inImg);
  75. break;
  76. 사례 3:
  77. $image = imagecreatefrompng($inImg);
  78. break;
  79. 기본값:
  80. return;
  81. break;
  82. }
  83. //색상 생성
  84. $color = @imagecolorallocate($image,hexdec(substr($this- >TextColor,1,2)),hexdec(substr($this->TextColor, 3,2)),hexdec(substr($this->TextColor,5,2))); 🎜>//빈 이미지를 생성합니다. 높이는 하단의 워터마크 높이만큼 증가합니다.
  85. $newHeight = $imgHeight 20;
  86. $objTmpImg = @imagecreatetruecolor($imgWidth,$newHeight);
  87. $ colorBg = @imagecolorallocate($objTmpImg,hexdec(substr($this->TextBgColor,1,2) ),hexdec(substr($this->TextBgColor,3,2)),hexdec(substr($this-> ;TextBgColor,5,2))); //배경색
  88. //사진 배경 채우기 Color
  89. @imagefill ($objTmpImg,0,0,$colorBg);
  90. //복사 원본 이미지를 임시 이미지로
  91. @imagecopy($objTmpImg,$image,0,0,0,0 ,$imgWidth,$imgHeight);
  92. //작성할 워터마크 텍스트 개체 생성
  93. $ objText = $this->createText($this->Text);
  94. //작성할 계산 입력된 워터마크 텍스트의 위치
  95. $x = 5;
  96. $y = $newHeight- 5;
  97. //텍스트 워터마크 쓰기
  98. @imagettftext($objTmpImg,10,0,$x, $y,$color,$this->Font,$objText);
  99. //생성 새 사진, 임시 사진
  100. switch($imgType)
  101. {
  102. 사례 1:
  103. imagegif($objTmpImg,$tmpImg);
  104. break;
  105. 사례 2:
  106. imagejpeg ($objTmpImg,$tmpImg);
  107. break;
  108. 사례 3:
  109. imagepng($objTmpImg ,$tmpImg);
  110. break;
  111. 기본값:
  112. return;
  113. break ;
  114. }
  115. //리소스 해제
  116. @imagedestroy($objTmpImg);
  117. @ imagedestroy($image);
  118. //파일 이름 바꾸기
  119. if($this-> OverFlag)
  120. {
  121. //원본 이미지 덮어쓰기
  122. @unlink($inImg);
  123. @rename($tmpImg,$outImg);
  124. }
  125. else
  126. {
  127. //원본 이미지를 덮어쓰지 마세요
  128. @rename($tmpImg,$outImg);
  129. }
  130. }
  131. //-------
  132. //기능 : 워터마크 텍스트 객체 생성
  133. //매개변수: 없음
  134. //반환: 워터마크 텍스트 객체 생성
  135. function createText($instring)
  136. {
  137. $outstring="";
  138. $ max=strlen($instring);
  139. for($i=0;$i<$max;$i )
  140. {
  141. $h=ord($instring[$i]);
  142. if($h>=160 && $i<$max-1)
  143. {
  144. $outstring .= " &#".base_convert(bin2hex(iconv("gb2312","ucs-2",substr( $instring,$i,2))),16,10).";";
  145. $i ;
  146. }
  147. else
  148. {
  149. $outstring .= $instring[$i ];
  150. }
  151. }
  152. return $outstring;
  153. }
  154. }//class
  155. ?>

코드 복사


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