C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[21115] Re:API함수중에 Ellipse가 어떻게 구현되어 있는지 아시는분 지도편달 바랍니다.
방태윤 [nabty] 1029 읽음    2002-08-30 11:37
그 유명한(?) Bresenham's 알고리즘입니다.

void put_pixel(int xx,int yy,int x,int y)
{
  Form1->Canvas->Pixels[xx+x][yy+y]=clBlack;
  Form1->Canvas->Pixels[xx-x][yy+y]=clBlack;
  Form1->Canvas->Pixels[xx-x][yy-y]=clBlack;
  Form1->Canvas->Pixels[xx+x][yy-y]=clBlack;
}
void put_line(int xx,int yy,int x,int y)
{
  Form1->Canvas->MoveTo(xx+x,yy+y);
  Form1->Canvas->LineTo(xx-x,yy+y);
  Form1->Canvas->MoveTo(xx+x,yy-y);
  Form1->Canvas->LineTo(xx-x,yy-y);
}

void ellipse(int x1,int y1,int x2,int y2,int mode) //mode..fill
{
  void(*put)(int,int,int,int);
  switch(mode){
    case 0:put=put_pixel;break;
    case 1:put=put_line;break;
  }
  int x,y,a2,b2,S,T;
  int a=(x2-x1)/2;
  int b=(y2-y1)/2;
  a2=a*a;
  b2=b*b;
  x=0;
  y=b;
  S=a2*(1-2*b)+2*b2;
  T=b2-2*a2*(2*b-1);
  put(x1+a,y1+b,x,y);
  do{
    if(S<0){
      S+=2*b2*(2*x+3);
      T+=4*b2*(x+1);
      x++;
    }else if(T<0){
      S+=2*b2*(2*x+3)-4*a2*(y-1);
      T+=4*b2*(x+1)-2*a2*(2*y-3);
      x++;
      y--;
    }else{
      S-=4*a2*(y-1);
      T-=2*a2*(2*y-3);
      y--;
    }
    put(x1+a,y1+b,x,y);
  }while(y>0);
}

김인구.구야 님이 쓰신 글 :
: 언뜻 생각같아선 Ellipse도 내부적으로
: SetPixel로 그렸을꺼 같은데 약간의 문제가 있을거 같기도 하구요...
: SetPixel이나 LineTo 둘중 하나로 구현 해볼려고 합니다.
: 도움 부탁드립니다.

+ -

관련 글 리스트
21096 API함수중에 Ellipse가 어떻게 구현되어 있는지 아시는분 지도편달 바랍니다. 김인구.구야 966 2002/08/29
21115     Re:API함수중에 Ellipse가 어떻게 구현되어 있는지 아시는분 지도편달 바랍니다. 방태윤 1029 2002/08/30
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.