>  기사  >  백엔드 개발  >  PHP 이미지 처리 함수 클래스(워터마크, 썸네일) [비례 압축 및 크로핑 압축에 대하여]

PHP 이미지 처리 함수 클래스(워터마크, 썸네일) [비례 압축 및 크로핑 압축에 대하여]

WBOY
WBOY원래의
2016-07-25 08:44:29954검색
다음은 워터마크, 썸네일 등의 기능을 포함하는 간단한 이미지 처리 클래스입니다.
하지만 썸네일을 생성하는 방법에는 두 가지가 있습니다. 하나는 이미지를 비례적으로 직접 압축하는 것이고, 다른 하나는 이미지를 잘라낸 후 압축하는 것입니다. 제 생각에는 동일 압축과 자르기 압축의 차이점은 다음과 같습니다.
동일 예시 압축: 이미지의 너비와 길이 비율이 합리적이고 이미지가 완성되었는지 확인할 수 있습니다. 그러나 실제 크기는 요구 사항을 충족한다고 보장되지 않습니다.
자르기 및 압축: 사진의 너비와 길이 비율이 합리적인지 확인하고 실제 크기도 보장할 수 있습니다. 그러나 사진의 무결성은 보장할 수 없습니다.image.php
  1. /**
  2. *
  3. * 이미지 처리 클래스
  4. * @author FC_LAMP
  5. * @internal 기능 포함: 워터마크, 썸네일
  6. */
  7. class Img
  8. {
  9. //이미지 형식
  10. 비공개 $exts = 배열('jpg', 'jpeg', 'gif', 'bmp', 'png' );
  11. /**
  12. *
  13. *
  14. * @throws 예외
  15. */
  16. 공용 함수 __construct()
  17. {
  18. if (! function_exists ( 'gd_info' ))
  19. {
  20. throw new Exception ( 'GD 라이브러리를 로드하지 못했습니다!' );
  21. }
  22. }
  23. /**
  24. *
  25. * 자르기 및 압축
  26. * @param $src_img 이미지
  27. * @param $save_img 생성 이미지
  28. * @param $option 매개변수 옵션(다음 포함): $maxwidth width $maxheight height
  29. * array('width'=>xx,'height'=>xxx)
  30. * @internal
  31. * 이미지가 너무 길거나 너무 넓은 경우 생성되는 일반적인 이미지 압축 방법
  32. *이를 처리하려면 먼저 자르고 비례적으로 압축하는 방법이 필요합니다.
  33. */
  34. 공개 함수 Thumb_img($src_img, $save_img = '', $option)
  35. {
  36. if (비어 있음 ( $option ['width'] ) 또는 비어 있음 ( $option ['height'] ))
  37. {
  38. return array ('flag' => False, 'msg' = > '원본 이미지의 길이와 너비는 0보다 작을 수 없습니다.' );
  39. }
  40. $org_ext = $this->is_img ( $src_img );
  41. if (! $org_ext [' flag'])
  42. {
  43. return $org_ext;
  44. }
  45. //저장 경로가 있으면 경로가 올바른지 확인
  46. if (!empty ( $save_img ))
  47. {
  48. $f = $this->check_dir ( $save_img );
  49. if (! $f ['flag'])
  50. {
  51. return $f;
  52. }
  53. }
  54. //해당 메소드 가져오기
  55. $org_funcs = $this->get_img_funcs ( $org_ext ['msg'] );
  56. //가져오기 원본 크기
  57. $source = $org_funcs ['create_func'] ( $src_img );
  58. $src_w = Imagesx ( $source );
  59. $src_h = imagey ( $source );
  60. //원본 이미지 조정(이미지 원본 모양 잘린 이미지 유지)
  61. $dst_scale = $option ['height'] / $option ['width'] // 대상 이미지 가로 세로 비율
  62. $src_scale = $ src_h / $src_w; // 원본 이미지 가로 세로 비율
  63. if ($src_scale >= $dst_scale)
  64. { // 너무 길다
  65. $w = intval ( $src_w );
  66. $h = intval ( $dst_scale * $w ) ;
  67. $x = 0;
  68. $y = ($src_h - $h) / 3;
  69. } else
  70. { // 너무 넓음
  71. $h = intval ( $ src_h );
  72. $w = intval ( $h / $dst_scale );
  73. $x = ($src_w - $w) / 2;
  74. $y = 0;
  75. }
  76. // 자르기
  77. $croped = imagecreatetruecolor( $w, $h );
  78. imagecopy( $croped, $source, 0, 0, $x, $y, $ src_w, $src_h );
  79. // 크기 조정
  80. $scale = $option ['너비'] / $w;
  81. $target = imagecreatetruecolor ( $option ['너비'], $option ['높이 '] );
  82. $ final_w = intval ( $w * $scale );
  83. $final_h = intval ( $h * $scale );
  84. imagecopyresampled ( $target, $croped, 0, 0, 0 , 0, $final_w, $final_h , $w, $h );
  85. imagedestroy ( $croped );
  86. //출력(저장) 이미지
  87. if (!empty ( $save_img ))
  88. {
  89. $org_funcs ['save_func'] ( $target, $save_img );
  90. } else
  91. {
  92. 헤더( $org_funcs ['header'] );
  93. $org_funcs ['save_func'] ( $target );
  94. }
  95. imagedestroy ( $target );
  96. return array ('flag' => True, 'msg' => '' );
  97. }
  98. /**
  99. *
  100. * 확대된 이미지
  101. * @param $src_img 원본 이미지
  102. * @param $save_img 저장 위치
  103. * @param $option 매개변수 설정 array('width'= >xx ,'키'=>xxx)
  104. *
  105. */
  106. 함수 resize_image($src_img, $save_img = '', $option)
  107. {
  108. $org_ext = $this-> ;is_img ( $src_img );
  109. if (! $org_ext ['flag'])
  110. {
  111. return $org_ext;
  112. }
  113. //저장 경로가 있는 경우 , 경로가 올바른지 확인
  114. if (!empty ( $save_img ))
  115. {
  116. $f = $this->check_dir ( $save_img );
  117. if (! $f [' flag'])
  118. {
  119. return $f;
  120. }
  121. }
  122. //해당 메소드 가져오기
  123. $org_funcs = $this->get_img_funcs ( $org_ext ['msg'] );
  124. //원본 크기 가져오기
  125. $source = $org_funcs ['create_func'] ( $src_img );
  126. $src_w = Imagesx ( $source );
  127. $src_h = 이미지 ( $source );
  128. if (($option ['너비'] && $src_w > $option ['너비']) || ($option ['높이'] && $src_h > $option ['높이' ]))
  129. {
  130. if ($option ['너비'] && $src_w > $option ['너비'])
  131. {
  132. $widthratio = $option ['너비'] / $src_w;
  133. $resizewidth_tag = true;
  134. }
  135. if ($option ['height'] && $src_h > $option [' height'])
  136. {
  137. $heightratio = $option ['height'] / $src_h;
  138. $resizeheight_tag = true;
  139. }
  140. if ($resizewidth_tag && $resizeheight_tag )
  141. {
  142. if ($ widthratio < $heightratio)
  143. $ratio = $widthratio;
  144. else
  145. $ratio = $heightratio;
  146. }
  147. if ($resizewidth_tag && ! $resizeheight_tag)
  148. $ratio = $widthratio;
  149. if ($resizeheight_tag && ! $resizewidth_tag)
  150. $ratio = $heightratio;
  151. $newwidth = $src_w * $ratio;
  152. $newheight = $src_h * $ratio;
  153. if (function_exists ( "imagecopyresampled" ))
  154. {
  155. $newim = imagecreatetruecolor ( $newwidth, $newheight );
  156. imagecopyresampled( $newim, $source, 0 , 0, 0, 0, $newwidth, $newheight, $src_w, $src_h );
  157. } else
  158. {
  159. $newim = imagecreate( $newwidth , $newheight );
  160. imagecopyreised ( $ newim, $source, 0, 0, 0, 0, $newwidth, $newheight, $src_w, $src_h );
  161. }
  162. }
  163. //그림 출력(저장)
  164. if (!empty ( $save_img ))
  165. {
  166. $org_funcs ['save_func'] ( $newim, $save_img );
  167. } else
  168. {
  169. 헤더( $org_funcs ['header'] );
  170. $org_funcs ['save_func']( $newim );
  171. }
  172. imagedestroy( $newim );
  173. 반환 배열 ('flag' => True, 'msg' => '' );
  174. }
  175. /**
  176. *
  177. * 워터마크 이미지 생성
  178. * @param $org_img 원본 이미지
  179. * @param $mark_img 워터마크 이미지
  180. * @param $save_img 디렉토리가 존재하지 않으면 Create를 시도합니다. 디렉토리
  181. * @param array $option 워터마크에 대한 기본 설정은 다음과 같습니다.
  182. * x: 워터마크의 가로 위치, 기본값은 워터마크 이미지의 너비를 뺀 값입니다.
  183. * y: 워터마크의 세로 위치, 기본값은 워터마크의 높이를 뺀 값
  184. * alpha: 알파 값(투명도 조절), 기본값은 50
  185. */
  186. 공개 함수 water_mark($org_img, $mark_img, $save_img = '', $option = array())
  187. {
  188. //사진 확인
  189. $org_ext = $this->is_img ( $org_img );
  190. if ( ! $org_ext ['플래그'])
  191. {
  192. return $org_ext;
  193. }
  194. $mark_ext = $this->is_img ( $mark_img );
  195. if (! $mark_ext [ ' flag'])
  196. {
  197. return $mark_ext;
  198. }
  199. //저장 경로가 있으면 경로가 맞는지 확인
  200. if (!empty ( $save_img ))
  201. {
  202. $f = $this->check_dir ( $save_img );
  203. if (! $f ['flag'])
  204. {
  205. return $f;
  206. }
  207. }
  208. //해당 캔버스 가져오기
  209. $org_funcs = $this->get_img_funcs ( $org_ext ['msg'] );
  210. $org_img_im = $org_funcs ['create_func' ] ( $org_img ) ;
  211. $mark_funcs = $this->get_img_funcs ( $mark_ext ['msg'] );
  212. $mark_img_im = $mark_funcs ['create_func'] ( $mark_img );
  213. //워터마크 이미지 좌표 복사
  214. $mark_img_im_x = 0;
  215. $mark_img_im_y = 0;
  216. //워터마크 이미지 높이 및 너비 복사
  217. $mark_img_w = ​​​​imagesx ( $mark_img_im );
  218. $mark_img_h = 이미지( $mark_img_im );
  219. $org_img_w = ​​​​이미지x( $org_img_im );
  220. $org_img_h = 이미지x( $org_img_im );
  221. / /합성 생성점 좌표
  222. $x = $org_img_w - $mark_img_w;
  223. $org_img_im_x = isset ( $option ['x'] ) ? $option ['x'] : $x;
  224. $org_img_im_x = ($org_img_im_x > $org_img_w 또는 $ org_img_im_x < 0) ? $x : $org_img_im_x;
  225. $y = $org_img_h - $mark_img_h;
  226. $org_img_im_y = isset ( $option ['y'] ) ? $option ['y'] : $ y;
  227. $org_img_im_y = ($org_img_im_y > $org_img_h 또는 $org_img_im_y < 0) ? $y : $org_img_im_y;
  228. //알파
  229. $alpha = isset ( $option [' alpha'] ) ? $option ['alpha'] : 50;
  230. $alpha = ($alpha > 100 또는 $alpha < 50) : $alpha;
  231. //이미지 병합
  232. imagecopymerge ( $org_img_im, $mark_img_im, $org_img_im_x, $org_img_im_y, $mark_img_im_x, $mark_img_im_y, $mark_img_w, $mark_img_h, $alpha );
  233. / /출력(저장) 이미지
  234. if (!empty ( $save_img ))
  235. {
  236. $org_funcs ['save_func'] ( $org_img_im, $save_img );
  237. } else
  238. {
  239. 헤더( $org_funcs [ 'header'] );
  240. $org_funcs ['save_func']( $org_img_im );
  241. }
  242. //캔버스 삭제
  243. imagedestroy( $org_img_im );
  244. imagedestroy ( $mark_img_im );
  245. return array ('flag' => True, 'msg' => '' );
  246. }
  247. /* *
  248. *
  249. * 이미지 확인
  250. * @paramknown_type $img_path
  251. * @return array('flag'=>true/false,'msg'=>ext/error message)
  252. */
  253. 비공개 함수 is_img($img_path)
  254. {
  255. if (!file_exists ( $img_path ))
  256. {
  257. 반환 배열 ('flag' => False, 'msg' => "$img_path 이미지 로드 실패! " );
  258. }
  259. $ext = 폭발( '.', $img_path );
  260. $ext = strtolower( end( $ext ) );
  261. if(!in_array( $ext, $ this->exts ))
  262. {
  263. return array ('flag' => False, 'msg' => "$img_path 이미지의 형식이 잘못되었습니다!" );
  264. }
  265. 반환 배열 ('flag' => True, 'msg' => $ext );
  266. }
  267. /**
  268. *
  269. * 올바른 이미지 함수를 반환합니다
  270. * @paramknown_type $ext
  271. */
  272. 비공개 함수 get_img_funcs($ext)
  273. {
  274. //选择
  275. 스위치($ext)
  276. {
  277. case 'jpg' :
  278. $header = 'Content-Type: image/jpeg';
  279. $createfunc = 'imagecreatefromjpeg';
  280. $savefunc = 'imagejpeg';
  281. break;
  282. case 'jpeg' :
  283. $header = 'Content-Type:image /jpeg';
  284. $createfunc = 'imagecreatefromjpeg';
  285. $savefunc = 'imagejpeg';
  286. break;
  287. case 'gif' :
  288. $header = 'Content-Type:image/ gif';
  289. $createfunc = 'imagecreatefromgif';
  290. $savefunc = 'imagegif';
  291. break;
  292. case 'bmp' :
  293. $header = '콘텐츠 유형:이미지/bmp ';
  294. $createfunc = 'imagecreatefrombmp';
  295. $savefunc = 'imagebmp';
  296. break;
  297. 기본값:
  298. $header = 'Content-Type:image/png';
  299. $createfunc = 'imagecreatefrompng';
  300. $savefunc = 'imagepng';
  301. }
  302. 반환 배열('save_func' => $savefunc, 'create_func' => $createfunc, 'header' = > $header );
  303. }
  304. /**
  305. *
  306. * 디렉터리를 확인하고 생성해 보세요.
  307. * @param $save_img
  308. */
  309. 비공개 함수 check_dir($save_img)
  310. {
  311. $dir = dirname ( $save_img );
  312. 만일(! is_dir ( $dir ))
  313. {
  314. if (! mkdir ( $dir, 0777, true ))
  315. {
  316. return array ('flag' => False, 'msg' => "图文保存目录 $dir 无法创建!" );
  317. }
  318. }
  319. 반환 배열 ('flag' => True, 'msg' => '' );
  320. }
  321. }
  322. if (! 비어 있음 ( $_FILES ['test'] ['tmp_name'] ))
  323. {
  324. //例子
  325. $img = new Img ();
  326. //원래
  327. $name = 폭발( '.', $_FILES ['test'] ['name'] );
  328. $org_img = 'D:/test.' . end ( $name );
  329. move_uploaded_file ( $_FILES ['test'] ['tmp_name'], $org_img );
  330. $option = array ('width' => $_POST ['width'], '높이' => $_POST ['높이'] );
  331. if ($_POST ['type'] == 1)
  332. {
  333. $s = $img->resize_image ( $org_img , '', $option );
  334. } else
  335. {
  336. $img->thumb_img( $org_img, '', $option );
  337. }
  338. 연결 해제( $org_img );
  339. }
