쉬어가는 페이지 (기울기에 따른 위치 구해보기)

· 11년 전 · 3491

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

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

이미지관련 > 쉬어가는 페이지 (기울기에 따른 위치 구해보기)   

 

이전에 세번째 내용에서 imageftbbox 함수는 기울기가 있을때 정확한 결과를 주지 않는다고 했습니다.

 

http://apmusers.com/lecture/study3.php

 

그래서 이번 내용에서는

앞으로의 내용에는 포함하지 않을 예정이지만

어떻게 하면 기울기에 따른 좌표값을 정확히 구해 낼수 있을 까 하는 부분에 대해 다루어 보았습니다.

 

내용중에는 삼각함수가 포함되어있습니다.

이전 강좌처럼 x_gap, y_gap 값은 구하지는 않았습니다. 

 

예제7 > study7.php

 

<?php

@error_reporting( E_ALL );
header("Content-Type: text/html; charset=UTF-8");



$font_file = './Daum_Regular.ttf';
$font_size = 40;
$text = 'FaggM';
$angles = Array(0, 45, 90, 135, 180, 225, 270, 315, -45, -90, -135, -180, -225, -270, -315);

?>
폰트파일 : <?php echo $font_file; ?><br>

폰트크기 : <?php echo $font_size; ?> px<br>

문자열 : <?php echo nl2br($text); ?><br>
<br>

<?php

//그래프를 그리기 위한 용도
$graph_size = 200;
$graph_font_size = 10;



//기울기가 0일때
$array = imageftbbox ( $font_size, 0, $font_file, $text );



// x 좌표의 최소값을 찾아서 0 을 기준으로 이동
$x_min = min($array[0], $array[2], $array[4], $array[6]) * -1;
$array[0] = $array[0] + $x_min;
$array[2] = $array[2] + $x_min;
$array[4] = $array[4] + $x_min;
$array[6] = $array[6] + $x_min;

// y 좌표의 최소값을 찾아서 0 을 기준으로 이동
$y_min = min($array[1], $array[3], $array[5], $array[7]) * -1;
$array[1] = $array[1] + $y_min;
$array[3] = $array[3] + $y_min;
$array[5] = $array[5] + $y_min;
$array[7] = $array[7] + $y_min;

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




