以多种尺寸显示图像

时间:2013-07-12 11:06:46

标签: php image gd

我正在尝试为图像添加一些文本,并使用不同大小的php中的gd显示它。我知道如何显示1张图片。这是代码。

<?php
if (!isset($_FILES['image']['tmp_name'])) {
}

else{
$file=$_FILES['image']['tmp_name'];
$img_src = imagecreatefromstring(file_get_contents($file));
$img_dest = imagecreatetruecolor(100, 100);
$src_width = imagesx($img_src);
$src_height = imagesy($img_src);
imagecopyresized($img_dest, $img_src, 0, 0, 0, 0, 100, 100, $src_width, $src_height);

$text = $_POST['text'];
$font_path = 'arial.TTF';
$black = imagecolorallocate($img_dest, 0, 0, 0);
imagettftext($img_dest, 25, 0, 302, 62, $grey, $font_path, $text);
imagettftext($img_dest, 20, 0, 10, 20, $black, $font_path, $text);
header( "Content-type: image/png" );
imagepng( $img_dest );
imagedestroy( $img_dest );
imagedestroy( $img_src );
}
?>

但是如何在同一页面中显示多于1张相同的图像但是大小不同

请告诉我如何做到这一点。

1 个答案:

答案 0 :(得分:1)

您需要为自己创建每个图像。像你那样修改图像是不可能的,因为你将图像作为对象返回。

如果您对网络服务器具有写入权限,则可以保存其他生成的图像,例如

$src_w = 100;
$src_h = 100;

$img_50perc = imagecreatetruecolor($src_w / 2, $src_h / 2);
imagecopyresized($img_50perc, $img_dest, 0, 0, 0, 0, $src_w/2, $src_h/2, $src_w, $src_h);

$img_25perc = imagecreatetruecolor($src_w / 4, $src_h / 4);
imagecopyresized($img_25perc, $img_dest, 0, 0, 0, 0, $src_w/4, $src_h/4, $src_w, $src_h);

然后你可以保存图像:

imagepng($img_dest, 'dest_folder/myfile_100perc.png');
imagepng($img_50perc, 'dest_folder/myfile_50perc.png');
imagepng($img_25perc, 'dest_folder/myfile_25perc.png');

您可以在创建可以从这些文件名中动态创建的php页面创建图像img-tags

echo '100 Percent of size: <img src="dest_folder/myfile_100perc" />';
echo '50 Percent of size: <img src="dest_folder/myfile_50perc" />';   
echo '25 Percent of size: <img src="dest_folder/myfile_25perc" />'; 

另一种方法是自己创建每个图像,并通过给予php脚本的参数调整大小

100%: <img src="myImageResizer.php?faktor=1" />
50%:  <img src="myImageResizer.php?faktor=2" />
25%:  <img src="myImageResizer.php?faktor=4" />

然后用给定的faktor计算dest-size

$faktor = $_GET['faktor'];
if (!$faktor || !is_numeric($faktor)) $faktor = 1;
$src_w = 100 / $faktor;
$src_h = 100 / $faktor;