문자열의 너비와 높이 구하기

설명.png

대단할것은 없는 강좌이지만,
제 강좌를 출처를 밝히고 외부로 퍼가는 것은 허용하지만,
다른 강좌의 자료나 책의 자료로 사용되거나 부분적인 인용은 허용하지 않습니다.

강좌는 php 5. 대를 기준으로 하며, 이미지 관련을 다룹니다.
이미지에 글을 쓰거나 이미지를 합치거나 하는 등의 내용을 다루어 볼까 합니다.
나중에는 간단한 짤방 만들기 같은 것도 할수 있지 않을까 싶습니다.

이미지관련 > 문자열의 너비와 높이 구하기 

 

이미지에 글자를 쓰는 작업을 할때,
"글자 길이에 상관없이 정확히 중간에 위치시키고 싶다."
"왼쪽 상단에 약간의 공간을 두고 위치 시키고 싶다.
"
등등의 글자 위치에 대한 문제가 발생하곤 합니다.

이런 문제를 해결하기 위해서는
글자가 차지하게 될 너비와 높이를 알아야 하고,
전체 이미지 크기에서 각 포지션에 맞는 좌표점을 찾아내는 것이 필요합니다.


오늘은 제일 먼저 글자의 너비와 높이를 구하는 부분을 다루어 볼까 합니다.

아래의 예제는 제가 알아보기 쉽게 작성한 것입니다.

 

예제2 > study2.php

 

<?php

$font_file = './Daum_Regular.ttf';
$font_size = 20;
$angle = 0;
$string = 'FABCDEFGM';

?>

폰트파일 : <?=$font_file?><br>

폰트크기 : <?=$font_size?> px<br>

기울기 : <?=$angle?><br>

문자열 : <?=$string?><br>
<br>

imageftbbox 함수를 사용하여 받은 결과값
<br>

<?

$array = imageftbbox ( $font_size, $angle, $font_file, $string );

print_r($array);
echo "<br><br>" . PHP_EOL;

?>

Y 좌표에 -1 을 곱한후의 결과값
<br>

<?

$array[1] *= -1;
$array[3] *= -1;
$array[5] *= -1;
$array[7] *= -1;

print_r($array);
echo "<br><br>" . PHP_EOL;

?>

왼쪽 상단의 XY 좌표를 0, 0 으로 변경해 준후의 결과값
<br>

<?

$x_gap = 0;
$y_gap = 0;

$x_gap = $array[0] * -1;
$array[0] += $x_gap;
$array[2] += $x_gap;
$array[4] += $x_gap;
$array[6] += $x_gap;

$y_gap = $array[1] * -1;
$array[1] += $y_gap;
$array[3] += $y_gap;
$array[5] += $y_gap;
$array[7] += $y_gap;

print_r($array);
echo "<br><br>" . PHP_EOL;

?>

문자열이 차지하게 될 너비와 높이는
<br>

<?

$width = $array[4] - $array[0];
$height = $array[5] - $array[1];

?>

너비 : <?=$width?><br>

높이 : <?=$height?><br>

<?

$im = imagecreatetruecolor(200, 200);
$red = imagecolorallocate($im, 0xFF, 0x00, 0x00);
$black = imagecolorallocate($im, 0x00, 0x00, 0x00);

imagefilledrectangle($im, 0, 0, 199, 199, $red);
imagerectangle ( $im , 0 ,0 , $width , $height , $black );
imagefttext($im, $font_size, $angle, 0, $height, $black, $font_file, $string);
imagepng($im, 'temp/1.png');
imagedestroy($im);

?>

<br>
<img src='temp/1.png?<?=time()?>'>
<br>
<br>

왼쪽 상단의 XY 좌표를 조정한후의 결과
<br>

<?

$im = imagecreatetruecolor(200, 200);
$red = imagecolorallocate($im, 0xFF, 0x00, 0x00);
$black = imagecolorallocate($im, 0x00, 0x00, 0x00);

imagefilledrectangle($im, 0, 0, 199, 199, $red);
imagerectangle ( $im , 0 ,0 , $width , $height , $black );
imagefttext($im, $font_size, $angle, 0 - $x_gap, $height - $y_gap, $black, $font_file, $string);
imagepng($im, 'temp/2.png');
imagedestroy($im);

?>

<br>
<img src='temp/2.png?<?=time()?>'>

 

일단 위의 예제를 그대로 복사하여 study2.php 에 저장한다음 브라우져로 일단 확인해보시기 바랍니다.
temp 디렉토리를 생성하여 주시고 linux 같은 경우는 퍼미션을 777 로 주십시오.

 

 

array imageftbbox ( float $size , float $angle , string $fontfile , string $text [, array $extrainfo ] )

전달 받은 글자크기, 기울기, 글자파일, 작성한 문자열을 가지고
이문자열이 차지할 너비와 높이를 직사각형의 좌표로 반환 해 줍니다.

0 => lower left corner, X position => 실제로는 왼쪽 상단
1 => lower left corner, Y position => 실제로는 왼쪽 상단
2 => lower right corner, X position => 실제로는 오른쪽 상단
3 => lower right corner, Y position => 실제로는 오른쪽 상단
4 => upper right corner, X position => 실제로는 오른쪽 하단
5 => upper right corner, Y position => 실제로는 오른쪽 하단
6 => upper left corner, X position => 실제로는 왼쪽 하단
7 => upper left corner, Y position => 실제로는 왼쪽 하단

 

그런데 여기서 유의할점은 Y 좌표는 실제 좌표와는 반대로 음수로 나온다는 점입니다.
이유는 아마도 상단에서 위로 그려서 그렇다고 생각됩니다.

 

[첨부된 이미지를 확인하여 주십시오.]

 