foreach($angles as $k => $angle){

    //그래프용
    $im = imagecreatetruecolor($graph_size * 2, $graph_size * 2);
    $red = imagecolorallocate($im, 0xFF, 0x00, 0x00);
    $blue = imagecolorallocate($im, 0x00, 0x80, 0xFF);
    $white = imagecolorallocate($im, 0xFF, 0xFF, 0xFF);
    $black = imagecolorallocate($im, 0x00, 0x00, 0x00);

    imagefilledrectangle($im, 0, 0, ($graph_size * 2) - 1, ($graph_size * 2) - 1, $white);
    imageline ( $im , $graph_size , 0 , $graph_size, ($graph_size * 2) - 1 , $blue);//세로선
    imageline ( $im , 0 , $graph_size , ($graph_size * 2) - 1, $graph_size , $blue);//가로선

    imagefttext($im, $graph_font_size, 0, 185, 220, $black, $font_file, '0');
    imagefttext($im, $graph_font_size, 0, 135, 20, $black, $font_file, 'Y축 음수');
    imagefttext($im, $graph_font_size, 0, 135, 390, $black, $font_file, 'Y축 양수');
    imagefttext($im, $graph_font_size, 0, 10, 220, $black, $font_file, 'X축 음수');
    imagefttext($im, $graph_font_size, 0, 340, 220, $black, $font_file, 'X축 양수');



    echo "<strong>기울기가 {$angle}도 일때</strong><br><br>" . PHP_EOL;

    if ($angle == 0) {

        $array2 = $array;
    }
    else {

        $angle2 = $angle * -1;

        if ($angle2 < 0)
            $angle3 = $angle2 -90;
        else
            $angle3 = $angle2 + 90;

        $rad2 = deg2rad($angle2);
        $x2 = round(cos($rad2) * $width);
        $y2 = round(sin($rad2) * $width);

        $rad3 = deg2rad($angle3);
        $x3 = round(cos($rad3) * $height) + $x2;
        $y3 = round(sin($rad3) * $height) + $y2;

        $x4 = round(cos($rad3) * $height);
        $y4 = round(sin($rad3) * $height);

        $array2 = Array();
        $array2[0] = 0;
        $array2[1] = 0;
        $array2[2] = $x2;
        $array2[3] = $y2;
        $array2[4] = $x3;
        $array2[5] = $y3;
        $array2[6] = $x4;
        $array2[7] = $y4;

        $x_min2 = min($array2[0], $array2[2], $array2[4], $array2[6]) * -1;
        $y_min2 = min($array2[1], $array2[3], $array2[5], $array2[7]) * -1;

        $array2[0] = $array2[0] + $x_min2;
        $array2[1] = $array2[1] + $y_min2;
        $array2[2] = $array2[2] + $x_min2;
        $array2[3] = $array2[3] + $y_min2;
        $array2[4] = $array2[4] + $x_min2;
        $array2[5] = $array2[5] + $y_min2;
        $array2[6] = $array2[6] + $x_min2;
        $array2[7] = $array2[7] + $y_min2;
    }

    imageline ( $im , $array2[0] + $graph_size , $array2[1] + $graph_size , $array2[2] + $graph_size, $array2[3] + $graph_size , $blue);
    imageline ( $im , $array2[2] + $graph_size , $array2[3] + $graph_size , $array2[4] + $graph_size, $array2[5] + $graph_size , $blue);
    imageline ( $im , $array2[4] + $graph_size , $array2[5] + $graph_size , $array2[6] + $graph_size, $array2[7] + $graph_size , $blue);
    imageline ( $im , $array2[6] + $graph_size , $array2[7] + $graph_size , $array2[0] + $graph_size, $array2[1] + $graph_size , $blue);

    if ($angle >= 0)
        imagefttext($im, $font_size, $angle, $array2[0] + $graph_size, $array2[1] + $graph_size, $red, $font_file, $text);
    else
        imagefttext($im, $font_size, $angle, $array2[6] + $graph_size, $array2[7] + $graph_size, $red, $font_file, $text);

    imagepng($im, 'temp/study7_' . ($k + 1) . '.png');
    imagedestroy($im);

    ?>

    <br>
    <img src='temp/study7_<?php echo ($k + 1); ?>.png?<?php echo time(); ?>'>
    <br><br>

    <?php
}

?>

 

$angle2 = $angle * -1;

 

지정된 기울기에 곱하기 -1 을 하는 이유는
imageftbbox
에서 사용되는 기울기는 실제 기울기의 반대이기 때문에 그렇습니다.           


if ($angle2 < 0)
    $angle3 = $angle2 -90;
else
    $angle3 = $angle2 + 90;
 

 

$angle3 은 긴변이 아닌 짧은 변쪽의 좌표를 구하기 위해 사용될 기울기 이며,

직각이므로 90 을 더하거나 빼주는 것입니다.


$rad2 = deg2rad($angle2);
$x2 = round(cos($rad2) * $width);
$y2 = round(sin($rad2) * $width);

$rad3 = deg2rad($angle3);
$x3 = round(cos($rad3) * $height) + $x2;
$y3 = round(sin($rad3) * $height) + $y2;

$x4 = round(cos($rad3) * $height);
$y4 = round(sin($rad3) * $height); 


cos 이나 sin 같은 삼각함수용 함수는 기울기를 각도 그대로 받지 않고

라디안으로 변환된 값을 받습니다.

따라서 deg2rad 으로 기울기 를 라디안으로 변환다음 각 삼각함수에 대입하여

좌표들을 구합니다.


기준이 되는 점을 0, 0 으로 맞추어 두었기 때문에

너비와 높이는 변형없이 곱해주기만 하면 됩니다.


$array2 = Array();
$array2[0] = 0;
$array2[1] = 0;
$array2[2] = $x2;
$array2[3] = $y2;
$array2[4] = $x3;
$array2[5] = $y3;
$array2[6] = $x4;
$array2[7] = $y4;

$x_min2 = min($array2[0], $array2[2], $array2[4], $array2[6]) * -1;
$y_min2 = min($array2[1], $array2[3], $array2[5], $array2[7]) * -1;

$array2[0] = $array2[0] + $x_min2;
$array2[1] = $array2[1] + $y_min2;
$array2[2] = $array2[2] + $x_min2;
$array2[3] = $array2[3] + $y_min2;
$array2[4] = $array2[4] + $x_min2;
$array2[5] = $array2[5] + $y_min2;
$array2[6] = $array2[6] + $x_min2;
$array2[7] = $array2[7] + $y_min2; 


