Проблема обновления кернинга в PHP с помощью функций imagettftext () и imagefttext () - PullRequest
4 голосов
/ 09 апреля 2010

Наш сервер разработки был недавно обновлен до PHP v5.2.13. С этим обновлением мы обнаружили, что у наших изображений png есть проблемы с кернингом (межбуквенный интервал). Мы перепробовали множество шрифтов и пока не нашли решения.

Мы создаем изображения с использованием библиотеки GD и записываем текст в изображения с помощью файлов шрифтов и функций imagettftext () или imagefttext ().

Кто-нибудь еще сталкивался с этим? Я что-то неправильно понимаю, или это должно быть отправлено в PHP как ошибка? Есть ли какие-нибудь крутые обходные пути, о которых я еще не думал?

Вот пример новой и старой жирной тахомы. Другие шрифты (полужирный и не полужирный) имеют ту же проблему. Некоторые буквы и цифры кажутся нецентральными или что-то в этом роде.

Плохо - новый PHP

Good - old PHP v5.2.11 (слова немного отличаются, потому что это наш сервер разработки, а другой - живой сервер)

Ответы [ 2 ]

3 голосов
/ 09 апреля 2010

«Отслеживание» - это аналогичный термин для определения того, насколько плотный или свободный текст установлен. Вам, возможно, повезет, что вам удастся поискать, например, этот результат .

0 голосов
/ 31 августа 2016

Кернинг у нас не работал благодаря используемому нами шрифту, поэтому нам пришлось включить ручной кернинг для конкретных буквенных комбинаций, таких как AV, AW ... и т. Д.

/**
 * This function lets you write a string with your own letter spacing ($t)
 * and kern specific letter combinations like AV
 * 
 * @param type $im An image resource, returned by one of the image creation functions
 * @param type $size The font size. Depending on your version of GD, this should be specified as the pixel size (GD1) or point size (GD2).
 * @param type $angle The angle in degrees, with 0 degrees being left-to-right reading text. Higher values represent a counter-clockwise rotation. For example, a value of 90 would result in bottom-to-top reading text.
 * @param type $t Letter Spacing
 * @param type $k Kerning Spacing
 * @param type $x The coordinates given by x and y will define the basepoint of the first character (roughly the lower-left corner of the character). This is different from the imagestring(), where x and y define the upper-left corner of the first character. For example, "top left" is 0, 0.
 * @param type $y The y-ordinate. This sets the position of the fonts baseline, not the very bottom of the character.
 * @param type $color The color index. Using the negative of a color index has the effect of turning off antialiasing. See imagecolorallocate().
 * @param type $font The path to the TrueType font you wish to use.
 * @param type $text Text to write/print to the image
 */
function ImageTTFTextWithSpacing($im, $size, $angle, $t, $k, $x, $y, $color, $font, $text) {
    $numchar = strlen($text);
    for($i = 0; $i < $numchar; $i++) {
        # Assign character
        $char[$i] = substr($text, $i, 1);

        //Top is wider than bottom of character
        $up = ['Y','V','W'];
        //Bottom is wider than top of character
        $down = ['A'];
        //From the second letter on
        if( $i > 0 && 
                //check whether we have TOP and BOTTOM type character 
                //next to each other so we need to adjust spacing
                ((in_array($char[$i], $up) && in_array($char[$i-1], $down)) || 
                (in_array($char[$i-1], $up) && in_array($char[$i], $down)) )) {
            $w -= $k;
        }

        # Write character
        imagettftext($im, $size, $angle, ($x + $w + ($i * $t)), $y, $color, $font, $char[$i]);

        # Get width of character
        $width = imagettfbbox($size, $angle, $font, $char[$i]);
        $w = $w + $width[2];
    }
}
...