bresenham 알고리즘을 이용한 직선, 원, 타원 그리기

· 15년 전 · 3245

http://blog.hansune.com/95

여기 참고 해서 php용으로 만들었습니다.

그런데 결과물은 php내장함수와 거의 똑같네요.
좀 다를 줄 알았는데......

php 내장함수를 사용하지 않고 원이나 타원 직선을 그릴수 있는 정도에 만족해야 할듯합니다.

알고리즘에 대한 설명은 없습니다.

test.php
-----------------------------------------------------------------------------------------------------------------------------
<?php

//직선 그리기
function imageline_bresenham(& $im, $startX, $startY, $endX, $endY, $color){

  //기준점 계산, 작은 쪽이 출발점, 큰쪽이 도착점
  if($endX < $startX){

    $dx = $startX - $endX;
    $tmpX = $endX;
    $tmpgoX = $startX; 
  }
  else{

    $dx = $endX - $startX;
    $tmpX = $startX;
    $tmpgoX = $endX;
  }

  if($endY < $startY){

    $dy = $startY - $endY;
    $tmpY = $endY;
    $tmpgoY = $startY;
  }
  else{

    $dy = $endY - $startY;
    $tmpY = $startY;
    $tmpgoY = $endY;
  }


  /* 기울기에 따른 계산*/

  if($dx >= $dy) { //기울기가 1보다 작거나 같을때

    $d = $dy * 2 - $dx;        //d의 값을 초기화
    $incrE = $dy * 2;         // E로의 이동을 위해서 쓰이는 증가
    $incrNE = ($dy - $dx) * 2;   // NE로의 이동을 위해서 쓰이는 증가
    $start = $tmpX;
    $end = $tmpgoX;
  }
  else { //기울기가 1보다 클때

    $d = $dx * 2 - $dy;
    $incrE = $dx * 2;
    $incrNE = ($dx - $dy) * 2;
    $start = $tmpY;
    $end = $tmpgoY;
  }

  //x, y 좌표 초기화
  $x = $startX;
  $y = $startY;

  imagesetpixel($im, $x, $y, $color);//시작점 찍음

  while($start < $end) {

    if( $d <= 0) { /*D값이 0보다 작으면 E를 선택 하나의 축만 이동*/

      $d += $incrE;
      if($dx >= $dy) { // 기울기가 1보다 작을때 X좌표만 증가

        if($endX < $startX)
          $x--;
        else
          $x++;
      }
      else {         // 기울기가 1보다 클때 Y좌표만 증가

        if($endY < $startY)
          $y--;
        else
          $y++;
      }
    }
    else {     /*D값이 0보다 클때 NE를 선택 X,Y 를 같이 이동시킨다.*/

      $d += $incrNE;
      if($endX < $startX)
        $x--;
      else
        $x++;

      if($endY < $startY)
        $y--;
      else
        $y++;
    }

    imagesetpixel($im, $x, $y, $color);
    $start ++;
  }
}

 

function imagearc_bresenham(& $im, $centerX, $centerY, $width, $height, $color) {

  $w_r = ceil($width / 2);
  $h_r = ceil($height / 2);
  $x = 0;
  $y = $h_r;
  $w_r_square  = $w_r * $w_r;
  $h_r_square  = $h_r * $h_r;

  $d = (4 * $h_r_square  + $w_r_square  * (1 - (4 * $h_r))) / 4;

  imagesetpixel($im, $x + $centerX, $y + $centerY, $color);
  imagesetpixel($im, $centerX - $x, $y + $centerY, $color);
  imagesetpixel($im, $x + $centerX, $centerY - $y , $color);
  imagesetpixel($im, $centerX - $x, $centerY - $y, $color);

 

  // $x 독립변수 구간
  while($h_r_square  * $x < $w_r_square  * $y){

    ++$x;

    if($d < 0){

      $d += $h_r_square  * (2 * $x + 1);
    }
    else {

      --$y;

      $d += $h_r_square  * (2 * $x + 1) - (2 * $w_r_square  * $y);
    }

    imagesetpixel($im, $x + $centerX, $y + $centerY, $color);
    imagesetpixel($im, $centerX - $x, $y + $centerY, $color);
    imagesetpixel($im, $x + $centerX, $centerY - $y, $color);
    imagesetpixel($im, $centerX - $x, $centerY - $y, $color);
  }

 

  // $y 독립변수 구간
  $x = $w_r;

  $y = 0;

  $d = (4 * $w_r_square  + $h_r_square  * (1 - (4 * $w_r))) / 4;

  imagesetpixel($im, $x + $centerX, $y + $centerY, $color);
  imagesetpixel($im, $centerX - $x, $y + $centerY, $color);
  imagesetpixel($im, $x + $centerX, $centerY - $y, $color);
  imagesetpixel($im, $centerX - $x, $centerY - $y, $color);

 

  while($h_r_square  * $x > $w_r_square  * $y){

    ++$y;

    if($d < 0){

      $d += $w_r_square  * (2 * $y + 1);

    }
    else {

      --$x;

      $d += $w_r_square  * (2 * $y + 1) - (2 * $h_r_square  * $x);
    }

 

    imagesetpixel($im, $x + $centerX, $y + $centerY, $color);
    imagesetpixel($im, $centerX - $x, $y + $centerY, $color);
    imagesetpixel($im, $x + $centerX, $centerY - $y, $color);
    imagesetpixel($im, $centerX - $x, $centerY - $y, $color);
  }
}

 

