php gd库 拼接,php用gd库实现图片合并功能

在实际的开发中需要用到合并图片的功能,比如实现微信中的头像图片合并功能。

这里主要是使用的gd库去操作的,当然还可以用ImageMagick去实现这个功能。

效果如下:

2017111511946658937344.jpg

php代码:$pics   = array(

'1.jpg',

'2.jpg',

'3.jpg',

'4.jpg',

'5.jpg',

'6.jpg',

'7.jpg',

'8.jpg',

'9.jpg',

);

$pic_list    = array_slice($pics, 0, 9); // 只操作前9个图片

$bg_w    = 200; // 背景图片宽度

$bg_h    = 200; // 背景图片高度

$background = imagecreatetruecolor($bg_w,$bg_h); // 背景图片

$color   = imagecolorallocate($background, 255, 255, 255); // 为真彩色画布创建白色背景,再设置为透明

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后的高度和宽度

// 最后两个参数为原始图片宽度和高度,倒数两个参数为copy时的图片宽度和高度

imagecopyresized($background,$resource,$start_x,$start_y,0,0,$pic_w,$pic_h,imagesx($resource),imagesy($resource));

$start_x    = $start_x + $pic_w + $space_x;

}

header("Content-type: image/jpg");

imagejpeg($background);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用PHPGD可以实现布料排版功能,以下是一个简单的示例代码: ```php <?php // 创建画布 $width = 800; // 画布宽度 $height = 600; // 画布高度 $image = imagecreatetruecolor($width, $height); // 设置背景色和边框 $bgColor = imagecolorallocate($image, 255, 255, 255); // 白色背景 $borderColor = imagecolorallocate($image, 0, 0, 0); // 黑色边框 imagefill($image, 0, 0, $bgColor); imagerectangle($image, 0, 0, $width - 1, $height - 1, $borderColor); // 布料尺寸和位置信息 $materialWidth = 400; // 布料宽度 $materialHeight = 300; // 布料高度 $materialX = 50; // 布料左上角X坐标 $materialY = 50; // 布料左上角Y坐标 // 绘制布料矩形 $materialColor = imagecolorallocate($image, 255, 0, 0); // 红色布料 imagefilledrectangle($image, $materialX, $materialY, $materialX + $materialWidth - 1, $materialY + $materialHeight - 1, $materialColor); // 零件尺寸和位置信息 $partWidth = 100; // 零件宽度 $partHeight = 80; // 零件高度 $partX = $materialX + 50; // 零件左上角X坐标 $partY = $materialY + 50; // 零件左上角Y坐标 // 绘制零件矩形 $partColor = imagecolorallocate($image, 0, 0, 255); // 蓝色零件 imagefilledrectangle($image, $partX, $partY, $partX + $partWidth - 1, $partY + $partHeight - 1, $partColor); // 输出像 header('Content-type: image/png'); imagepng($image); // 销毁像资源 imagedestroy($image); ?> ``` 以上示例代码创建一个800x600的画布,绘制了一个红色的布料矩形和一个蓝色的零件矩形。可以根据实际需求,调整布料和零件的尺寸、位置以及颜色。最后通过`header('Content-type: image/png')`和`imagepng($image)`将像输出为PNG格式。 这只是一个简单的示例,实际应用中可能需要更复杂的算法来进行布料排版和优化。可以根据具体需求,结合GD提供的绘函数,编写更复杂的代码来实现布料排版功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值