Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 730

•  TDictionary Custom Sort  6 735

•  Fast Watermark Sources  6 518

•  3D Designer  9 460

•  Sik Screen Capture  6 850

•  Patch Maker  7 298

•  Айболит (remote control)  7 241

•  ListBox Drag & Drop  6 101

•  Доска для игры Реверси  97 893

•  Графические эффекты  7 421

•  Рисование по маске  6 716

•  Перетаскивание изображений  5 568

•  Canvas Drawing  5 950

•  Рисование Луны  5 730

•  Поворот изображения  5 185

•  Рисование стержней  3 792

•  Paint on Shape  2 968

•  Генератор кроссвордов  3 911

•  Головоломка Paletto  3 107

•  Теорема Монжа об окружностях  3 926

•  Пазл Numbrix  2 582

•  Заборы и коммивояжеры  3 379

•  Игра HIP  2 318

•  Игра Go (Го)  2 217

•  Симулятор лифта  2 625

•  Программа укладки плитки  2 207

•  Генератор лабиринта  2 726

•  Проверка числового ввода  2 364

•  HEX View  2 704

•  Физический маятник  2 376

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Как нарисовать фрактал



procedure DrawMandelbrot(ACanvas: TCanvas; X, Y, au, bu: Double; X2, Y2:
  Integer);
var
  c1, c2, z1, z2, tmp: Double;
  i, j, Count: Integer;
begin
  c2 := bu;
  for i := 10 to X2 do
  begin
    c1 := au;
    for j := 0 to Y2 do
    begin
      z1 := 0;
      z2 := 0;
      Count := 0;
      {count is deep of iteration of the mandelbrot set
       if |z| >=2 then z is not a member of a mandelset}
      while (((z1 * z1 + z2 * z2 < 4) and (Count <= 90))) do
      begin
        tmp := z1;
        z1 := z1 * z1 - z2 * z2 + c1;
        z2 := 2 * tmp * z2 + c2;
        Inc(Count);
      end;
      //the color-palette depends on TColor(n*count mod t)
{$IFDEF LINUX}
      ACanvas.Pen.Color := (16 * Count mod 255);
      ACanvas.DrawPoint(j, i);
{$ELSE}
      ACanvas.Pixels[j, i] := (16 * Count mod 255);
{$ENDIF}
      c1 := c1 + X;
    end;
    c2 := c2 + Y;
  end;
end;

procedure TForm1.Button1Click(Sender: TObject);
var
  R: TRect;
  au, ao: Integer;
  dX, dY, bo, bu: Double;
begin
  // Initialize Mandelbrot
  R.Left := 0;
  R.Right := 200;
  R.Top := 0;
  R.Bottom := 205;
  ao := 1;
  au := -2;
  bo := 1.5;
  bu := -1.5;
  //direct scaling cause of speed
  dX := (ao - au) / (R.Right - R.Left);
  dY := (bo - bu) / (R.Bottom - R.Top);
  DrawMandelbrot(Self.Canvas, dX, dY, au, bu, R.Right, R.Bottom);
end;




Похожие по теме исходники

Фракталы




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте