function imageapi_gd_create_tmp in ImageAPI 5
Same name and namespace in other branches
- 6 imageapi_gd.module \imageapi_gd_create_tmp()
Create a truecolor image preserving transparency from a provided image.
Parameters
$image: An image object.
$width: The new width of the new image, in pixels.
$height: The new height of the new image, in pixels.
Return value
A GD image handle.
2 calls to imageapi_gd_create_tmp()
- imageapi_gd_image_crop in ./
imageapi_gd.module - Crop an image using the GD toolkit.
- imageapi_gd_image_resize in ./
imageapi_gd.module - Scale an image to the specified size using GD.
File
- ./
imageapi_gd.module, line 242 - GD2 toolkit functions
Code
function imageapi_gd_create_tmp($image, $width, $height) {
$res = imagecreatetruecolor($width, $height);
if ($image->info['extension'] == 'gif') {
// Grab transparent color index from image resource.
$transparent = imagecolortransparent($image->resource);
if ($transparent >= 0) {
// The original must have a transparent color, allocate to the new image.
$transparent_color = imagecolorsforindex($image->resource, $transparent);
$transparent = imagecolorallocate($res, $transparent_color['red'], $transparent_color['green'], $transparent_color['blue']);
// Flood with our new transparent color.
imagefill($res, 0, 0, $transparent);
imagecolortransparent($res, $transparent);
}
}
elseif ($image->info['extension'] == 'png') {
imagealphablending($res, FALSE);
$transparency = imagecolorallocatealpha($res, 0, 0, 0, 127);
imagefill($res, 0, 0, $transparency);
imagealphablending($res, TRUE);
imagesavealpha($res, TRUE);
}
else {
imagefill($res, 0, 0, imagecolorallocate($res, 255, 255, 255));
}
return $res;
}