::: 델파이 Tip&Trick :::

델파이 Tip&Trick 성격에 맞지 않는 광고,비방,질문의 글은 즉시 삭제하며
내용을 복사하여 사용할 경우 반드시 이곳(http://www.howto.pe.kr)을 출처로 명시하여 주세요


Category

  김영대(2003-03-07 20:57:41, Hit : 4818, Vote : 1145
 베쥬(Bezier) 곡선 그리기2

// Win95/NT4.0 부터 베쥬(Bezier) 곡선을 그릴 수 있는 API가 추가되었습니다
// 그러나, Delphi 의 TCanvas 에서는 지원되지 않습니다
// 물론 API 를 직접 호출하면 사용할 수 있습니다
// 아래 예제는 PolyBezier() API 를 사용해 타원을 그리는 예제입니다
// http://home.t-online.de/home/Robert.Rossmair/ellipse.htm 를 참고해 보세요

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  ExtCtrls;

type
  TForm1 = class(TForm)
    Image1: TImage;
    procedure FormCreate(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation
{$R *.DFM}

{
  Ellipse approximation using N Bezier curves.
  Relative approximation error <= (1-cos(Pi/N))3/(54*(1+cos(Pi/N)))
     "           "         "   < 4.25E-6        for N = 8
  X, Y: Center coordinates
  A, B: Half axis lengths
  Angle: Angle in radians
}
procedure DrawEllipse(DC: hDC; X, Y, A, B, Angle: Double);
type
  TFloatPoint = record
    X, Y: Double;
  end;
const
  N = 8;
  Alpha = Pi/N;
  Beta = 0.26521648984; // = 4*(1-cos(Alpha))/(3*sin(Alpha))
var
  P: array[0..N*3] of TFloatPoint;
  Q: array[0..N*3] of TPoint; // N Bezier curves
  SinA, CosA: Double;
  Temp: Double;
  I, J, K: Integer;
begin
  for I := 0 to N-1 do
  begin
    Temp := I * (2*Alpha);
    CosA := cos(Temp);
    SinA := sin(Temp);
    K := I*3;
    if K = 0
      then J := N*3-1
      else J := K-1;
    P[K].X := A * CosA;
    P[K].Y := B * SinA;
    SinA := Beta * A * SinA;
    CosA := Beta * B * CosA;
    P[J].X := P[K].X + SinA;
    P[J].Y := P[K].Y - CosA;
    P[K+1].X := P[K].X - SinA;
    P[K+1].Y := P[K].Y + CosA;
  end;
  P[N*3] := P[0];
  CosA := cos(Angle);
  SinA := sin(Angle);
  for i := Low(P) to High(P) do // Rotate and translate
  begin
    Q[I].X := Round(P[I].X*CosA - P[I].Y*SinA +X);
    Q[I].Y := Round(P[I].X*SinA + P[I].Y*CosA +Y);
  end;

  // Draw ellipse and fill it using the current pen and brush
  BeginPath(DC);
  PolyBezier(DC, Q, High(Q)+1);
  EndPath(DC);
  StrokeAndFillPath(DC);
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
  DrawEllipse(Image1.Canvas.Handle,
              Image1.Width div 2,
              Image1.Height div 2,
              40,
              80,
              20*(Pi/180)); // Angle 20
end;

end.





411   [일반/컴포넌트] 윈도우즈 메모장의 편집내용을 가져오기  김영대 2003/03/07 3986 1092
410   [윈도우즈 API] 윈도우즈"시작" 버튼 Disable/Enable  김영대 2003/03/07 4534 1210
409   [윈도우즈 API] TaskBar의 다양한 기능제어  김영대 2003/03/07 5217 1415
408   [시스템] 윈도우즈 전체의 키보드 입력 금지  김영대 2003/03/07 4564 1224
407   [데이터베이스] SQL실행시의 모래시계를 표시하지 않는 방법  김영대 2003/03/07 4646 1154
406   [윈도우즈 API] 커서(케럿)의 깜박임 속도를 변경하기  김영대 2003/03/07 4804 1269
405   [데이터베이스] 데이타베이스 로그인(login) 화면 띄우기  김영대 2003/03/07 4096 1030
404   [일반/컴포넌트] 간단히 화면 하드카피(snapshot) 하기  김영대 2003/03/07 4775 1149
403   [윈도우즈 API] 스크린 세이버의 기동시간 바꾸기  김영대 2003/03/07 4313 1309
402   [시스템] 폴더의 변경여부를 감시하기  김영대 2003/03/07 5731 1285
401   [일반/컴포넌트] 전각문자인지 반각문자인지 검사하기  김영대 2003/03/07 6691 1251
400   [일반/컴포넌트] 문자열의 바이트수가 아닌 실제 글자수 구하기  김영대 2003/03/07 4992 1140
399   [일반/컴포넌트] 임시파일명 자동으로 생성하기  김영대 2003/03/07 5209 1664
398   [데이터베이스] DBGrid의 수직이동 막대 감추기  김영대 2003/03/07 4789 1235
397   [시스템] 프린터 리스트를 구하여 기본 프린터 변경하기  김영대 2003/03/07 13163 1289
396   [일반/컴포넌트] 타이틀바 클릭시 사용자 팝업메뉴 보이기  김영대 2003/03/07 4879 1178
395   [윈도우즈 API] 폼을 최하위(?)로 설정하기  김영대 2003/03/07 4807 1273
394   [시스템] 시스템에 등록된 한글폰트의 리스트  김영대 2003/03/07 5236 1547
393   [일반/컴포넌트] StringGrid 의 BeginUpdate/EndUpdate ?  김영대 2003/03/07 5438 1170
392   [윈도우즈 API] 바탕화면 아이콘의 글자색 바꾸기  김영대 2003/03/07 5137 1298
391   [윈도우즈 API] 스크린 세이버 비밀번호 알아내기  김영대 2003/03/07 4879 1203
390   [일반/컴포넌트] 파일에서 특정 Byte 모두 찾기  김영대 2003/03/07 4504 1156
389   [네트웍/인터넷] Network Adaptor 가 여러개인 경우의 IP 구하기  김영대 2003/03/07 6238 1568
388   [시스템] 프린트 스풀러 제어방법  김영대 2003/03/07 6559 1876
387   [윈도우즈 API] 바탕화면 아이콘의 글자색 바꾸기2  김영대 2003/03/07 5177 1467
386   [일반/컴포넌트] 베쥬(Bezier) 곡선 그리기  김영대 2003/03/07 4800 1439
385   [윈도우즈 API] 정의되지 않은 Alt+키 입력시 Beep음 제거  김영대 2003/03/07 4348 1221
384   [일반/컴포넌트] 부활절 달걀(easter egg) 문자열 입력받기  김영대 2003/03/07 4773 1153
383   [시스템] Delphi VCL 사용안하고 프로그램 만들기  김영대 2003/03/07 5246 1313
382   [윈도우즈 API] CTRL+ALT+DEL 에 나타나지 않는 프로그램  김영대 2003/03/07 5144 1292
  [일반/컴포넌트] 베쥬(Bezier) 곡선 그리기2  김영대 2003/03/07 4818 1145
380   [시스템] 키보드 자동반복지연 읽기/설정  김영대 2003/03/07 4657 1189
379   [시스템] 키보드 자동반복속도 읽기/설정  김영대 2003/03/07 5442 1491
378   [시스템] 윈도우즈 캡션의 높이 읽기/설정  김영대 2003/03/07 4440 1218
377   [일반/컴포넌트] ListView 의 column header 오른쪽에 이미지 넣기  김영대 2003/03/07 4954 1209
376   [일반/컴포넌트] Delphi 4 Secret Registry Settings  김영대 2003/03/07 6405 1580
375   [데이터베이스] Record Lock 검사  김영대 2003/03/07 4287 1123
374   [윈도우즈 API] 즐겨찾기 폴더의 파일에서 URL 뽑아내기  김영대 2003/03/07 5264 1293
373   [시스템] CD-ROM의 변경여부를 감시하기  김영대 2003/03/07 4988 1307
372   [시스템] Locking/ Unlocking floppy driver or CD  김영대 2003/03/07 4273 1220

[이전 10개] [1]..[11][12][13][14] 15 [16][17][18][19][20]..[25] [다음 10개]
 

Copyright 1999-2021 Zeroboard / skin by zero