public function createMosaicGroupAvatar($pic_list = array(), $bg_w = 396, $bg_h = 396) { if (!$pic_list) { $result = new \stdClass(); $result->img_id = 0; $result->url = ''; return $result; } $pic_list = array_slice($pic_list, 0, 9); // 只操做前9個圖片 $background = imagecreatetruecolor($bg_w, $bg_h); // 背景圖片 $color = imagecolorallocate($background, 216, 216, 216); // 爲真彩色畫布建立白色背景,再設置爲透明 imagefill($background, 0, 0, $color); //區域填充 imageColorTransparent($background, $color); // 將某個顏色定義爲透明色 $pic_count = count($pic_list); $lineArr = array(); // 須要換行的位置 $space_x = 3; $space_y = 3; $line_x = $pic_h = $start_y = 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 = 124; // 開始位置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 = 85.5; // 開始位置X $start_y = 85.5; // 開始位置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 = 85.5; // 開始位置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 = 166.5; // 開始位置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 = 80.5; // 開始位置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; } $image_info = getimagesize($pic_path); $image_suffix = end(explode('/', end($image_info))); switch ($image_suffix) { case 'png': $resource = imagecreatefrompng($pic_path); break; default: $resource = imagecreatefromjpeg($pic_path); } $image_width = imagesx($resource); $image_height = imagesy($resource); // 圖片圓角處理 $radius = 0; //20 40-貌似不錯 50也不錯 // lt(左上角) $lt_corner = $this->get_lt_rounder_corner($radius); imagecopymerge($resource, $lt_corner, 0, 0, 0, 0, $radius, $radius, 100); // lb(左下角) $lb_corner = imagerotate($lt_corner, 90, 0); imagecopymerge($resource, $lb_corner, 0, $image_height - $radius, 0, 0, $radius, $radius, 100); // rb(右上角) $rb_corner = imagerotate($lt_corner, 180, 0); imagecopymerge($resource, $rb_corner, $image_width - $radius, $image_height - $radius, 0, 0, $radius, $radius, 100); // rt(右下角) $rt_corner = imagerotate($lt_corner, 270, 0); imagecopymerge($resource, $rt_corner, $image_width - $radius, 0, 0, 0, $radius, $radius, 100); // $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; } $fname = 'xshop' . date('YmdHis').rand(100, 999); $tmp_img_path = '/tmp/'.$fname.'.jpg'; imagejpeg($background, $tmp_img_path); /*
上傳圖片
*/unlink($tmp_img_path); // 釋放內存 imagedestroy($background); return $wx_img_res; } /** * [產生一個弧角圖片] * @param [type] $radius [弧度] * @return [type] [description] */ public function get_lt_rounder_corner($radius) { // $radius:弧角圖片的大小 $img = imagecreatetruecolor($radius, $radius); $bgcolor = imagecolorallocate($img, 223, 223, 223); // $bgcolor = imagecolorallocate($img, 216, 216, 216); $fgcolor = imagecolorallocate($img, 0, 0, 0); imagefill($img, 0, 0, $bgcolor); // $radius,$radius:以圖像的右下角開始畫弧 // $radius*2, $radius*2:已寬度、高度畫弧 // 180, 270:指定了角度的起始和結束點 // fgcolor:指定顏色 imagefilledarc($img, $radius, $radius, $radius * 2, $radius * 2, 180, 270, $fgcolor, IMG_ARC_PIE); // 設置顏色爲透明 imagecolortransparent($img, $fgcolor); return $img; }
效果:this