setcolor(15);
setfillstyle(1,7);
bar(160,150,460,260);
rectangle(165,155,455,255);
rectangle(167,157,453,253);
case (ea mod 2) of
0: outtextxy(180,170,' Идет работа .Ждите..');
1: outtextxy(180,170,' Working.Please wait..');
end;
setfillstyle(1,12);
setcolor(0);
rectangle(200,199,401,221);
for i:=1 to 9 do
line(200+i*20,200,200+i*20,220);
delay(20000);
for i:=1 to 100 do
begin
if ((i-1) mod 10)=0 then
line(200+((i-1) div 10)*20,200,200+((i-1) div 10)*20,220);
bar(round(200+2*(i-0.5)),200,200+2*i,220);
delay(1100);
bar(280,230,323,250);
str(i,f);
f:=f+'%';
outtextxy(290,235,f);
if (i mod 25) =0 then
bar(170,180,452,198);
if (ea mod 2)=0 then
case (i div 25) of
0:
outtextxy(170,190,'Подготовка ');
1:
outtextxy(170,190,'Расчет коеффициентов в многочлене');
2:
outtextxy(170,190,'Расчет коеффициентов Ньютона-Котеса');
3:
outtextxy(170,190,'Расчет интеграла');
end
else
outtextxy(170,190,'Prepearing');
outtextxy(170,190,'Calculation of mnogochlen coeff.');
outtextxy(170,190,'Calculation of Newton-Cotes coeff. ');
outtextxy(170,190,'Calculation of integral');
procedure winwwodn(ea:word);
{Окно ввода числа узлов интерполяции}
var
c:char;
f:string;
helpwin(ea);
if (ea mod 2) =0 then
outtextxy(360,140,' В этом окне необходимо ');
outtextxy(360,155,' ввести количество узлов ');
outtextxy(360,170,' интерполяции, от которого ');
outtextxy(360,185,' будет зависить точность ');
outtextxy(360,200,' вычисления интеграл и ');
outtextxy(360,215,' количество зн чений функции.');
outtextxy(360,240,' ВНИМАНИЕ : НАСТОЯТЕЛЬНО ');
outtextxy(360,250,' РЕКОМЕНДУЕТСЯ НЕ ВВОДИТЬ ');
outtextxy(360,260,' ЗНАЧЕНИЕ N БОЛЬШЕ 12 !! ');
outtextxy(360,140,' In this window you have to ');
outtextxy(360,155,' put into the number. ');
outtextxy(360,170,' The accuracy of calculation ');
outtextxy(360,185,' and the number of function ');
outtextxy(360,200,' parameters will depend on ');
outtextxy(360,215,' this number. ');
outtextxy(360,240,' WARNING: IT IS HARDLY ');
outtextxy(360,250,' RECOMENDED NOT TO PUT IN ');
outtextxy(360,260,' NUMBER MORE THEN 12 !! ');
setcolor(2);
setfillstyle(1,14);
bar(70,200,340,300);
rectangle(75,205,335,295);
rectangle(77,207,333,293);
outtextxy(90,227,'Введите количество узлов(n):');
outtextxy(80,270,'ВНИМАНИЕ: При больших n возможна');
outtextxy(80,280,'некорректная работа компьютера!!');
outtextxy(80,217,'Put in number of');
outtextxy(80,227,' interpolation units:');
outtextxy(80,270,'WARNING:if you use big number ');
outtextxy(80,280,'of units,PC wont work properly!');
setfillstyle(1,0);
bar(190,240,230,255);
procedure wwodn(ea:word;var n:integer);
{Процедура ввода узлов n}
ec,p:integer;
k,f:string;
x:integer;
newsc(ea);
winwwodn(ea);
repeat
gotoxy(25,16);
read(k);
val(k,p,ec);
if ec<>0 then
error1(ea);
readln;
until ec=0;
n:=p;
if n>12 then
if keypressed then
c:=readkey;
c:='r';
bar(140,210,490,300);
rectangle(145,215,485,295);
rectangle(147,217,483,293);
outtextxy(150,227,' Предупреждение!');
outtextxy(150,237,' Вы дейcтвительно хотите использовать');
outtextxy(150,250,' большое значение N ???');
outtextxy(150,227,' Warning!!
');
outtextxy(150,237,' Do you realy want to use a big
outtextxy(150,250,' number interpolation units(N)???
sound(600);
delay(4000);
nosound;
setfillstyle(1,2);
bar(320,260,350,280);
bar(250,260,280,280);
if (c=#80) or (c=#72) or (c=#77) or (c=#75) then
x:=x+1;
if (x mod 2)=0 then
END;
outtextxy(255,267,'ДА');
outtextxy(325,267,'НЕТ');
outtextxy(255,267,'YES');
outtextxy(325,267,'NO');
until c=#13;
if abs(x mod 2)=1 then
n:=0;
bar(160,200,460,280);
rectangle(165,205,455,275);
rectangle(167,207,453,273);
outtextxy(180,227,'Для работы программы необходимо');
outtextxy(180,237,' заново ввести N.');
outtextxy(180,247,' Нажмите ENTER для продолжения.');
outtextxy(180,227,' To continue you have to ');
outtextxy(180,237,' again put in N. ');
outtextxy(180,247,' Press ENTER to continue.');
until n>0;
procedure winwwodab(ea:word);
{Окно ввода приделов интегрирования}
outtextxy(360,140,' В этом окне необходимо');
outtextxy(360,155,' ввести сначала нижнее');
outtextxy(360,170,' значение интеграл и нажать');
outtextxy(360,185,' ENTER, а затем ввести');
outtextxy(360,200,' верхнее значение интеграла');
outtextxy(360,215,' и снова нажать ENTER.');
outtextxy(360,140,' In this window you have to:');
outtextxy(360,155,'firstly, put in lower value ');
outtextxy(360,170,'of integral and press ENTER,');
outtextxy(360,185,'then put in higher value');
outtextxy(360,200,'of integral and press ENTER');
setfillstyle(1,5);
bar(10,210,335,320);
rectangle(15,215,330,315);
rectangle(17,217,328,313);
settextstyle(0,0,0);
outtextxy(20,230,' Введите нижнее значение');
outtextxy(20,244,' интеграл :');
outtextxy(20,262,' Введите верхнее значение');
outtextxy(20,272,'интеграл :');
outtextxy(20,230,' Put in lower value of');
outtextxy(20,244,' integral:');
outtextxy(20,262,' Put in higher value of');
outtextxy(20,272,'integral:');
procedure wwodab(ea:word;var a,b:real);
{Процедура ввода приделов интегрирования}
k:string;
ec:integer;
winwwodab(ea);
gotoxy(16,16);
val(k,a,ec);
str(a:4:2,f);
outtextxy(120,244,f);
gotoxy(16,18);
val(k,b,ec);
procedure helpwin(ea:word);
{основа окна помощи}
setfillstyle(1,3);
bar(350,100,590,380);
Страницы: 1, 2, 3, 4, 5, 6