AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Cross-Platform-Entwicklung [FMX] Wann ist TMessageDlg tatsächlich geschlossen?
Thema durchsuchen
Ansicht
Themen-Optionen

[FMX] Wann ist TMessageDlg tatsächlich geschlossen?

Ein Thema von DeddyH · begonnen am 29. Jun 2015 · letzter Beitrag vom 29. Jun 2015
Antwort Antwort
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#1

[FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 14:52
Ab Delphi XE7 gibt es ja die Möglichkeit, einen non-blocking TMessageDlg mit einer anonymen Methode zu verwenden. Funktioniert ja im Prinzip auch, nur habe ich zumindest unter iOS das Problem, dass bei der Abarbeitung dieser Methode der Dialog immer noch sichtbar (und mir in diesem Fall im Weg) ist. Gibt es eine elegante Möglichkeit, den Rückgabewert auszuwerten und mit der weiteren Verarbeitung zu warten, bis sich der Dialog wirklich verabschiedet hat?

Danke fürs Lesen.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen

Geändert von DeddyH (29. Jun 2015 um 14:55 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.143 Beiträge
 
Delphi 10.3 Rio
 
#2

AW: [FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 15:09
Erst mal 42! (Weil kein Source gepostet)

Ob der Dialog nun blocking oder nonblocking ist...
Im Normalfall musst Du die Verarbeitung ja anhalten um auf die Antwort von User zu warten...

Unter Android muss es nonBlocking sein, unter iOS nicht, daher mache ich das so:

Delphi-Quellcode:
function MyMessageDlg(const Msg: string; DlgType: TMsgDlgType; Buttons: TMsgDlgButtons; HelpCtx: Longint): Integer;
{$IFDEF ANDROID}
var
  MsgDlgResult : Integer;
{$ENDIF}
begin
  {$IFDEF ANDROID}
  MsgDlgResult := -1;
  FMX.Dialogs.MessageDlg(Msg, DlgType, Buttons, HelpCtx,
    procedure(const AResult: TModalResult)
      begin
        MsgDlgResult:= AResult;
      end);

  while MsgDlgResult<0 do
    begin
      Application.Processmessages;
      Sleep(10);
    end;

    Result := MsgDlgResult;
  {$ELSE}
  Result := FMX.Dialogs.MessageDlg(Msg, DlgType, Buttons, HelpCtx);
  {$ENDIF}
end;
Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#3

AW: [FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 15:23
Application.ProcessMessages und Eleganz beißt sich zwar IMO (zumindest unter VCL), aber es geht wohl nicht anders. Mit einem Sack voll IFDEFs habe ich das nun mittlerweile auch in den Griff bekommen, trotzdem Danke.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
741 Beiträge
 
#4

AW: [FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 15:28
Delphi-Quellcode:
function MyMessageDlg(const Msg: string; DlgType: TMsgDlgType; Buttons: TMsgDlgButtons; HelpCtx: Longint): Integer;
{$IFDEF ANDROID}
var
  MsgDlgResult : Integer;
{$ENDIF}
begin
  {$IFDEF ANDROID}
  MsgDlgResult := -1;
  FMX.Dialogs.MessageDlg(Msg, DlgType, Buttons, HelpCtx,
    procedure(const AResult: TModalResult)
      begin
        MsgDlgResult:= AResult;
      end);

  while MsgDlgResult<0 do
    begin
      Application.Processmessages;
      Sleep(10);
    end;

    Result := MsgDlgResult;
  {$ELSE}
  Result := FMX.Dialogs.MessageDlg(Msg, DlgType, Buttons, HelpCtx);
  {$ENDIF}
end;
"Überlebt" das die App unter Android, wenn du bei angezeigtem Dialog zum Homescreen oder einer anderen App wechselst und danach zurück zu deiner App?
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.143 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: [FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 17:15
Application.ProcessMessages und Eleganz beißt sich zwar IMO (zumindest unter VCL), aber es geht wohl nicht anders. Mit einem Sack voll IFDEFs habe ich das nun mittlerweile auch in den Griff bekommen, trotzdem Danke.
Der VCL Teil hat ja auch kein Application.ProcessMessages

"Überlebt" das die App unter Android, wenn du bei angezeigtem Dialog zum Homescreen oder einer anderen App wechselst und danach zurück zu deiner App?
Klar warum auch nicht?
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
741 Beiträge
 
#6

AW: [FMX] Wann ist TMessageDlg tatsächlich geschlossen?

  Alt 29. Jun 2015, 17:24
"Überlebt" das die App unter Android, wenn du bei angezeigtem Dialog zum Homescreen oder einer anderen App wechselst und danach zurück zu deiner App?
Klar warum auch nicht?
Weil man AFAIR bei XE5 noch ganz normal ShowMessage blockierend aufrufen konnte und damals genau das oben beschriebene ein Problem (wenn nicht sogar "das" Problem?!) war.

Und: Wenn deine Lösung so einfach und gut funktioniert, warum hat Emba das dann nicht als Standard eingebaut?
  Mit Zitat antworten Zitat
Antwort Antwort


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 01:40 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz