AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Nix mit plattformübergreifend...

Ein Thema von Rued · begonnen am 5. Jan 2025 · letzter Beitrag vom 6. Jan 2025
Antwort Antwort
Seite 2 von 2     12   
AuronTLG

Registriert seit: 2. Mai 2018
Ort: Marburg
294 Beiträge
 
Delphi 12 Athens
 
#11

AW: Nix mit plattformübergreifend...

  Alt Gestern, 15:40
Zitat:
setlength(rf,anz);
for a := 0 to anz -1 do rf[a] := a;
azufmix(rf);
for a := 0 to anz -1 do begin
n:= rf[a];
MessageDlg(Spain[n].SpruchES, TMsgDlgType.mtConfirmation,
[
TMsgDlgBtn.mbYes,
TMsgDlgBtn.mbNo,
TMsgDlgBtn.mbClose
], 0, procedure(const AResult: TModalResult)
begin
case AResult of
mrNo: showmessage(Spain[n].SpruchDE);
mrClose:exit;
end;
end );
end;
Das hier geht in die richtige Richtung, ist aber nicht ganz richtig gedacht. Wie erwähnt kann der Hauptthread in Android nicht blockiert werden, d.h. der MessageDlg hält die App nicht an, wodurch die Schleife einfach weiterläuft.
Die asynchronen Dialoge mit Rückgabemethode funktionieren so, dass sie angezeigt werden während der Quelltext weiter ausgeführt wird und die Rückgabemethode genau dann ausgelöst wird, wenn der Nutzer mit dem Dialog interagiert hat.
Dementsprechend muss der nächste Schritt immer in der Rückgabemethode ausgelöst werden. Das erfordert, wenn man eine Art Schleifendurchlauf erreichen will, etwas Umdenken.

Zitat:
//array rf wird entsprechend Record-Größe für Ausdrücke gefüllt
setlength(rf,anz); for a := 0 to anz -1 do rf[a] := a;
//Array wird gemischt
azufmix(rf);
for a :=0 to anz-1 do begin
wo := rf[a];
LSpain2.Text := Spain[wo].SpruchES;
Timer1.Enabled := true;
end;
Ähnliches Problem wie oben: Die Schleife ist in Sekundenbruchteilen durchgelaufen, in welchen derselbe Timer anz - 1 mal wieder und wieder auf Enabled gesetzt wird, wodurch er dennoch genau einmal ausgelöst wird.
Ähnlich wie oben muss der nächste Schritt immer beim auslösen des Timers durchgeführt werden.
  Mit Zitat antworten Zitat
QuickAndDirty

Registriert seit: 13. Jan 2004
Ort: Hamm(Westf)
1.946 Beiträge
 
Delphi 12 Athens
 
#12

AW: Nix mit plattformübergreifend...

  Alt Gestern, 16:10
Ich habe das gefühl du strukturierst dein Programm wie ein Kommandozeilen-Programm bzw,. Konsolen-Programm.

Die GUI ist aber Ereignis getrieben, bzw. Thread getrieben.

Das Application Framework hat eine Message Queue.

Wenn du "MessageDlg" oder "showmessage" aufrufst ist das Non-Blocking. Das heißt, die Funktion hinterlegt in der Warteschlange, dass du nen Dialog angezeigt haben willst, wie der konfiguriert wird und welcher Code danach ausgeführt werden soll.

Wenn dein For-Schleifen Code abgearbeitet ist und das Ereignis das deinen Code aufgerufen hat abgearbeitet ist, dann wird das nächste Ereignis aus der Warteschleife abgearbeitet, und irgendwann kommen dann deine Dialoge dran.

Der Timer setzt wenn er enabled wird alle so und so viel millisekunden eine Nachricht auf die Warteschlange, dass ein Ereignis ausgeführt werden soll.


Du musst nicht eine "Eingabe-Verarbeitung-Ausgabe-Wiederholen" struktur anlegen, denn das Framework hat das alles schon. Das Framework erlaubt dir Callback Proceduren zu hinterlegen , sogenannte Events.
Andreas
Monads? Wtf are Monads?

Geändert von QuickAndDirty (Gestern um 16:20 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:25 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 by Thomas Breitkreuz