ホームページ > バックエンド開発 > PHPチュートリアル > PHPを使用して複数の写真を1枚に結合する方法

PHPを使用して複数の写真を1枚に結合する方法

php中世界最好的语言
リリース: 2023-03-18 07:22:01
オリジナル
3691 人が閲覧しました

ここでの合成は、複数の写真を 1 つに結合することであり、必要な友達は直接ダウンロードできます。

画像合成はブラウザ上で表示でき、フォルダに保存できます


例は次のとおりです:

<?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 中国語 Web サイトのその他の関連記事にご注意ください。

関連書籍:

php gifアニメーションを合成または作成する

php imagick拡張機能画像を合成する2つの方法_PHPチュートリアル

GD関数画像を合成する関連する質問jpg 、png )

以上がPHPを使用して複数の写真を1枚に結合する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート