Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
25th
Май
График на форме
Posted by obzor under Delphi
Как построить график бесконечности на форме?
ссылка на формулу
Имеется формула, но я не могу её преобразовать, что бы она рисовалась у меня на форме.
Лемниската Бернулли Delphi…
procedure TForm1.FormResize(Sender: TObject);
begin
Self.Repaint;
end;
procedure TForm1.FormPaint(Sender: TObject);
var
xc, yc, x1, y1, y2, m, xd, yd: integer;
x, y, c, MyStep: Extended;
ARect: TRect;
MyColor: TColor;
begin
ARect := Self.Canvas.ClipRect;
Self.Canvas.Brush.Color := clWhite;
Self.Canvas.FillRect(ARect);
Self.Canvas.Pen.Color := 11829830;
MyColor := clGreen;
xc := ARect.Right div 2;
yc := Arect.Bottom div 2;
Self.Canvas.MoveTo(0,yc); Self.Canvas.LineTo(ARect.Right, yc); Self.Canvas.LineTo(ARect.Right-8, yc-4);
Self.Canvas.MoveTo(ARect.Right,yc); Self.Canvas.LineTo(ARect.Right-8, yc+4);
Self.Canvas.MoveTo(xc,ARect.Bottom); Self.Canvas.LineTo(xc,Arect.Top); Self.Canvas.LineTo(xc-4,ARect.Top+8);
Self.Canvas.MoveTo(xc,ARect.Top); Self.Canvas.LineTo(xc+4,ARect.Top+8);
c := 1; m := 100;
x := -c * sqrt(2);
MyStep := 0.0001; // Чем меньше это число, тем лучше качество
xd := 0; yd := 0; // Смещение центра у графика. Можно поменять для наглядности xd := 15; yd := -20;
while x <= c*sqrt(2) do
begin
if sqrt(c*c*c*c+4*x*x*c*c)-x*x-c*c > MyStep then
begin
y := sqrt(sqrt(c*c*c*c+4*x*x*c*c)-x*x-c*c);
x1:= xc + round(x*m);
y1:= yc - round(y*m);
y2:= yc + round(y*m);
Self.Canvas.Pixels[x1+xd,y1+yd] := MyColor;
Self.Canvas.Pixels[x1+xd,y2+yd] := MyColor;
end;
x := x + MyStep;
end;
end;
Случайные статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)