이부분은 새로 구해진 기울기가 적용된 좌표가

음수 영역을 가질수 있기 때문에 다시 양수로 미는 부분입니다.


if ($angle >= 0)
    imagefttext($im, $font_size, $angle, $array2[0] + $graph_size, $array2[1] + $graph_size, $red, $font_file, $text);
else
    imagefttext($im, $font_size, $angle, $array2[6] + $graph_size, $array2[7] + $graph_size, $red, $font_file, $text);


원래 기울기가 음수 이면 기준점 꼭지점의 상단 점의 좌표를 기준점으로 삼습니다.

이유는 기울기가 음수 이면 결국 사각형이 뒤집힌거나 같기 때문입니다.



이번 내용은 그냥 심심풀이 쉬어가는 개념으로 이해해 주시면 될것 같습니다.


 

 

위 예제를 실행 하여 보면

각도에 따라 문자열이 위치해야 할 박스가 정확하게 그려져 있음을 볼수 있습니다.

 

예제를 실행할 때에는 temp 디렉토리를 생성하고 퍼미션을 777 로 주어야 합니다.   

 

 

 

 

 

첨부파일

Daum_Regular.ttf (1.2 MB) 15회 2014-07-29 16:14
|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 1,440
11년 전 조회 3,579
11년 전 조회 2,305
11년 전 조회 709
11년 전 조회 1,269
11년 전 조회 1,168
11년 전 조회 815
11년 전 조회 2,945
11년 전 조회 1,427
11년 전 조회 1,288
11년 전 조회 669
11년 전 조회 2,990
11년 전 조회 2,897
11년 전 조회 721
11년 전 조회 3,425
11년 전 조회 836
11년 전 조회 740
11년 전 조회 1,030
11년 전 조회 837
11년 전 조회 647
11년 전 조회 1,074
11년 전 조회 1,782
11년 전 조회 1,028
11년 전 조회 796
11년 전 조회 636
11년 전 조회 2,400
11년 전 조회 1,949
11년 전 조회 2,481
11년 전 조회 1,414
11년 전 조회 2,691
11년 전 조회 3,103
11년 전 조회 4,444
11년 전 조회 5,796
11년 전 조회 2,138
11년 전 조회 1,706
11년 전 조회 1,447
11년 전 조회 1,111
11년 전 조회 853
11년 전 조회 1,031
11년 전 조회 924
11년 전 조회 1,407
11년 전 조회 2,207
11년 전 조회 883
11년 전 조회 1,065
11년 전 조회 1,723
11년 전 조회 1,403
11년 전 조회 1,301
11년 전 조회 1,220
11년 전 조회 1,141
11년 전 조회 3,492
11년 전 조회 1,131
11년 전 조회 1,743
11년 전 조회 1,997
11년 전 조회 1,310
11년 전 조회 1,303
11년 전 조회 1,298
11년 전 조회 755
11년 전 조회 1,154
11년 전 조회 1,491
11년 전 조회 1,459
11년 전 조회 827
11년 전 조회 1,179
11년 전 조회 945
11년 전 조회 1,698
11년 전 조회 1,340
11년 전 조회 716
11년 전 조회 2,144
11년 전 조회 6,618
11년 전 조회 1,279
11년 전 조회 1,124
11년 전 조회 1,054
11년 전 조회 916
11년 전 조회 1,451
11년 전 조회 843
11년 전 조회 3,406
11년 전 조회 1,248
11년 전 조회 1,641
11년 전 조회 1,009
11년 전 조회 2,653
11년 전 조회 1,285
11년 전 조회 2,574
11년 전 조회 1,937
11년 전 조회 2,449
11년 전 조회 1,396
11년 전 조회 2,528
11년 전 조회 1,343
11년 전 조회 1,031
11년 전 조회 1,036
11년 전 조회 5,416
11년 전 조회 1,221
11년 전 조회 784
11년 전 조회 751
11년 전 조회 1,110
11년 전 조회 1,452
11년 전 조회 1,869
11년 전 조회 2,180
11년 전 조회 1,083
11년 전 조회 1,407
11년 전 조회 1,350
11년 전 조회 991
🐛 버그신고