复代码

사용 방법:

水印
  1. $img = 새 Img();
  2. $org_img = 'D:/tt.png';
  3. $mark_img = 'D:/t .png';
  4. //保存水印图 Images(如果$save_img为空时,将会直接输图文)
  5. $save_img = 'D:/test99h/testone/sss.png';
  6. //水印设置调节
  7. $option = array ('x' => 50, 'y' => 50, 'alpha' => 80 );
  8. //生成水印图文
  9. $flag = $img->water_mark ( $org_img, $mark_img, $save_img, $option );
复代码

当我们调节 $option 参数时,会有数变化:

1 $option = 배열('x' => 0, 'y' => 0, '알파' => 50 );

2$option = 배열('x' => 50, 'y' => 50, '알파' => 80 );


3 如果你不设置$option 参数,将会采用默认值:

如果要纯文字式的水印,可以参看这里:http://www.php.net/manual/zh/image.examples.merged-watermark.php
  1. //例子
  2. $img = 새 이미지();
  3. $org_img = 'D:/tt.png';
  4. //压缩图picture(100*100)
  5. $option = array ('width' => 100, 'height' => 100 );
  6. //$save_img为空时,将会直接输출图이미지到浏览器
  7. $save_img = 'D:/test99h/testone/sss_thumb.png';
  8. $flag = $img->thumb_img ( $org_img, $save_img, $option );
