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

설명.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,418
11년 전 조회 833
11년 전 조회 732
11년 전 조회 1,024
11년 전 조회 832
11년 전 조회 639
11년 전 조회 1,065
11년 전 조회 1,778
11년 전 조회 1,024
11년 전 조회 788
11년 전 조회 631
11년 전 조회 2,397
11년 전 조회 1,945
11년 전 조회 2,475
11년 전 조회 1,409
11년 전 조회 2,685
11년 전 조회 3,099
11년 전 조회 4,437
11년 전 조회 5,788
11년 전 조회 2,129
11년 전 조회 1,699
11년 전 조회 1,441
11년 전 조회 1,108
11년 전 조회 849
11년 전 조회 1,024
11년 전 조회 919
11년 전 조회 1,400
11년 전 조회 2,204
11년 전 조회 876
11년 전 조회 1,058
11년 전 조회 1,717
11년 전 조회 1,400
11년 전 조회 1,289
11년 전 조회 1,216
11년 전 조회 1,134
11년 전 조회 3,485
11년 전 조회 1,125
11년 전 조회 1,735
11년 전 조회 1,995
11년 전 조회 1,309
11년 전 조회 1,299
11년 전 조회 1,292
11년 전 조회 751
11년 전 조회 1,149
11년 전 조회 1,486
11년 전 조회 1,455
11년 전 조회 823
11년 전 조회 1,173
11년 전 조회 937
11년 전 조회 1,694
11년 전 조회 1,334
11년 전 조회 714
11년 전 조회 2,141
11년 전 조회 6,612
11년 전 조회 1,273
11년 전 조회 1,120
11년 전 조회 1,051
11년 전 조회 910
11년 전 조회 1,443
11년 전 조회 836
11년 전 조회 3,401
11년 전 조회 1,242
11년 전 조회 1,633
11년 전 조회 1,009
11년 전 조회 2,642
11년 전 조회 1,279
11년 전 조회 2,566
11년 전 조회 1,927
11년 전 조회 2,441
11년 전 조회 1,389
11년 전 조회 2,521
11년 전 조회 1,336
11년 전 조회 1,024
11년 전 조회 1,032
11년 전 조회 5,412
11년 전 조회 1,217
11년 전 조회 781
11년 전 조회 748
11년 전 조회 1,105
11년 전 조회 1,450
11년 전 조회 1,866
11년 전 조회 2,176
11년 전 조회 1,081
11년 전 조회 1,406
11년 전 조회 1,345
11년 전 조회 984
11년 전 조회 745
11년 전 조회 2,169
11년 전 조회 1,412
11년 전 조회 3,248
11년 전 조회 1,149
11년 전 조회 1,008
11년 전 조회 2,092
11년 전 조회 2,745
11년 전 조회 2,105
11년 전 조회 3,140
11년 전 조회 1,525
11년 전 조회 3,272
11년 전 조회 788
11년 전 조회 1,088
🐛 버그신고