> 백엔드 개발 > PHP 튜토리얼 > PHP를 사용하여 여러 장의 사진을 하나로 결합하는 방법

PHP를 사용하여 여러 장의 사진을 하나로 결합하는 방법

php中世界最好的语言
풀어 주다: 2023-03-18 07:22:01
원래의
3691명이 탐색했습니다.

여기서 합성은 GIF 사진이 아닌 여러 장의 사진을 하나로 합치는 것입니다. 필요한 친구는 직접 다운로드할 수 있습니다.

이미지 합성은 브라우저에 표시되고 폴더에 저장될 수 있습니다.


예는 다음과 같습니다.

<?php
 /**
 * 图片合并
 **/
  
 $pic_list  = array(
  &#39;img2.png&#39;,
  &#39;img2.png&#39;,
  &#39;logo.png&#39;,
  &#39;logo.png&#39;,
  &#39;logo.png&#39;,
  &#39;img2.png&#39;,
  &#39;img2.png&#39;,
  &#39;img2.png&#39;,
  &#39;img2.png&#39;
 );
   
 $pic_list = array_slice($pic_list, 0, 9); // 只操作前9个图片
  
 $bg_w = 150; // 背景图片宽度
 $bg_h = 150; // 背景图片高度
  
 $background = imagecreatetruecolor($bg_w,$bg_h); // 背景图片
 $color = imagecolorallocate($background, 202, 201, 201); // 为真彩色画布创建白色背景,再设置为透明
 imagefill($background, 0, 0, $color);
 imageColorTransparent($background, $color);
  
 $pic_count = count($pic_list);
 $lineArr = array(); // 需要换行的位置
 $space_x = 3;
 $space_y = 3;
 $line_x = 0;
 switch($pic_count) {
 case 1: // 正中间
  $start_x = intval($bg_w/4); // 开始位置X
  $start_y = intval($bg_h/4); // 开始位置Y
  $pic_w = intval($bg_w/2); // 宽度
  $pic_h = intval($bg_h/2); // 高度
  break;
 case 2: // 中间位置并排
  $start_x = 2;
  $start_y = intval($bg_h/4) + 3;
  $pic_w = intval($bg_w/2) - 5;
  $pic_h = intval($bg_h/2) - 5;
  $space_x = 5;
  break;
 case 3:
  $start_x = 40; // 开始位置X
  $start_y = 5; // 开始位置Y
  $pic_w = intval($bg_w/2) - 5; // 宽度
  $pic_h = intval($bg_h/2) - 5; // 高度
  $lineArr = array(2);
  $line_x = 4;
  break;
 case 4:
  $start_x = 4; // 开始位置X
  $start_y = 5; // 开始位置Y
  $pic_w = intval($bg_w/2) - 5; // 宽度
  $pic_h = intval($bg_h/2) - 5; // 高度
  $lineArr = array(3);
  $line_x = 4;
  break;
 case 5:
  $start_x = 30; // 开始位置X
  $start_y = 30; // 开始位置Y
  $pic_w = intval($bg_w/3) - 5; // 宽度
  $pic_h = intval($bg_h/3) - 5; // 高度
  $lineArr = array(3);
  $line_x = 5;
  break;
 case 6:
  $start_x = 5; // 开始位置X
  $start_y = 30; // 开始位置Y
  $pic_w = intval($bg_w/3) - 5; // 宽度
  $pic_h = intval($bg_h/3) - 5; // 高度
  $lineArr = array(4);
  $line_x = 5;
  break;
 case 7:
  $start_x = 53; // 开始位置X
  $start_y = 5; // 开始位置Y
  $pic_w = intval($bg_w/3) - 5; // 宽度
  $pic_h = intval($bg_h/3) - 5; // 高度
  $lineArr = array(2,5);
  $line_x = 5;
  break;
 case 8:
  $start_x = 30; // 开始位置X
  $start_y = 5; // 开始位置Y
  $pic_w = intval($bg_w/3) - 5; // 宽度
  $pic_h = intval($bg_h/3) - 5; // 高度
  $lineArr = array(3,6);
  $line_x = 5;
  break;
 case 9:
  $start_x = 5; // 开始位置X
  $start_y = 5; // 开始位置Y
  $pic_w = intval($bg_w/3) - 5; // 宽度
  $pic_h = intval($bg_h/3) - 5; // 高度
  $lineArr = array(4,7);
  $line_x = 5;
  break;
 }
 foreach( $pic_list as $k=>$pic_path ) {
  $kk = $k + 1;
  if ( in_array($kk, $lineArr) ) {
   $start_x = $line_x;
   $start_y = $start_y + $pic_h + $space_y;
  }
  $pathInfo = pathinfo($pic_path);
  switch( strtolower($pathInfo[&#39;extension&#39;]) ) {
   case &#39;jpg&#39;:
   case &#39;jpeg&#39;:
    $imagecreatefromjpeg = &#39;imagecreatefromjpeg&#39;;
   break;
   case &#39;png&#39;:
    $imagecreatefromjpeg = &#39;imagecreatefrompng&#39;;
   break;
   case &#39;gif&#39;:
   default:
    $imagecreatefromjpeg = &#39;imagecreatefromstring&#39;;
    $pic_path = file_get_contents($pic_path);
   break;
  }
  $resource = $imagecreatefromjpeg($pic_path);
  // $start_x,$start_y copy图片在背景中的位置
  // 0,0 被copy图片的位置
  // $pic_w,$pic_h copy后的高度和宽度
  imagecopyresized($background,$resource,$start_x,$start_y,0,0,$pic_w,$pic_h,imagesx($resource),imagesy($resource)); // 最后两个参数为原始图片宽度和高度,倒数两个参数为copy时的图片宽度和高度
  $start_x = $start_x + $pic_w + $space_x;
 }
  
 header("Content-type: image/jpg");
 imagejpeg($background);
 imagegif($background, "./hero_gam.png");
   
?>
로그인 후 복사


이 사례를 읽고 나면 방법을 마스터했다고 생각합니다. 중국 웹사이트의 PHP 기타 관련 기사에 주목해주세요!

관련 읽기:

php 합성 또는 gif 애니메이션 생성

php imagick 확장 그림을 합성하는 두 가지 방법_PHP 튜토리얼

GD 기능 합성 사진관련 질문(jpg , png )

위 내용은 PHP를 사용하여 여러 장의 사진을 하나로 결합하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