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

설명.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,405
11년 전 조회 825
11년 전 조회 721
11년 전 조회 1,011
11년 전 조회 821
11년 전 조회 631
11년 전 조회 1,055
11년 전 조회 1,772
11년 전 조회 1,010
11년 전 조회 774
11년 전 조회 619
11년 전 조회 2,383
11년 전 조회 1,931
11년 전 조회 2,468
11년 전 조회 1,398
11년 전 조회 2,675
11년 전 조회 3,095
11년 전 조회 4,427
11년 전 조회 5,775
11년 전 조회 2,117
11년 전 조회 1,693
11년 전 조회 1,425
11년 전 조회 1,092
11년 전 조회 837
11년 전 조회 1,017
11년 전 조회 906
11년 전 조회 1,388
11년 전 조회 2,189
11년 전 조회 868
11년 전 조회 1,043
11년 전 조회 1,703
11년 전 조회 1,395
11년 전 조회 1,278
11년 전 조회 1,203
11년 전 조회 1,122
11년 전 조회 3,470
11년 전 조회 1,117
11년 전 조회 1,719
11년 전 조회 1,986
11년 전 조회 1,294
11년 전 조회 1,282
11년 전 조회 1,276
11년 전 조회 738
11년 전 조회 1,136
11년 전 조회 1,479
11년 전 조회 1,440
11년 전 조회 814
11년 전 조회 1,157
11년 전 조회 925
11년 전 조회 1,682
11년 전 조회 1,321
11년 전 조회 698
11년 전 조회 2,133
11년 전 조회 6,600
11년 전 조회 1,264
11년 전 조회 1,109
11년 전 조회 1,042
11년 전 조회 896
11년 전 조회 1,429
11년 전 조회 827
11년 전 조회 3,385
11년 전 조회 1,232
11년 전 조회 1,624
11년 전 조회 998
11년 전 조회 2,629
11년 전 조회 1,267
11년 전 조회 2,553
11년 전 조회 1,920
11년 전 조회 2,429
11년 전 조회 1,375
11년 전 조회 2,509
11년 전 조회 1,319
11년 전 조회 1,012
11년 전 조회 1,024
11년 전 조회 5,405
11년 전 조회 1,201
11년 전 조회 764
11년 전 조회 740
11년 전 조회 1,089
11년 전 조회 1,436
11년 전 조회 1,854
11년 전 조회 2,161
11년 전 조회 1,069
11년 전 조회 1,389
11년 전 조회 1,334
11년 전 조회 976
11년 전 조회 732
11년 전 조회 2,160
11년 전 조회 1,405
11년 전 조회 3,234
11년 전 조회 1,139
11년 전 조회 996
11년 전 조회 2,078
11년 전 조회 2,732
11년 전 조회 2,094
11년 전 조회 3,126
11년 전 조회 1,512
11년 전 조회 3,261
11년 전 조회 775
11년 전 조회 1,074
🐛 버그신고