From c1147629f7aae2ee90ccd7c9f1ccbf106361d486 Mon Sep 17 00:00:00 2001 From: Eugen Wissner Date: Sat, 13 Dec 2025 16:35:46 +0100 Subject: =?UTF-8?q?Add=20book=20"=D0=97=D0=B0=D0=BD=D0=B8=D0=BC=D0=B0?= =?UTF-8?q?=D1=82=D0=B5=D0=BB=D1=8C=D0=BD=D0=BE=D0=B5=20=D0=BF=D1=80=D0=BE?= =?UTF-8?q?=D0=B3=D1=80=D0=B0=D0=BC=D0=BC=D0=B8=D1=80=D0=BE=D0=B2=D0=B0?= =?UTF-8?q?=D0=BD=D0=B8=D0=B5"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../1/2_ideal_gas/unit1.pas" | 125 +++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 "\320\227\320\260\320\275\320\270\320\274\320\260\321\202\320\265\320\273\321\214\320\275\320\276\320\265 \320\277\321\200\320\276\320\263\321\200\320\260\320\274\320\274\320\270\321\200\320\276\320\262\320\260\320\275\320\270\320\265/1/2_ideal_gas/unit1.pas" (limited to 'Занимательное программирование/1/2_ideal_gas/unit1.pas') diff --git "a/\320\227\320\260\320\275\320\270\320\274\320\260\321\202\320\265\320\273\321\214\320\275\320\276\320\265 \320\277\321\200\320\276\320\263\321\200\320\260\320\274\320\274\320\270\321\200\320\276\320\262\320\260\320\275\320\270\320\265/1/2_ideal_gas/unit1.pas" "b/\320\227\320\260\320\275\320\270\320\274\320\260\321\202\320\265\320\273\321\214\320\275\320\276\320\265 \320\277\321\200\320\276\320\263\321\200\320\260\320\274\320\274\320\270\321\200\320\276\320\262\320\260\320\275\320\270\320\265/1/2_ideal_gas/unit1.pas" new file mode 100644 index 0000000..44489ca --- /dev/null +++ "b/\320\227\320\260\320\275\320\270\320\274\320\260\321\202\320\265\320\273\321\214\320\275\320\276\320\265 \320\277\321\200\320\276\320\263\321\200\320\260\320\274\320\274\320\270\321\200\320\276\320\262\320\260\320\275\320\270\320\265/1/2_ideal_gas/unit1.pas" @@ -0,0 +1,125 @@ +unit Unit1; + +{$mode objfpc}{$H+} + +interface + +uses + Classes, SysUtils, Forms, Controls, Graphics, Dialogs, ExtCtrls, StdCtrls, + Math; + +type + + Molecule = record + X, Y: Integer; + Vx, Vy: Integer; + end; + + { TForm1 } + + TForm1 = class(TForm) + StartStopBtn: TButton; + Screen: TPaintBox; + procedure StartStopBtnClick(Sender: TObject); + procedure ScreenPaint(Sender: TObject); + private + const R: Integer = 10; { Радиус молекулы } + V: Integer = 7; { Максимальная скорость молекулы } + N = 30; { Количество молекул } + var Mol: array[1..N] of Molecule; { Массив молекул } + public + + end; + +var + Form1: TForm1; + IsRunning: Boolean = false; + +implementation + +{$R *.lfm} + +{ TForm1 } + +procedure TForm1.ScreenPaint(Sender: TObject); + var i: Integer; +begin + if not IsRunning then Exit; + + for i := 1 to N do { Цикл по всем молекулам } + begin + Screen.Canvas.Pen.Color := clBtnFace; { Стираем молекулу } + Screen.Canvas.Ellipse(Mol[i].X - R, Mol[i].Y - R, + Mol[i].X + R, Mol[i].Y + R); + + Mol[i].X := Mol[i].X + Mol[i].Vx; { Сдвигаем на новую позицию } + Mol[i].Y := Mol[i].Y + Mol[i]. Vy; + + { Определяем, не вышла ли молекула за границы аквариума } + if Mol[i].X > Screen.Width - R then + begin + Mol[i].X := Screen.Width - R; + Mol[i].Vx := -Mol[i].Vx; + end; + if Mol[i].X < R then + begin + Mol[i].X := R; + Mol[i].Vx := -Mol[i].Vx; + end; + if Mol[i].Y > Screen.Height - R then + begin + Mol[i].Y := Screen.Height - R; + Mol[i].Vy := -Mol[i].Vy; + end; + if Mol[i].Y < R then + begin + Mol[i].Y := R; + Mol[i].Vy := -Mol[i].Vy; + end; + + Screen.Canvas.Pen.Color := clBlue; { Рисуем молекулу на новой } + Screen.Canvas.Ellipse(Mol[i].X - R, Mol[i].Y - R, { позиции } + Mol[i].X + R, Mol[i].Y + R); + end; +end; + +procedure TForm1.StartStopBtnClick(Sender: TObject); + var angle: Real; { Угол, задающий изначальное направление полета } + i: Integer; { Счетчик цикла } + CurV: Integer; { Выбранная случайная скорость молекулы } +begin + if IsRunning then + begin + IsRunning := false; + StartStopBtn.Caption := 'Пуск'; + Exit; + end; + + StartStopBtn.Caption := 'Стоп'; + IsRunning := true; + + Randomize; + + for i := 1 to N do { Цикл по всем молекулам } + begin + Mol[i].X := RandomRange(R, Screen.Width - R); { Выбор начального } + Mol[i].Y := RandomRange(R, Screen.Height - R); { положения молекулы } + angle := Random(360) * Pi / 180; { и ее направления } + + CurV := RandomRange(1, V); { Выбор скорости молекулы (1 - V) } + Mol[i].Vx := Round(CurV * Sin(angle)); { Получение составляющих } + Mol[i].Vy := Round(CurV * Cos(angle)); { скорости молекулы } + end; + + while IsRunning do { Основной цикл } + begin + Screen.Invalidate; + Sleep(10); { Пауза на 10 миллисекунд } + Application.ProcessMessages; + if Application.Terminated then Break; + end; + +end; + +end. + -- cgit v1.2.3