复代码

调节$옵션의 큰 크기:
  1. $option = 배열('너비' => 200, '높이' => 200);
제제대码

水印与压缩图
  1. $img = new Img ();
  2. //hara图
  3. $org_img = 'D:/tt.png';
  4. //水印标记图
  5. $mark_img = 'D:/t.png';
  6. //保存水印图文
  7. $save_img = 'D:/test99h/testone/sss.png';
  8. //水印设置调节
  9. $option = array ('x' => 50, 'y' => 50, 'alpha' => 60 );
  10. //生成水印图文
  11. $flag = $img->water_mark ( $org_img, $mark_img, $save_img, $option );
  12. //压缩水印图文
  13. $option = array ('너비' => 200, '높이' => 200 );
  14. //保存压缩图
  15. $save_img2 = 'D:/test99h/testone/sss2_thumb.png';
  16. $flag = $img->thumb_img ( $save_img, $save_img2, $ 옵션 ); //等比例压缩类似
复代码

생성된 워터마크 이미지를 압축할 때, 압축 후 생성된 이미지의 형식은 원본 이미지 및 워터마크 이미지와 일치해야 합니다. 그렇지 않으면 알 수 없는 오류가 발생합니다.

또한 참고: 이미지 압축의 원리는 제가 고안한 것이 아닙니다.
이미지 처리, 비례, PHP


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