我正在尝试将 jpeg 放在 png 后面 - png 具有 alpha 透明度。
前景图片在这里: http: //peugeot208.srv.good-morning.no/images/marker-shadow.png
后面的图片是 Facebook 个人资料图片 - 通常是这样的: https ://graph.facebook.com/100000515495823/picture
结果图像失去透明度,而是黑色:http: //peugeot208.srv.good-morning.no/libraries/cache/test.png
这是我使用的代码:
// combine image with shadow
$newCanvas = imagecreatetruecolor(90,135);
$shadow = imagecreatefrompng("marker-shadow.png");
//imagealphablending($newCanvas, false);
imagesavealpha($newCanvas, true);
imagecopy($newCanvas, $canvas, 20, 23, 0, 0, 50, 50);
imagecopy($newCanvas, $shadow, 0, 0, 0, 0, 90, 135);
imagepng($newCanvas, $tempfile, floor($quality * 0.09));
如果我启用 imagealphablending($newCanvas, false);,结果是正确的(标记中间的孔是透明的)但是后面的图像消失了。
你能解释一下吗?:-)
谢谢!
编辑:找到解决方案
我做了一些摆弄,最终得到了这段代码——原点不是createimagetruecolor,而是从模板创建的图像——这是一个透明的png。
现在它可以工作了 - 结果是正确透明的。我真的不知道为什么。知道为什么吗?
fbimage.php
// Create markerIcon
$src = $_REQUEST['fbid'];
$base_image = imagecreatefrompng("../images/marker-template.png");
$photo = imagecreatefromjpeg("https://graph.facebook.com/".$src."/picture");
$top_image = imagecreatefrompng("../images/marker-shadow.png");
imagesavealpha($base_image, true);
imagealphablending($base_image, true);
imagecopy($base_image, $photo, 20, 23, 0, 0, 50, 50);
imagecopy($base_image, $top_image, 0, 0, 0, 0, 90, 135);
imagepng($base_image, "./cache/".$src.".png");
?>
<img src="./cache/<?php echo $src ?>.png" />
更新:检查以下代码 您可以在这里找到结果:http: //peugeot208.srv.good-morning.no/images/marker.php 如您所见,背景仍然是黑色的。
// create base image
$base_image = imagecreatetruecolor(90,135);
$photo = imagecreatefromjpeg("marker-original.jpg");
$top_image = imagecreatefrompng("marker-shadow.png");
imagesavealpha($top_image, true);
imagealphablending($top_image, true);
imagesavealpha($base_image, true);
imagealphablending($base_image, true);
// merge images
imagecopy($base_image, $photo, 20, 23, 0, 0, 50, 50);
imagecopy($base_image, $top_image, 0, 0, 0, 0, 90, 135);
// return file
header('Content-Type: image/png');
imagepng($base_image);