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

· 11년 전 · 4464

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

강좌는 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년 전 조회 2,447
11년 전 조회 4,582
11년 전 조회 3,268
11년 전 조회 1,706
11년 전 조회 2,251
11년 전 조회 2,162
11년 전 조회 1,806
11년 전 조회 4,049
11년 전 조회 2,445
11년 전 조회 2,323
11년 전 조회 1,686
11년 전 조회 3,968
11년 전 조회 3,860
11년 전 조회 1,707
11년 전 조회 4,444
11년 전 조회 1,850
11년 전 조회 1,731
11년 전 조회 2,032
11년 전 조회 1,810
11년 전 조회 1,630
11년 전 조회 2,099
11년 전 조회 2,799
11년 전 조회 2,096
11년 전 조회 1,765
11년 전 조회 1,611
11년 전 조회 3,400
11년 전 조회 2,926
11년 전 조회 3,403
11년 전 조회 2,441
11년 전 조회 3,665
11년 전 조회 4,092
11년 전 조회 5,446
11년 전 조회 6,796
11년 전 조회 3,150
11년 전 조회 2,722
11년 전 조회 2,446
11년 전 조회 2,122
11년 전 조회 1,857
11년 전 조회 2,016
11년 전 조회 1,925
11년 전 조회 2,371
11년 전 조회 3,204
11년 전 조회 1,843
11년 전 조회 2,047
11년 전 조회 2,658
11년 전 조회 2,372
11년 전 조회 2,263
11년 전 조회 2,169
11년 전 조회 2,123
11년 전 조회 4,465
11년 전 조회 2,100
11년 전 조회 2,696
11년 전 조회 2,945
11년 전 조회 2,259
11년 전 조회 2,231
11년 전 조회 2,255
11년 전 조회 1,714
11년 전 조회 2,128
11년 전 조회 2,473
11년 전 조회 2,380
11년 전 조회 1,743
11년 전 조회 2,130
11년 전 조회 1,897
11년 전 조회 2,612
11년 전 조회 2,239
11년 전 조회 1,632
11년 전 조회 3,037
11년 전 조회 7,497
11년 전 조회 2,158
11년 전 조회 2,026
11년 전 조회 1,936
11년 전 조회 1,794
11년 전 조회 2,315
11년 전 조회 1,753
11년 전 조회 4,301
11년 전 조회 2,131
11년 전 조회 2,548
11년 전 조회 1,901
11년 전 조회 3,448
11년 전 조회 2,253
11년 전 조회 3,536
11년 전 조회 2,923
11년 전 조회 3,394
11년 전 조회 2,403
11년 전 조회 3,474
11년 전 조회 2,298
11년 전 조회 2,014
11년 전 조회 2,012
11년 전 조회 6,386
11년 전 조회 2,174
11년 전 조회 1,734
11년 전 조회 1,704
11년 전 조회 2,063
11년 전 조회 2,412
11년 전 조회 2,850
11년 전 조회 3,143
11년 전 조회 2,063
11년 전 조회 2,360
11년 전 조회 2,274
11년 전 조회 1,941