Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Multimedia (https://www.delphipraxis.net/16-multimedia/)
-   -   Delphi Ich will die Sanduhr zurück! (https://www.delphipraxis.net/191626-ich-will-die-sanduhr-zurueck.html)

p80286 3. Feb 2017 11:40

Ich will die Sanduhr zurück!
 
Hallo zusammen,
blöder Titel, trifft aber beinahe was ich will.
Jedes Mal wenn meine Anwendung auf eine DB zugreift (
Delphi-Quellcode:
Screen.Cursor:=crHourglass;
wird nach Tagesform mal Wasserstand in der Regenrinne div Sekunden der vollen Stunde) die "Sanduhr" angezeigt.
Ja, die Abfrage läuft in einem eigenen Thread, die GUI hat also eigentlich genug Zeit sich um Wichtiges zu kümmern. Unter NT war es ein richtiger Volkssport sich eigene Cursor zu basteln, aber das scheint aus der Mode gekommen zu sein. Ich hätte mir sonst da etwas auffälliges für die Datenbank gebastelt.
Oder wäre es besser auf der Oberfläche eine "Aktivitätskomponente" zu platzieren, das ist selbst gemacht, da weiß man was man hat?

Was würdet Ihr empfehlen?
Gruß
K-H

P.S.
Meine Ansprüche würden auch vom "DOS-Turner" (|/-\|/-\) befriedigt. Haupsache man sieht etwas.

Valle 3. Feb 2017 11:57

AW: Ich will die Sanduhr zurück!
 
Das mit dem Cursor würde heute wahrscheinlich niemand mehr verstehen

Heute benutzt man eigentlich nur noch Ladeanimationen als Bild in der GUI. Zumindest an der Webentwicklung sollte der praktischerweise dort sein, wo der Benutzer eine Aktion auslöst. Beispiel: Ich klicke auf meiner Seite auf den Button "Rechnung als bezahlt markieren". Dann verschwindet dieser Button und wird von einer Ladeanimation ersetzt. Das wird auf native Anwendungen wohl auch übertragbar sein.

Bei der Bildersuche der Suchmaschine deines Vertrauens findest du mit "loading gif" und "spinner gif" Beispiele für Animationen. Es gibt auch etliche Webseiten, die dir eine Animation generieren, die du dann herunterladen kannst.

jaenicke 3. Feb 2017 12:09

AW: Ich will die Sanduhr zurück!
 
Ich habe in einer kompakten GUI z.B. eine Ladeanimation direkt im Button gemacht. Sprich der Button wurde inaktiv, bekam die Caption Lade... und unter dem Text erschien eine ProgressBar, die natürlich auch in der Taskleiste entsprechend eingeblendet wurde.

Das hat den Vorteil, dass man das Fenster auch minimieren kann und trotzdem noch den Status sieht.

p80286 3. Feb 2017 12:19

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von Valle (Beitrag 1360729)
Das mit dem Cursor würde heute wahrscheinlich niemand mehr verstehen

Oh man, oh mann, ich werde nicht nur, ich bin wohl alt.
Vielen Dank für die Anregung, dann werde ich mich mal umschauen.
(In einer Neueren TOAD-Version habe ich vor kurzem ein Fenster mit "Laufzeit der Abfrage: x sec" gesehen, das war eigentlich nicht schlecht)

Vielen Dank
K-H

nahpets 3. Feb 2017 12:39

AW: Ich will die Sanduhr zurück!
 
Für "Damit der Anwender was zu sehen hat." nehme ich regelmäßig aus der JVCL den TJvProgressDialog.
Der hat 'ne Progressbar, in der man halt die Position verschieben kann und 'ne Caption, in der man "Fortschrittstexte" anzeigen kann.

Dazu kommt bei Datenbankabfragen ganz altertümlich
Delphi-Quellcode:
Screen.Cursor := crSQLWait;
Ja, das mit dem Werden bzw. Sein stimmt wohl, erwischt uns alle irgendwann, da kommt das "Früher war alles Besser" irgendwie ganz von alleine ;-) Ist halt der Anfang vom Ende der Flexibilität beim Älterwerden.

Was ich auch ganz gerne mal mache, wenn irgendwelche Arbeitsschritte hintereinander sehr lange dauern:

Delphi-Quellcode:
Application.Title := 'was machen wir-Beschreibung';
Wenn's dann fertig ist, kommt wieder der alte Application.Title dahin. Man sieht halt auch bei minimiertem Programm, dass es noch lebt und noch nicht fertig ist.

Die Sanduhr verschwindet, auch wenn sie eingeschaltet ist, oft, wenn man mit der Maus über irgendwelchen Komponenten vorbeikommt, die entweder irgendwas editierbares haben oder über Scrollbars verfügen. Da wird die Sanduhr dann schonmal beim Drüberkommen umgeändert in das "für die Komponente Richtige" und beim Verlassen nicht zur Sanduhr zurückgeändert, sondern zum Defaultcursor. Ist halt ein bisserl wie Lotto, nur mit weniger "Gewinnchancen" ;-)

p80286 3. Feb 2017 13:19

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von nahpets (Beitrag 1360744)
Die Sanduhr verschwindet, auch wenn sie eingeschaltet ist, oft, wenn man mit der Maus über irgendwelchen Komponenten vorbeikommt, die entweder irgendwas editierbares haben oder über Scrollbars verfügen. Da wird die Sanduhr dann schonmal beim Drüberkommen umgeändert in das "für die Komponente Richtige" und beim Verlassen nicht zur Sanduhr zurückgeändert, sondern zum Defaultcursor. Ist halt ein bisserl wie Lotto, nur mit weniger "Gewinnchancen" ;-)

Danke, der Zusammenhang ist mir noch gar nicht aufgefallen.
Ich habe bei einigen Anwendungen ein MSGLabel bzw. ein MSGPanel falls mehrere Arbeitsschritte hintereinander anfallen. Da es sich bei meinem Sorgenkind um eine Dialoganwendung handelt hatte ich so etwas (ähnliches) erst gar nicht in Betracht gezogen.

Früher war's nicht besser, es war weniger bunt.

Gruß
K-H

jaenicke 5. Feb 2017 09:21

AW: Ich will die Sanduhr zurück!
 
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:

Zitat von nahpets (Beitrag 1360744)
Delphi-Quellcode:
Application.Title := 'was machen wir-Beschreibung';
Wenn's dann fertig ist, kommt wieder der alte Application.Title dahin. Man sieht halt auch bei minimiertem Programm, dass es noch lebt und noch nicht fertig ist.

Das ist doch genau der Anwendungszweck der Fortschrittsanzeige in der Taskleiste. Das hat Microsoft ja genau für diesen Zweck eingebaut. Deshalb macht das auch Sinn das zu benutzen wie ich oben schon schrieb.

Das finde ich auch viel intuitiver als nur den Anwendungstitel zu setzen, den ich nur sehe, wenn ich die Maus drüberhalte. Vor allem kann man auch direkt signalisieren, wenn die Aktion pausiert ist oder z.B. ein Fehler passiert ist, durch den eine Benutzereingabe erforderlich ist. Dazu kommt, dass man ein Overlay-Icon setzen kann um direkt in der Taskleiste zu signalisieren was gerade passiert, wenn das in so kleiner Form möglich ist.
Das sieht dann z.B. so aus:

Anhang 46603

p80286 5. Feb 2017 11:50

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von jaenicke (Beitrag 1360834)
Zitat:

Zitat von nahpets (Beitrag 1360744)
Delphi-Quellcode:
Application.Title := 'was machen wir-Beschreibung';
Wenn's dann fertig ist, kommt wieder der alte Application.Title dahin. Man sieht halt auch bei minimiertem Programm, dass es noch lebt und noch nicht fertig ist.

Das ist doch genau der Anwendungszweck der Fortschrittsanzeige in der Taskleiste. Das hat Microsoft ja genau für diesen Zweck eingebaut. Deshalb macht das auch Sinn das zu benutzen wie ich oben schon schrieb.

Das finde ich auch viel intuitiver als nur den Anwendungstitel zu setzen, den ich nur sehe, wenn ich die Maus drüberhalte. Vor allem kann man auch direkt signalisieren, wenn die Aktion pausiert ist oder z.B. ein Fehler passiert ist, durch den eine Benutzereingabe erforderlich ist. Dazu kommt, dass man ein Overlay-Icon setzen kann um direkt in der Taskleiste zu signalisieren was gerade passiert, wenn das in so kleiner Form möglich ist.
Das sieht dann z.B. so aus:

Anhang 46603

Über "Intuitiv" kann man wohl diskutieren, wobei es sein kann, daß ich der einzige bin, der sehr selten auf die Taskleiste schaut. Davon abgesehen, wie kann man (ich) das realisieren (Jedi?)

Gruß
K-H

nahpets 5. Feb 2017 12:13

AW: Ich will die Sanduhr zurück!
 
Du kannst eigentlich an beliebiger Stelle im Progamm einfach Application.Title eine beliebige Zeichenfolge zuweisen. Die wird dann in der Taskleiste angezeigt.

So 'ne Art Fortschrittsanzeige könne so aussehen:
Delphi-Quellcode:
var
  sTitle : String;
begin
  sTitle := Application.Title;
  Table1.First;
  while not Table1.EoF do begin
    Table1.Edit;
    // Irgendwas ändern
    Table1.Post;
    Table1.Next;
    Application.Title := Format('ID: %.5d',[Table1.FieldByName('ID').AsInteger]);
  end;
  Application.Title := sTitle;
end;
Möchtest Du auch noch das Icon ändern, so müsste Application.Icon dafür die richtige Eigenschaft sein.

[EDIT]
Wenn Du einen eigenen Dialog haben möchtest, so kannst Du den TJvProgressDialog von den Jedis nehmen.

Aktualisieren des Dialoges könnte so gehen:
Delphi-Quellcode:
// pd -> Komponente TJvProgressDialog auf dem Formular
type
  Tform1 = class(TForm)
    pd: TJvProgressDialog;
  public
    { Public-Deklarationen }
    procedure pdAnzeigen(sCaption : String; sText : String = ''; iMin : Integer = 0; iMax : Integer = 100; iPosition : Integer = 50);
    procedure pdHide;
  end;

procedure Tform1.pdAnzeigen(sCaption : String; sText : String = ''; iMin : Integer = 0; iMax : Integer = 100; iPosition : Integer = 50);
begin
  pd.Caption := sCaption;
  pd.Text    := sText;
  pd.Min     := iMin;
  pd.Max     := iMax;
  pd.Position := iPosition;
  pd.Show;
  if sText <> '' then Application.Title := sText;
end;

procedure TfmTextverwaltung.pdHide;
begin
  pd.Hide;
  Application.Title := 'Mein Programmname';
end;

// irgendwo im Programm
var
  iMin : Integer;
  iMax : Integer;
  iPos : Integer;
  sCaption : String;
  sText   : String;

begin
  Screen.Cursor := crSQLWait;
  pdAnzeigen('Datenbankabfrage läuft ...');
  qrySQL.ExecSQL;

// oder
  pdAnzeigen('SQL-Statement wird ausgeführt ...',qrySQL.SQL.Text);
  qrySQL.ExecSQL;

//oder:
  pdAnzeigen('Öffne Abfrage ...',qrySQL.SQL.Text);
  qry.Open;
  iMin := 0;
  iMax := qry.RecordCount;
  iPos := 0;
  sCaption := Format('%d Datensätze werden verarbeitet ...',[iMax]);
  sText   := '';
  pdAnzeigen(sCaption, sText, iMin, iMax , iPos);
  qry.First
  while not qry.Eof do begin
    Inc(iPos);
    sText := Format('ID: %.5d',[qry.FieldByName('ID').AsInteger]);
    pdAnzeigen(sCaption, sText , iMin, iMax, iPos);
    // Irgendwas mit den Daten machen ...
    qry.Next;
  end;
  qry.Close;
  pdHide;
  Screen.Cursor := crDefault;
[/EDIT]

p80286 5. Feb 2017 12:50

AW: Ich will die Sanduhr zurück!
 
Mal schauen,
Vielen Dank!

K-H

Valle 5. Feb 2017 13:04

AW: Ich will die Sanduhr zurück!
 
Es sei aber gesagt, dass nahpets' Lösung nicht das erreicht was auf jaenickes Screenshot zu sehen ist. Genau genommen würden die meisten Anwender diesen Application Title heute gar nicht mehr zu Gesicht bekommen. Über Bei Google suchendelphi taskbar progress findet man, wie man eine ProgressBar in die Taskleiste bekommt.

Als zusätzliche Maßnahme finde ich die Idee gut, aber nur einen anderen Cursor und diesen Titel ist nicht mehr zeitgemäß.

Aviator 5. Feb 2017 13:45

AW: Ich will die Sanduhr zurück!
 
Seit XE7 oder XE8 gibt es eine Komponente TTaskBar, die dir die Funktionen zum Anzeigen der Statusbar und der Icons und Funktionsbuttons in der Taskleiste zur Verfügung stellt.

Wenn du diese Version nicht besitzt, dann kannst du dir allerdings durch die Interfaces von Microsoft behelfen und somit den gleichen Effekt erzielen.

ITaskBarList, ITaskBarList2, ITaskBarList3

p80286 5. Feb 2017 15:14

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von Valle (Beitrag 1360846)
Als zusätzliche Maßnahme finde ich die Idee gut, aber nur einen anderen Cursor und diesen Titel ist nicht mehr zeitgemäß.

Das versteh' ich nicht!
Solange der Benutzer gut erkennen kann, das ein Programm etwas arbeitet ("es tut nichts, dann tut es was") ist alles gut. Je nachdem ist ein Cursor oder ein Progressbar natürlich Augenwischerei, aber es ist gut für den Blutdruck des Benutzers.

Gruß
K-H

Valle 5. Feb 2017 18:51

AW: Ich will die Sanduhr zurück!
 
Mh, ich verstehe nicht was es nicht zu verstehen gibt. :stupid:

