Форум программистов, компьютерный форум, киберфорум
Наши страницы
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
MaxiMax
0 / 0 / 0
Регистрация: 24.06.2009
Сообщений: 68
1

Изменение программы.

24.06.2009, 01:11. Просмотров 1068. Ответов 3
Метки нет (Все метки)

У меня есть программа которая рисует гиперболы и вычисляет для них фокусы, эксцентриситет, директрисы. Так же рисует асимптоты, полуоси и дериктрисы, но мне нужно её переделать чтобы, координатные оси были x [-3,9], y [-3,9], она рисовала элипс и выполняла те же функции для него, в принципе это не сложно... для человека знающего делфи, я так думаю
Помогите пожалуйста, сроки поджимают, незнаю что делать уже =(

вот код программы:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
unit Unit1;
 
interface
 
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, Math, StdCtrls, ExtCtrls, Menus, jpeg;
 
type
TForm1 = class(TForm)
PaintBox1: TPaintBox;
Edit1: TEdit;
Edit2: TEdit;
Label1: TLabel;
Label4: TLabel;
GroupBox1: TGroupBox;
Button1: TButton;
Button2: TButton;
GroupBox2: TGroupBox;
Label2: TLabel;
Edit3: TEdit;
Label3: TLabel;
Label5: TLabel;
CheckBox1: TCheckBox;
Edit4: TEdit;
Label6: TLabel;
Label7: TLabel;
CheckBox2: TCheckBox;
CheckBox3: TCheckBox;
Label8: TLabel;
Edit5: TEdit;
Label9: TLabel;
GroupBox3: TGroupBox;
CheckBox4: TCheckBox;
CheckBox5: TCheckBox;
MainMenu1: TMainMenu;
N1: TMenuItem;
N2: TMenuItem;
N3: TMenuItem;
N4: TMenuItem;
N5: TMenuItem;
N6: TMenuItem;
N7: TMenuItem;
Image1: TImage;
N8: TMenuItem;
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure FormCreate(Sender: TObject);
procedure CheckBox1Click(Sender: TObject);
procedure CheckBox2Click(Sender: TObject);
procedure CheckBox3Click(Sender: TObject);
procedure CheckBox4Click(Sender: TObject);
procedure CheckBox5Click(Sender: TObject);
procedure N3Click(Sender: TObject);
procedure N4Click(Sender: TObject);
procedure N5Click(Sender: TObject);
procedure N7Click(Sender: TObject);
procedure N8Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
 
var
Form1: TForm1;
A,B,R,XA,YA,L,E,D:real;
x0,y0:integer;
xe,ye:integer;
x,y:real;
dx,dy:real;
Mx,My:real;
xmin,xmax,ymin,ymax:integer;
a1,a2,b1,b2:integer;
n:integer;
x1,y1,y2,y3,c:real;
implementation
 
uses Unit2, Unit3, Unit4, Unit7;
 
{$R *.dfm}
 
 
 
procedure TForm1.Button1Click(Sender: TObject);
begin
A:=StrToFloat(Edit1.Text);
B:=StrToFloat(Edit2.Text);
n:=1;
PaintBox1.Repaint;
end;
 
procedure TForm1.Button2Click(Sender: TObject);
begin
n:=0;
PaintBox1.Repaint;
end;
 
procedure TForm1.FormCreate(Sender: TObject);
begin
xmin:=-20; xmax:=4; ymin:=-20; ymax:=4;
a1:=0; a2:=580;
b1:=0; b2:=580;
dx:=2; dy:=2;
with PaintBox1.Canvas do
begin
Brush.Color:=clWhite;
Rectangle(-1,-1,PaintBox1.Width+1,PaintBox1.Height+1);
Pen.width:=1;
Pen.Color:=clBlack;
Mx:=round((a2-a1)/(xmax-xmin));
My:=round((b2-b1)/(ymax-ymin));
x0:=a1-round(mx)*xmin;
y0:=b1+round(my)*ymax;
TextOut(a2-10,y0-15,'X');
TextOut(x0+5,b1+5,'Y');
If checkbox5.checked=true then
begin
TextOut(x0+5,y0-18,'0');
end;
Pen.width:=1;
Pen.Style:=psDot;
Pen.Color:=clBtnShadow;
x:=xmin;
repeat
Xe:=round(mx*(x-xmin)+a1);
If checkbox4.checked=true then
begin
MoveTo(xe,b1);LineTo(xe,b2);
end;
If checkbox5.checked=true then
begin
if (x<>0) and (x<>-20) and(x<>4) then textOut(xe-5,y0+5,FloatToStr(x)) else
begin
if x=-20 then textOut(xe+1,y0+5,FloatToStr(x));
if x=4 then textOut(xe-18,y0+5,FloatToStr(x));
end;
end;
x:=x+dx;
until(x>xmax);
y:=ymin;
repeat
Ye:=round(my*(-y+ymax)+b1);
If checkbox4.checked=true then
begin
MoveTo(a1,ye);LineTo(a2,ye);
end;
If checkbox5.checked=true then
begin
if (y<>0) and (y<>-20) and (y<>4) then textOut(x0-20,ye-5,FloatToStr(y)) else
begin
if y=-20 then textOut(x0-20,ye-17,FloatToStr(y));
if y=4 then textOut(x0-20,ye+1,FloatToStr(y));
end;
end;
y:=y+dy;
until(y>ymax);
Pen.Width:=2;
Pen.Color:=clRed;
Pen.Style:=psSolid;
MoveTo(a1,y0); LineTo(a2,y0);
MoveTo(x0,b1); LineTo(x0,b2);
Pen.Color:=clBlack;
If n=1 then
begin
pen.Width:=1;
if checkbox2.checked=true then
begin
Pen.Style:=psDot;
Pen.Color:=clRed;
MoveTo(a1-round(mx*xmin+a*mx),b1+round(my*ymax+b*my));
LineTo(a1-round(mx*xmin+a*mx),b1+round(my*ymax-b*my));
LineTo(a1-round(mx*xmin-a*mx),b1+round(my*ymax-b*my));
LineTo(a1-round(mx*xmin-a*mx),b1+round(my*ymax+b*my));
LineTo(a1-round(mx*xmin+a*mx),b1+round(my*ymax+b*my));
Pen.Color:=clBlack;
Pen.Style:=psSolid;
Pen.Width:=2;
MoveTo(x0,y0);
LineTo(x0,b1+round(my*ymax-b*my));
MoveTo(x0,y0);
LineTo(a1-round(mx*xmin-a*mx),y0);
end;
x1:=xmin;
repeat
y2:=((sqr(x1)/sqr(a))-1)*sqr(b);
if checkbox1.checked=true then
begin
y1:=x1*b/a;
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clblue;
y1:=-x1*b/a;
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clblue;
end;
if y2>=0 then
begin
y1:=sqrt(y2);
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
y1:=-sqrt(y2);
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
end;
x1:=x1+0.005;
until(x1>xmax);
If (a>20) or (a<-20) then showMessage('ГЋГЎГҐ ãèïåðáîëû Г*Г*õîäÿòñÿ Г§Г* ïðåäåëГ*ìè'+#13
+'êîîðäèГ*Г*ГІГ*îé ïëîñêîñòè')
else
begin
if (a>4) or (a<-4) then ShowMessage('ГЏГ°Г*ГўГ*Гї ãèïåðáîëГ* Г*Г*õîäèòñÿ Г§Г* ïðåäåëГ*ìè'
+#13+'êîîðäèГ*Г*ГІГ*îé ïëîñêîñòè');
end;
c:=sqrt(sqr(a)+sqr(b));
Edit3.Text:=FloatToStrf(c,fffixed,4,2);
TextOut(a1-round(mx*xmin-abs(a)*mx-c*mx)-3,y0-16,'C');
TextOut(a1-round(mx*xmin+abs(a)*mx+c*mx)-3,y0-16,'C');
E:=C/A;
Edit4.Text:=FloatToStrf(E,fffixed,4,2);
Pen.Style:=psSolid;
Pen.Color:=clBlue;
Pen.Width:=1;
ellipse(round(x0+(c+abs(a))*mx-3),y0-3,round(x0+(c+abs(a))*mx+3),y0+3);
ellipse(round(x0-(c+abs(a))*mx-3),y0-3,round(x0-(c+abs(a))*mx+3),y0+3);
D:=abs(A/E);
Edit5.Text:=FloatToStrf(D,fffixed,4,2);
If checkbox3.Checked=True then
begin
y1:=ymin;
repeat
pixels[a1-round(mx*xmin+D*mx),b1+round(my*ymax-y1*my)]:=clGreen;
pixels[a1-round(mx*xmin-D*mx),b1+round(my*ymax-y1*my)]:=clGreen;
y1:=y1+0.01;
until(y1>ymax);
end;
end;
end;
end;
 
 
 
procedure TForm1.CheckBox1Click(Sender: TObject);
begin
Paintbox1.Repaint;
end;
 
procedure TForm1.CheckBox2Click(Sender: TObject);
begin
Paintbox1.Repaint;
end;
 
procedure TForm1.CheckBox3Click(Sender: TObject);
begin
PaintBox1.Repaint;
end;
 
procedure TForm1.CheckBox4Click(Sender: TObject);
begin
Paintbox1.Repaint;
end;
 
procedure TForm1.CheckBox5Click(Sender: TObject);
begin
PaintBox1.Repaint;
end;
 
procedure TForm1.N3Click(Sender: TObject);
begin
form2.show;
end;
 
procedure TForm1.N4Click(Sender: TObject);
begin
form3.show;
end;
 
procedure TForm1.N5Click(Sender: TObject);
begin
close;
end;
 
procedure TForm1.N7Click(Sender: TObject);
begin
form4.show;
end;
 
procedure TForm1.N8Click(Sender: TObject);
begin
form7.show;
end;
 
end.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.06.2009, 01:11
Ответы с готовыми решениями:

Изменение программы
Помогите исправить программу. Требуется найти произведение элементов массива, ...

Изменение кода программы
Подскажите, как изменить эти две формулы под данный код программы, чтобы их...

Изменение иконки программы
В общем задача такая не трудная, но я не знаю даже с чего и начать ее решать...

Изменение имени программы в делфи
Интересует как менять имя программы в процесах не имя формы меняймое через...

Програмное изменение данных программы
Здравствуйте, дорогие форумчане :) В общем такая проблема: Есть у меня...

3
Landser
57 / 7 / 4
Регистрация: 18.04.2009
Сообщений: 370
24.06.2009, 10:31 2
короче я твой код скопировал себе, стал компилить, ну а он ясно дело не компилиться,тк я не создал
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
PaintBox1: TPaintBox;
Edit1: TEdit;
Edit2: TEdit;
Label1: TLabel;
Label4: TLabel;
GroupBox1: TGroupBox;
Button1: TButton;
Button2: TButton;
GroupBox2: TGroupBox;
Label2: TLabel;
Edit3: TEdit;
Label3: TLabel;
Label5: TLabel;
CheckBox1: TCheckBox;
Edit4: TEdit;
Label6: TLabel;
Label7: TLabel;
CheckBox2: TCheckBox;
CheckBox3: TCheckBox;
Label8: TLabel;
Edit5: TEdit;
Label9: TLabel;
GroupBox3: TGroupBox;
CheckBox4: TCheckBox;
CheckBox5: TCheckBox;
MainMenu1: TMainMenu;
N1: TMenuItem;
N2: TMenuItem;
N3: TMenuItem;
N4: TMenuItem;
N5: TMenuItem;
N6: TMenuItem;
N7: TMenuItem;
Image1: TImage;
N8: TMenuItem;
так что скажи, где именно в твоём коде "рисует гиперболы и вычисляет для них фокусы, эксцентриситет, директрисы. Так же рисует асимптоты, полуоси и дериктрисы"-а то я чё то не врублюсь так,и я типа почитаю книжку,(а то всё это на первом курсе аж было)-и постараюсь подумать,тут на мой взгляд нам несколько знание дельфи надо применить,сколько саму эту геометрию с элипсами, гиперболами и тд

ps прикрепи исходник, так будет значительно удобней вносить исправления
0
MaxiMax
0 / 0 / 0
Регистрация: 24.06.2009
Сообщений: 68
25.06.2009, 19:03  [ТС] 3
Landser, спс за попытку, я уже разобрался...
0
MaxiMax
0 / 0 / 0
Регистрация: 24.06.2009
Сообщений: 68
25.06.2009, 19:10  [ТС] 4
Landser, спс за попытку, я уже разобрался...
этот кусок:
if y2>=0 then
begin
y1:=sqrt(y2);
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
y1:=-sqrt(y2);
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
end;

нужно заменяить на этот:

if y2<=0 then
begin
y1:=sqrt(abs(y2));
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
y1:=-sqrt(abs(y2));
pixels[a1-round(mx*xmin-x1*mx),b1+round(my*ymax+y1*my)]:=clpurple;
end;

если интересно то выкладываю 2 варианта проги, 1 с гиперболой а второй с элипсом, второй не доработаный=)
0
Вложения
Тип файла: rar 1.rar (22.1 Кб, 26 просмотров)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.06.2009, 19:10

Изменение переменной во время выполнения программы
Здравствуйте! Мне необходимо изменять переменную во время выполнения программы....

Изменение размера Image во время работы программы
Как сделать вокруг Image такую рамку, и чтобы потянув за неё можно было легко...

Изменение значения Label во время исполнения программы
В поле edit ввожу строку, как реализовать подсчет длины строки в поле Label во...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru