Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Задачи _ вращающийся эллипс

Автор: e.s. 9.05.2007 17:42

необходимо нарисовать вращающийся эллипс,
система координат произвольная.
видимо лучший способ- это через параметрическую систему к., но я не могу понять одну вещь
у нас есть ур-е эллипса
x=a*cos(t);
y=b*sin(t);
а как сделать чтобы он вращался?
подобную программу выкладывал Volvo:
для краткоси буду считать что cos и sin ,берут угол от градусов

X0,Y0- координаты центра
angl- угол поворота фигуры


i:=0 to 359 do
begin
cX:=a*cos(i);
cY:=b*sin(i);
X:=X0+cX*cos(angl)-cY*sin(angl);
Y:=Y0+cX*sin(angl)+cY*cos(angl);
end;


так вот, можете мне объяснить откуда такие формулы для X и Y
почему
X:=X0+cX*cos(angl)-cY*sin(angl);
Y:=Y0+cX*sin(angl)+cY*cos(angl);

Автор: volvo 9.05.2007 18:08

Цитата
откуда такие формулы для X и Y
Тебе же надо точку, координаты которой ты получил в параметрической системе, отрисовать на экране (следовательно - в системе декартовой)? Вот и находим координаты X и Y точки в декартовой с/к, центр которой находится в точке экрана с координатами X0, Y0...

Автор: e.s. 9.05.2007 18:52

ну центр Х0 и У0 ето ясно, сХ и сУ тоже все ок, а почему для Х надо делать так:
сX*cos(angl)-cY*sin(angl) --это проекция так будет?

Автор: e.s. 9.05.2007 19:27

все понял как проецируется, BIG THNKS за программу

Автор: Вопрос 10.05.2007 3:38

Да, это правильные формулы для эллипсаса.
Но можно вопрос: как это работает на Паскале?

Автор: e.s. 14.05.2007 2:23

всмысле? что значит как?
обычная программа с graph'ом, там задается уравнение эллипса и по точкам его рисуешь.
у меня прга- фигуры(точки, окружности, прямоугольники, линии и эллипсы) движутся и вращаются с переменной скоростью. фигур 30 движутся без тормозов, когда >40 то начинает лагать...

Автор: Чужак 14.05.2007 2:31

Цитата(Вопрос @ 10.05.2007 0:38) *

Да, это правильные формулы для эллипсаса.
Но можно вопрос: как это работает на Паскале?

Вот-вращающийся эллипс-код.

program El;
uses crt,graph;
var gd, gm, X0, Y0: Integer;
X,Y,cX,cY,a,b,i,angl: Real;
begin
gd := detect;
initgraph(gd, gm, '');
X0:=320; Y0:=240; i:=0;
a:=50; b:=150; angl:=0;
repeat
while i<360 do
begin
i:=i+0.5;
cX:=a*cos(i);
cY:=b*sin(i);
X:=X0+cX*cos(angl)-cY*sin(angl);
Y:=Y0+cX*sin(angl)+cY*cos(angl);
PutPixel(Round(X), Round(Y), 15);
end;
Delay(200); i:=0;
ClearDevice; angl:=angl+0.01;
until keypressed;
closegraph;
end.


У меня нормально работает.