![]() |
Re: Wieso funktioniert das mit dem Zufall nicht?
Hast du evtl. Randomize vergessen?
k-w PS: Einfach "Randomize;" ins OnCreate schreiben. :wink: |
Re: Wieso funktioniert das mit dem Zufall nicht?
Zitat:
Zum Problem: Da benötigst du eine globale Boolean-Variable, die angibt, ob es der erste "Kontakt" mit der Ampel ist. Der Default-Wert ist natürlich false. Sobald das Auto in den Bereich der Ampel kommt, setzt du sie auf true. Gleichzeitig setzt du das Timerintervall hoch, falls Random zutrifft. Im nächsten Timeraufruf (Variable = false, im Bereich der Ampel) setzt du das Intervall wieder auf den Standardwert. Wenn das Auto die Ampel hinter sich gelassen hat, musst du sie wieder auf true stellen. |
Re: Wieso funktioniert das mit dem Zufall nicht?
Zitat:
|
Re: Wieso funktioniert das mit dem Zufall nicht?
Hallo fabgo,
wenn du den Zufallswert nur einmal pro Fahrt haben möchtest, dann musst du ihn beim Fahrtbeginn (ImgAuto1.Left = -20) bestimmen und in einer private Variable deiner Form (TAmpel2) ablegen. Außerdem musst du etwas aufpassen, wenn du IF-ELSE-IF Strecken kodierst, besonders wenn du an verschiedenen Stellen weitere Bedingungen knüpfst. Die Intervalle müssen immer klar zu erkennen sein:
Delphi-Quellcode:
Schreibfehler inbegriffen...
interface
type TAmpel2 = class(TForm) ... private GibGas: boolean; end; implementation procedure TAmpel2.Timer1Timer(Sender: TObject); begin with ImAuto1 do begin Left := (Left + 20 + 2) mod 640 - 20; if Left = -20 then GibGas := Odd(Random(2)); if (Left >= 174) then Timer1.Interval := 10 else if (Left > 124) then begin if ImRotLinks.Visible then Timer1.Interval := 30 end else if Left > 88 then begin if ImGelbLinks.Visible then if GibGas then Timer1.Interval := 10 else Timer1.Interval := 1000; end else Timer1.Interval := 10; end; end; Grüße vom marabu |
Re: Wieso funktioniert das mit dem Zufall nicht?
VIELEN DANK!!!
|
Re: Wieso funktioniert das mit dem Zufall nicht?
Zitat:
Zitat:
Delphi-Quellcode:
Var RandSeed: LongInt;
Procedure Randomize; Var Count: LargeInt; Begin If QueryPerformanceCounter(Count) Then RandSeed := Count Else RandSeed := GetTickCount; End; Function Random(Range: LongInt): LongInt; Overload; // Borland Delphi v7.0 Build 4453 Begin RandSeed := RandSeed * 134775813 + 1; //Result := LargeInt(Range) * LongWord(RandSeed) div LargeInt($100000000); Result := TLargeIntRec(LargeInt(Range) * LongWord(RandSeed)).Hi; End; Function Random: Extended; Overload; // Borland Delphi v7.0 Build 4453 Begin RandSeed := RandSeed * 134775813 + 1; //Result := 1.0 * LongWord(RandSeed) / LargeInt($100000000); Result := LongWord(RandSeed) / LargeInt($100000000); End; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:06 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz