Deine Klasse TKreis ist auch mit überflüssigen Informationen gespickt. Das reicht schon:
Delphi-Quellcode:
TKreis = class(TShape)
private
{ Private-Deklarationen }
public
{ Public-Deklarationen }
speedx,speedy :integer;
end;
Allerdings solltest du diese Werte auch beim Erstellen des Kreises mit vorgeben:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
arraylaenge,
radius : integer;
begin
arraylaenge := length(kreis);
setLength( kreis, arraylaenge + 1);
kreis[arraylaenge]:= TKreis.Create(self);
With kreis[arraylaenge] do
begin
Parent := Self;
Shape := stCircle;
radius := 10+random(30); // 10 .. 39
Width := radius*2;
Height := radius*2;
Top := random( Self.ClientHeight - Height );
Left := random( Self.ClientWidth - Width );
speedx := random( 41 ) - 20; // -20 .. 20
speedy := random( 41 ) - 20; // -20 .. 20
end;
end;
Das mit dem
with
kann einen manchmal in Teufels Küche bringen, von daher sollte man es eigentlich vermeiden, wenn hier der Kontext nicht eindeutig ist. Hier sollte es zwar funktionieren, fraglich ist aber nur, wie lange.
Nun zum Bewegen:
Delphi-Quellcode:
procedure TForm1.Timer1Timer(Sender: TObject);
var
kidx, ntop, nleft : integer;
k : TKreis;
begin
for kidx := Low( Kreis ) to High( Kreis ) do
begin
k := Kreis[kidx];
ntop := k.top + k.speedy;
nleft := k.left + k.speedx;
// Untere Grenze prüfen
if ntop > ( Self.ClientHeight - k.Height ) then
begin
ntop := 2 * ( Self.ClientHeight - k.Height ) - ntop; // Abprallen berücksichtigen
k.speedy := - k.speedy; // Richtung umdrehen
end;
// analog mit oben, links, rechts verfahren
...
// Position zuweisen
k.top := ntop;
k.left := nleft;
end;
end;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ea 0a 4c 14 0d b6 3a a4 c1 c5 b9
dc 90 9d f0 e9 de 13 da 60)