亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php如何實現圖片合成

發布時間:2021-08-11 09:54:46 來源:億速云 閱讀:129 作者:小新 欄目:開發技術

這篇文章主要介紹php如何實現圖片合成,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

1.多張圖片合成一張比如:

圖片合成,可以顯示在瀏覽器上面同時保存到文件夾下面

php如何實現圖片合成

實例如下所示:

<?php 
 /** 
 * 圖片合并 
 **/ 
 
 $pic_list  = array( 
  'img2.png', 
  'img2.png', 
  'logo.png', 
  'logo.png', 
  'logo.png', 
  'img2.png', 
  'img2.png', 
  'img2.png', 
  'img2.png' 
 ); 
  
 $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['extension']) ) { 
   case 'jpg': 
   case 'jpeg': 
    $imagecreatefromjpeg = 'imagecreatefromjpeg'; 
   break; 
   case 'png': 
    $imagecreatefromjpeg = 'imagecreatefrompng'; 
   break; 
   case 'gif': 
   default: 
    $imagecreatefromjpeg = 'imagecreatefromstring'; 
    $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如何實現圖片合成”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

都昌县| 资阳市| 和林格尔县| 龙口市| 罗平县| 都江堰市| 沿河| 盐源县| 沾化县| 南康市| 静海县| 德江县| 辽中县| 德昌县| 闻喜县| 天柱县| 徐汇区| 龙川县| 环江| 海淀区| 潜山县| 常山县| 罗江县| 马龙县| 合江县| 上蔡县| 中山市| 扶余县| 五指山市| 家居| 乌鲁木齐市| 清水县| 双桥区| 象山县| 青海省| 阳东县| 寻甸| 平舆县| 佛坪县| 宿迁市| 呈贡县|