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

· 11년 전 · 3515

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

강좌는 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,472
11년 전 조회 3,613
11년 전 조회 2,329
11년 전 조회 735
11년 전 조회 1,287
11년 전 조회 1,192
11년 전 조회 838
11년 전 조회 2,979
11년 전 조회 1,457
11년 전 조회 1,314
11년 전 조회 688
11년 전 조회 3,014
11년 전 조회 2,927
11년 전 조회 743
11년 전 조회 3,451
11년 전 조회 863
11년 전 조회 762
11년 전 조회 1,054
11년 전 조회 867
11년 전 조회 669
11년 전 조회 1,103
11년 전 조회 1,797
11년 전 조회 1,058
11년 전 조회 816
11년 전 조회 660
11년 전 조회 2,432
11년 전 조회 1,982
11년 전 조회 2,499
11년 전 조회 1,437
11년 전 조회 2,717
11년 전 조회 3,122
11년 전 조회 4,468
11년 전 조회 5,825
11년 전 조회 2,160
11년 전 조회 1,722
11년 전 조회 1,473
11년 전 조회 1,142
11년 전 조회 881
11년 전 조회 1,052
11년 전 조회 954
11년 전 조회 1,429
11년 전 조회 2,234
11년 전 조회 907
11년 전 조회 1,081
11년 전 조회 1,746
11년 전 조회 1,419
11년 전 조회 1,319
11년 전 조회 1,234
11년 전 조회 1,162
11년 전 조회 3,516
11년 전 조회 1,152
11년 전 조회 1,769
11년 전 조회 2,017
11년 전 조회 1,336
11년 전 조회 1,321
11년 전 조회 1,321
11년 전 조회 773
11년 전 조회 1,180
11년 전 조회 1,513
11년 전 조회 1,473
11년 전 조회 846
11년 전 조회 1,197
11년 전 조회 959
11년 전 조회 1,721
11년 전 조회 1,354
11년 전 조회 737
11년 전 조회 2,165
11년 전 조회 6,635
11년 전 조회 1,293
11년 전 조회 1,137
11년 전 조회 1,069
11년 전 조회 934
11년 전 조회 1,463
11년 전 조회 862
11년 전 조회 3,429
11년 전 조회 1,266
11년 전 조회 1,659
11년 전 조회 1,033
11년 전 조회 2,669
11년 전 조회 1,303
11년 전 조회 2,591
11년 전 조회 1,950
11년 전 조회 2,469
11년 전 조회 1,413
11년 전 조회 2,544
11년 전 조회 1,359
11년 전 조회 1,047
11년 전 조회 1,056
11년 전 조회 5,432
11년 전 조회 1,241
11년 전 조회 803
11년 전 조회 768
11년 전 조회 1,123
11년 전 조회 1,470
11년 전 조회 1,890
11년 전 조회 2,198
11년 전 조회 1,103
11년 전 조회 1,428
11년 전 조회 1,367
11년 전 조회 1,007
🐛 버그신고