Ich habe zwei Dinge in diesem Thread gesagt: Den Cursor würde heute keiner mehr sehen und Application.Title sieht auch niemand mehr. Wenn man also nur diese beiden Dinge zur Benachrichtigung verwendet, sehen viele Benutzer keine Indikation für einen laufenden Vorgang mehr.

Man kann natürlich nach "es tut nichts, dann tut es was" arbeiten, das wäre aber nicht der Standard den ich verfolge(n muss). Ich bin zwar wie gesagt in der Webentwicklung tätig, aber dafür sind unsere Kunden (mit Verlaub) besonders strohdoof. Da muss man sich um jede Indikation wirklich Gedanken machen... :?

jaenicke 6. Feb 2017 06:27

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von p80286 (Beitrag 1360858)
Das versteh' ich nicht!
Solange der Benutzer gut erkennen kann, das ein Programm etwas arbeitet ("es tut nichts, dann tut es was") ist alles gut.

Den Application.Title sieht man seit Windows 7 (standardmäßig) nur, wenn man mir der Maus über den Eintrag in der Taskleiste hält. Den Cursor sieht man nur sicher, wenn man die Maus über die Anwendung hält.

Dir einzige immer sichtbare Methode seit Windows 7 ist die Fortschrittsanzeige direkt auf dem Taskbar Eintrag.
(Selbst wenn man die Taskleiste mit der Anzeige der Titel überflutet, was man ja auch ab Windows 7 leider noch einstellen kann, ist das sichtbar.)

Es ist auch die einzige Methode, bei der man ohne zu lesen den Status sieht.

himitsu 6. Feb 2017 10:05

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von jaenicke (Beitrag 1360876)
Den Application.Title sieht man seit Windows 7 (standardmäßig) nur, wenn man mir der Maus über den Eintrag in der Taskleiste hält.

Oder wenn man wie ich, sofort nach der Windowsinstallation diese Titelanzeige aktiviert.

Zitat:

Zitat von jaenicke (Beitrag 1360876)
Den Cursor sieht man nur sicher, wenn man die Maus über die Anwendung hält.

Man kann zwar global im Windows den Cursor ändern, aber das wäre ja nicht nett.

jaenicke 6. Feb 2017 11:08

AW: Ich will die Sanduhr zurück!
 
Zitat:

Zitat von himitsu (Beitrag 1360883)
Oder wenn man wie ich, sofort nach der Windowsinstallation diese Titelanzeige aktiviert.

Die finde ich so überflüssig wie nur irgendetwas, da ich einfach nur arbeiten möchte und nicht auch noch dort Text lesen möchte. Aber so unterschiedlich sind eben die Arbeitsweisen. Als Entwickler sollte man auch alle diese Möglichkeiten unterstützen.

p80286 6. Feb 2017 12:59

AW: Ich will die Sanduhr zurück!
 
Erst einmal vielen Dank für die vielen Anregungen!
Da ich heute noch einmal bemerken durfte wie, unzuverlässig die Taskbar(Darstellung) ist, werde ich dies als Zweitmöglichkeit nutzen. Meine primäre Lösung wäre eine Progressbar oder etwas verwandtes auf dem Mainform.
hier hab ich noch etwas zur Taskbar aufgetan, falls sich jemand dafür interessiert.

Gruß
K-H

nahpets 6. Feb 2017 14:05

AW: Ich will die Sanduhr zurück!
 
Ungetestet, da nur grob abgekupfert:
Delphi-Quellcode:
procedure SetProgressBarOnPanel(stb : TStatusBar; pb : TProgressBar; iPanelNo : Integer);
var
          PanelRect       : TRect;
          ProgressBarStyle : LongInt;
begin
  if pb.Parent <> stb then pb.Parent := stb;
  ProgressBarStyle       := GetWindowLong(pb.Handle, GWL_EXSTYLE);
  ProgressBarStyle       := ProgressBarStyle - WS_EX_STATICEDGE;
  SetWindowLong(pb.Handle, GWL_EXSTYLE, ProgressBarStyle);
  SendMessage(stb.Handle, SB_GETRECT, iPanelNo, Integer(@PanelRect));
  pb.SetBounds(PanelRect.Left  + 1,
               PanelRect.Top   + 1,
               PanelRect.Right - PanelRect.Left - 2,
               PanelRect.Bottom - PanelRect.Top - 2);
end;
Damit müsste man eine Progressbar auf ein Panel einer Statusbar legen können, dabei gehe ich mal davon aus, dass die Statusbar mindestens 1 Panel hat.
Delphi-Quellcode:
type
  Tform1 = class(TForm)
    pb: TProgressBar;
    stb: TStatusBar;
...
// Im FormCreate oder so:
  SetProgressBarOnPanel(stb,pb,0);


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:27 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