imagepsslantfont(integer font_identifier, double slant_factor)
Функция imagepsslantfont используется для придания наклона шрифту, который называется курсивом. Аргументом font_identifier является целое число, возвращенное функцией imagepsloadfont. Функция slant_factor действует аналогично аргументу extension_factor функции imagepsextendfont. Значения больше единицы приводят к наклону шрифта вправо, а значения меньше единицы вызывают наклон шрифта влево.
array imagepstext(resource image, string text, integer font_identifier, integer size, integer foreground, integer background, integer x, integer y, integer spacing, integer leading, double angle, integer antialias_steps)
Функция imagepstext (листинг 16.27) создает текстовую строку с использованием шрифта PostScript в изображении. Аргумент image является целым числом и возвращается функциями imagecreate, imagecreatefrompng или аналогичными. Аргумент font_identifier является значением, возвращаемым функцией imageps-loadfont. Аргумент size задает высоту в пикселях. Аргументы foreground и background представляют собой идентификаторы цветов. Фоновый цвет используется для сглаживания. Ограничивающая рамка этим цветом не заполняется. Аргументы x и y задают верхний левый угол, из которого начинается черчение. Аргумент spacing управляет расстоянием между строками текста по вертикали, аргумент leading - расстоянием между символами по горизонтали. Оба аргумента выражаются в 1/1000 "M" и прибавляются к расстояниям, принятым для данного шрифта по умолчанию. Аргумент angle задает угол в градусах в отсчете от обычной ориентации слева направо. Аргумент antialias_steps определяет количество цветов, применяемых при использовании сглаживания. Допустимы два значения: 4 и 16. Последние четыре аргумента являются необязательными. Возвращаемый массив содержит две пары координат, задающих нижний левый и верхний правый углы ограничивающей рамки. 

j Листинг 16.27. Функция imagepstext_
<?php
/*
**Наложить текст на фотографию, воспользовавшись шрифтом
PostScript
*/
// задать параметры текста $image = "waterfall.jpg";
$font_file = "/usr/share/fonts/default/Type1/n019003l.pfb"; $size = 100; $angle = 0;
$text = "Waterfall";
$antialias_steps = 16; $spacing = 0; $leading = 0; // загрузить шрифт
if(!($myFont = imagepsloadfont($font_file)))
{
print("Невозможно загрузить шрифт!"); exit();
}
//получить ограничивающую рамку
$Box = imagepsbbox($text, $myFont, $size, $spacing, $leading,
$angle); // загрузить фотографию $image = imagecreatefromjpeg($image); //задать цвет текста
$colorText = imagecolorallocate($image, 0x00, 0xFF, 0x00); $colorClearText = imagecolorresolvealpha($image, 0x00, 0xFF, 0x00, 0xFF);
$colorShadow = imagecolorresolvealpha($image, 0x00, 0x00,
0x00, 0x50);
$colorClearShadow = imagecolorresolvealpha($image, 0x00, 0x00,
0x00, 0xFF);
imagelayereffect($image, IMG_EFFECT_NORMAL); // нанести легкую тень 
imagepstext($image, $text, $myFont, $size, $colorShadow, $colorClearShadow, 55, $Box[3]+55, $spacing, $leading, $angle, $antialias_steps); // написать текст
imagepstext($image, $text, $myFont, $size, $colorText, $colorClearText,
50, $Box[3]+50, $spacing, $leading, $angle, $antialias_steps); // загрузить шрифт imagepsfreefont($myFont); //отправить полученное изображение header("Content-type: image/png"); imagepng($image);
?>

imagerectangle(resource image, integer top_left_x, integer top_left_y, integer bottom_right_x, integer bottom_right_y, integer color)
Функция imagerectangle (листинг 16.28) вычерчивает прямоугольник по координатам верхнего левого и нижнего правого углов. Внутри прямоугольник не раскрашивается, как это делается при работе функции imagefilledrectangle. Вывод функции представлен на рис. 16.14.

j Листинг 16.28. Функция imagerectangle_
<?php
// создать зеленый квадрат $image = imagecreate(200,200);
$colorGreen = imagecolorallocate($image, 128, 255, 128); $colorBlack = imagecolorallocate($image, 0, 0, 0); imagefill($image, 0, 0, $colorGreen); // начертить черный прямоугольник imagerectangle($image,
10, 10, 90, 90,
$colorBlack); // отправить полученное изображение header("Content-type: image/png"); imagepng($image);
?>
Обработка изображений и графики
resource imagerotate(resource image, double angle, integer background)
Функция imagerotate (листинг 16.29) возвращает новое изображение, повернутое относительно исходного изображения на заданный угол. Положительное значение угла, задаваемое в аргументе angle, вращает изображение по часовой стрелке. Аргумент background задает цвет, используемый для заполнения незакрытых областей на углах, некратных 90. Результат работы этой функции показан на рис. 16.15.

Листинг 16.29. Функция imagerotate

<?php
//создать зеленый квадрат
$image = imagecreatetruecolor(200,200);
$colorGreen = imagecolorallocate($image, 128, 255, 128); $colorBlack = imagecolorallocate($image, 0, 0, 0); imagefill($image, 0, 0, $colorGreen); //начертить черный прямоугольник imagerectangle($image,
10, 10, 90, 90,
$colorBlack); //вращать на 35 градусов и заменить $image = imagerotate($image, 35, $colorBlack); // отправить полученное изображение header("Content-type: image/png"); imagepng($image);
?>
Обработка изображений и графики
imagesavealpha(resource image, boolean on)
Функция imagesavealpha задает сохранение альфа-уровней при записи изображения на диск.