$w = 400;
$h = 800;

$im = imagecreatetruecolor($w, $h);
$red = imagecolorallocate($im, 255, 0, 0);

 


imageline_bresenham($im, 200, 200, 100, 0, $red);
imageline_bresenham($im, 200, 200, 400, 100, $red);
imageline_bresenham($im, 200, 200, 400, 200, $red);
imageline_bresenham($im, 200, 200, 400, 300, $red);
imagearc_bresenham($im, 200, 200, 180, 360, $red);
imagearc_bresenham($im, 100, 200, 200, 200, $red);

imageline($im, 200, 600, 100, 400, $red);
imageline($im, 200, 600, 400, 500, $red);
imageline($im, 200, 600, 400, 600, $red);
imageline($im, 200, 600, 400, 700, $red);
imagearc($im, 200, 600, 180, 360, 0, 360, $red);
imagearc($im, 100, 600, 200, 200, 0, 360, $red);

header('Content-Type: image/png');
imagepng($im);

?>
샘플 : http://apmusers.com/php_arc.php

[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
15년 전 조회 1,782
15년 전 조회 1,318
15년 전 조회 3,521
15년 전 조회 1,889
15년 전 조회 1,913
15년 전 조회 1,924
15년 전 조회 1,977
15년 전 조회 1,576
15년 전 조회 2,333
15년 전 조회 1,851
15년 전 조회 1,475
15년 전 조회 3,340
15년 전 조회 1,703
15년 전 조회 1,913
15년 전 조회 1,664
15년 전 조회 2,540
15년 전 조회 2,565
15년 전 조회 2,197
15년 전 조회 1,570
15년 전 조회 1,830
15년 전 조회 1,479
15년 전 조회 1,446
15년 전 조회 1,705
15년 전 조회 3,066
15년 전 조회 3,097
15년 전 조회 2,066
15년 전 조회 1,566
15년 전 조회 1,748
15년 전 조회 1,767
15년 전 조회 1,643
15년 전 조회 1,540
15년 전 조회 1,453
15년 전 조회 1,814
15년 전 조회 1,772
15년 전 조회 1,548
15년 전 조회 1,498
15년 전 조회 1,669
15년 전 조회 2,146
15년 전 조회 1,658
15년 전 조회 1,987
15년 전 조회 1,814
15년 전 조회 2,534
15년 전 조회 3,596
15년 전 조회 2,931
15년 전 조회 1,488
15년 전 조회 2,489
15년 전 조회 2,678
15년 전 조회 1,996
15년 전 조회 1,955
15년 전 조회 3,246
15년 전 조회 3,124
15년 전 조회 6,131
15년 전 조회 2,074
15년 전 조회 4,852
15년 전 조회 1,964
15년 전 조회 2,248
15년 전 조회 2,225
15년 전 조회 2,222
15년 전 조회 1,706
15년 전 조회 1,956
15년 전 조회 2,081
15년 전 조회 2,031
15년 전 조회 2,734
15년 전 조회 1,870
15년 전 조회 1,985
15년 전 조회 1,475
15년 전 조회 1,586
15년 전 조회 1,585
15년 전 조회 1,507
15년 전 조회 1,475
15년 전 조회 1,516
15년 전 조회 1,663
15년 전 조회 1,683
15년 전 조회 3,201
15년 전 조회 1,526
15년 전 조회 2,180
15년 전 조회 2,041
15년 전 조회 2,193
15년 전 조회 1,895
15년 전 조회 2,401
15년 전 조회 1,205
15년 전 조회 1,685
15년 전 조회 1,660
15년 전 조회 3,456
15년 전 조회 3,791
15년 전 조회 2,490
15년 전 조회 1,938
15년 전 조회 2,572
15년 전 조회 2,044
15년 전 조회 1,671
15년 전 조회 4,361
15년 전 조회 2,005
15년 전 조회 2,101
15년 전 조회 3,364
15년 전 조회 2,064
15년 전 조회 4,752
15년 전 조회 2,949
15년 전 조회 3,748
15년 전 조회 2,354
15년 전 조회 2,599