글자를 이미지에 쓰게 될때 Y 좌표는 양수로 써야 하며, 위에서 아래로 갈때 0 부터 숫자가 증가하게 됩니다.
그래서 imageftbbox 받은 값의 Y좌표는 모두 곱하기 -1 을 해서 처리합니다.

(실제로는 위아래를 뒤집은 것인데 직사각형이므로 뒤집어도 결과가 같습니다.)


$array[1] *= -1;
$array[3] *= -1;
$array[5] *= -1;
$array[7] *= -1;


그런데 왼쪽 상단의 XY 좌표가 0, 0 이 아닙니다.
우리가 필요한것은 0, 0 으로 부터의 좌표이므로 전체적으로 조정합니다.

$x_gap = 0;
$y_gap = 0;

$x_gap = $array[0] * -1;
$array[0] += $x_gap;
$array[2] += $x_gap;
$array[4] += $x_gap;
$array[6] += $x_gap;

$y_gap = $array[1] * -1;
$array[1] += $y_gap;
$array[3] += $y_gap;
$array[5] += $y_gap;
$array[7] += $y_gap;

이제 실제 문자열이 차지하게될 너비와 높이 를 구합니다.
각 대각의 x 좌표를 빼서 너비를 구하고
각 대각의 y 좌표를 빼서 높이를 구합니다.


$width = $array[4] - $array[0];
$height = $array[5] - $array[1];



bool imagerectangle ( resource $image , int $x1 , int $y1 , int $x2 , int $y2 , int $color )
대각의 두 xy 좌표를 받아서 직사각형을 그리는 함수 입니다.




우리는 왼쪽 상단에 딱 붙여서 그릴 것이므로
imagerectangle ( $im , 0 ,0 , $width , $height , $black );
와 같이 사용하였습니다.

imagefttext($im, $font_size, $angle, 0, $height, $black, $font_file, $string);
로 같은 위치에 글자를 그렷습니다만. 뭔가 미세하게 박스랑 차이가 납니다.

왼쪽 상단의 XY 좌표가 0, 0 이 아니엇던 것을 주목합니다.
폰트나 글자에 따라 약간의 차이가 있는데 그 좌표에서 문자열을 쓰는 것을 시작해야만

원래 너비나 높이의 문자열이 그려집니다.
따라서 시작점을 조정합니다.

imagefttext($im, $font_size, $angle, 0 - $x_gap, $height - $y_gap, $black, $font_file, $string);

 

 

다음 내용에서는 이미지의 오른쪽 상단, 왼쪽 하단, 오른쪽 하단, 가운데 위치해서 문자열을 그리는 것을 해보겠습니다. 

첨부파일

설명.png (5.2 KB)
0회 2014-07-21 10:23
|

댓글 1개

강좌 예제: https://dbckdghk-c9-terrorboy.c9.io/study/study2.php
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 3,427
11년 전 조회 838
11년 전 조회 740
11년 전 조회 1,031
11년 전 조회 838
11년 전 조회 647
11년 전 조회 1,077
11년 전 조회 1,782
11년 전 조회 1,029
11년 전 조회 796
11년 전 조회 638
11년 전 조회 2,402
11년 전 조회 1,951
11년 전 조회 2,482
11년 전 조회 1,415
11년 전 조회 2,691
11년 전 조회 3,103
11년 전 조회 4,444
11년 전 조회 5,800
11년 전 조회 2,139
11년 전 조회 1,707
11년 전 조회 1,449
11년 전 조회 1,112
11년 전 조회 854
11년 전 조회 1,032
11년 전 조회 925
11년 전 조회 1,407
11년 전 조회 2,207
11년 전 조회 883
11년 전 조회 1,066
11년 전 조회 1,723
11년 전 조회 1,403
11년 전 조회 1,301
11년 전 조회 1,221
11년 전 조회 1,142
11년 전 조회 3,493
11년 전 조회 1,131
11년 전 조회 1,744
11년 전 조회 1,997
11년 전 조회 1,312
11년 전 조회 1,307
11년 전 조회 1,299
11년 전 조회 755
11년 전 조회 1,155
11년 전 조회 1,491
11년 전 조회 1,461
11년 전 조회 827
11년 전 조회 1,179
11년 전 조회 945
11년 전 조회 1,701
11년 전 조회 1,340
11년 전 조회 717
11년 전 조회 2,145
11년 전 조회 6,618
11년 전 조회 1,279
11년 전 조회 1,124
11년 전 조회 1,054
11년 전 조회 917
11년 전 조회 1,452
11년 전 조회 844
11년 전 조회 3,407
11년 전 조회 1,248
11년 전 조회 1,642
11년 전 조회 1,009
11년 전 조회 2,653
11년 전 조회 1,285
11년 전 조회 2,575
11년 전 조회 1,937
11년 전 조회 2,450
11년 전 조회 1,397
11년 전 조회 2,529
11년 전 조회 1,345
11년 전 조회 1,031
11년 전 조회 1,036
11년 전 조회 5,418
11년 전 조회 1,221
11년 전 조회 785
11년 전 조회 751
11년 전 조회 1,111
11년 전 조회 1,453
11년 전 조회 1,870
11년 전 조회 2,181
11년 전 조회 1,083
11년 전 조회 1,408
11년 전 조회 1,350
11년 전 조회 992
11년 전 조회 747
11년 전 조회 2,176
11년 전 조회 1,420
11년 전 조회 3,253
11년 전 조회 1,156
11년 전 조회 1,014
11년 전 조회 2,098
11년 전 조회 2,752
11년 전 조회 2,111
11년 전 조회 3,144
11년 전 조회 1,535
11년 전 조회 3,276
11년 전 조회 791
11년 전 조회 1,094
🐛 버그신고