Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt werden (https://www.delphipraxis.net/151965-wenn-das-faelligkeitsdatum-erreicht-ist-soll-zelle-im-stringgrid-rot-angezeigt-werden.html)

Waldow 7. Jun 2010 22:44


Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt werden
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo!
Ich habe in einem Stringgrid ein Rechnungsdatum und ein Fälligkeitsdatum stehen.
Wenn das Fälligkeitsdatum erreicht ist soll die Zelle rot angezeigt werden.

Mit meinem Code wird aber immer die ganze Spalte rot.
Was mache ich falsch?

Delphi-Quellcode:
procedure TFRechnung.AdvStringGrid3DrawCell(Sender: TObject; ACol,
  ARow: Integer; Rect: TRect; State: TGridDrawState);
var
  Datumrechnung, Datumrechungfaellig: TDate;
  I: Integer;
begin
  with (Sender as TAdvStringGrid) do
  begin
    for i := 1 to AdvStringGrid3.rowcount - 2 do begin
      Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, i]);
      Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, i]);
      if
        Datumrechungfaellig = Datumrechnung + 14 then
        AdvStringGrid3.Colors[11, i] := clred;
    end;
  end;
end;
Um mein Problem zu verdeutlichen sende ich eine Grafik mit.

Luckie 7. Jun 2010 23:45

AW: Im Stringgrid Datum vergleichen
 
Äh, was hat der Thementitel mit dem Problem zu tun? Offensichtlich schaffst du es doch schon die Daten zu vergleichen. Du darfst eben nur eine Zelle färben und nicht die ganze Zeile. Dazzu musst du eben gucken mit welcher Eigenschaft der Komponente du eine Zelle ansprichst. Ich kenne das AdvStringGrid nicht.

Sir Rufo 8. Jun 2010 00:42

AW: Im Stringgrid Datum vergleichen
 
Zumal wird beim Zeichnen einer jeden Zelle dein Code ausgeführt (schaue mal in allen Zeilen nach).

Die Methode gibt dir doch mit, welche Zelle jetzt gerade gezeichnet werden soll
Delphi-Quellcode:
ACol, ARow : Integer
Delphi-Quellcode:
if ACol = 11 then
  with TAdvStringGrid( Sender ) do
    begin
      Colors[ ACol, ARow ] := clRed;
    end;

Waldow 8. Jun 2010 00:58

AW: Im Stringgrid Datum vergleichen
 
Hallo und danke.
@Luckie: Habe den Titel geändert.
@Sir Rufo: Okay das färbt auch die ganze Spalte.
Wie muss ich das mit dem ausrechnen/anzeigen der Farbe in Kombination mit dem Datum machen?
Im ColumnHeader steht Wort "Datum" und "Fällig" ich dachte, dass ich deshalb mit
Delphi-Quellcode:
for i := 1 to AdvStringGrid3.rowcount - 2 do begin
      Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, i]);
      Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, i]);
arbeiten muss.

Sonst gibt Delphi Fehlermeldungen aus weil das Wort "Datum" kein gültiges Datum ist.

Gruss
Waldow

Luckie 8. Jun 2010 01:03

AW: Im Stringgrid Datum vergleichen
 
Zitat:

Zitat von Waldow (Beitrag 1026684)
@Luckie: steht doch in meinem ersten Post.

Ja, jetzt passt der Thementitel zum Problem. Vorher stand da was anderes.

rapante 8. Jun 2010 07:52

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Moin Waldow,

das müsste so (oder so ähnlich ;)) funktionieren:
(Bei deinem Ansatz würde er imho beim Zeichnen jeder Zelle immer alle Zeilen durchgehen)
Delphi-Quellcode:
if (ARow <> 0) and (ACol in [9,11]) then
begin
  Colors[ ACol, ARow ] := clRed;
end;

DonManfred 8. Jun 2010 14:04

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
GetCellColor ist dein Freund...

so ungefähr (schnell hier im editor geschrieben)...

Delphi-Quellcode:
procedure TFRechnung.AdvStringGrid3GetCellColor(Sender: TObject; ARow, ACol: Integer; AState: TGridDrawState; ABrush: TBrush; AFont: TFont);
var
  Datumrechnung, Datumrechungfaellig: TDate;
begin
  if odd(ARow) then begin
    abrush.color := $00E4E4E4;     // $00ECECF0
    afont.Color := clBlack;
  end else begin
    abrush.color := $00EEEEEE;
    afont.Color := clBlack;
  end;
  if ARow = 0 then begin
    abrush.Color := clBtnFace;
    afont.Color := clBlack;
  end;
  // Hier nun eine Prüfung ob die aktuelle Zelle anders gefärbt werden muss.
  // wenn ja, dann abrush und/oder afont entsprechend setzen...
  Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, i]);
  Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, i]);
  if Datumrechungfaellig = Datumrechnung + 14 then abrush.color := clred;
end;

Waldow 8. Jun 2010 14:39

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Hi DonManfred, danke für deine Hilfe!
Mit GetCellColor hatte ich auch schon etwas gemacht nur nicht weiter verfolgt.

Code:
Wenn ich kompiliere erhalte ich folgende Meldung:
---------------------------
Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt RG.exe ist eine Exception der Klasse EConvertError aufgetreten. Meldung: ''Datum' ist kein gültiges Datum'. Prozess wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzen.
---------------------------
OK  Hilfe  
---------------------------
Ich hatte so eine Meldung auch schon.
Sie hat bestimmt etwas mit dem ColumnHeader zu tun, steht "Datum" und "Fällig" drinnen.
Im FixedFooter steht "Gesamtsumme" usw.
Deshalb jetzt mein Versuch mit der Schleife.
Delphi-Quellcode:
  for i := 1 to AdvStringGrid3.rowcount - 2 do begin
    Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, i]);
    Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, i]);
    if Datumrechungfaellig = Datumrechnung + 14 then abrush.color := clred;
  end;
Aber dann wird wieder alles rot angezeigt.
Ist die Schleife unnötig?

[EDIT] Ich habe den Fehler gefunden. Ich hatte einen Denkfehler.
Es ist immer alles rot...es sind ja immer 14 Tage unterschied. Oh Mann!
Danke nochmal an ALLE!

Gruss Waldow

DonManfred 8. Jun 2010 14:48

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Natürlich ist sie unnötig in GetCellcolor. Die funktion bekommt ROW und COL übermittelt. du musst also NUR die Zeile ROW überprüfen... und das eigentlich auch nur, wenn COL die Spalte ist, die evtl. gefärbt werden soll.

Prinzipiell müsste das aber so gehen; evtl. hab ich da nen tippfehler drin oder so; ha das halt schnell im editor hier zusammengepastet...

Waldow 8. Jun 2010 15:36

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Hallo, wenn ich die Schleife rausnehme erhalte ich wieder die Fehlermeldung:

Code:
Im Projekt RG.exe ist eine Exception der Klasse EConvertError aufgetreten. Meldung: ''Datum' ist kein gültiges Datum'. Prozess wurde angehalten. Mit Einzelne Anweisung oder Start fortsetzen.
Das mit dem Datum und der Farbe wird immer noch nicht richtig angezeigt.

Delphi-Quellcode:
 jetzt := Now;
  for i := 1 to AdvStringGrid3.rowcount - 2 do begin
    Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, i]);
    Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, i]);
    Label5.Caption := Format('%d', [DaysBetween(StrToDate(AdvStringGrid3.Cells[9, i]), jetzt)]);
    if strtoint(Label5.Caption) > 14 then abrush.color := clred;
  end;
end;
Oder wie wird bei dir das i gefüllt?

taaktaak 8. Jun 2010 15:56

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Moin, Moin.
Nun, wenn du die Schleife entfernst, aber das i verwendest, dürfte i einen nicht gewollten Wert besitzen. Vermutlich muss für i jetzt Row eingesetzt werden - aber du solltest die gesamte Methode OnDrawCell() mal mit dem aktuellen Stand zeigen...

rapante 8. Jun 2010 18:10

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Hy,

Es wurde jetzt schon mehrfach darauf hingewiesen das eine Schleife an dieser Stelle unnötig ist.

Setz doch einfach mal einen Breakpoint in der procedure und sieh dir an wann diese aufgerufen wird
-> unzwar für jede Zelle 1 mal

Das heisst das du jedesmal wenn eine Zelle gezeichnet wird, in deiner Schleife das komplette Grid durch gehst!

Um die Fehlermeldung zu vermeiden, darfst du die erste Zeile(0) nicht mit verarbeiten:
Delphi-Quellcode:
procedure TFRechnung.AdvStringGrid3GetCellColor(Sender: TObject; ARow, ACol: Integer; AState: TGridDrawState; ABrush: TBrush; AFont: TFont);
var
  Datumrechnung, Datumrechungfaellig: TDate;
begin
  if ARow <> 0 then // Die Kopfzeile nicht prüfen
  begin
    Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, ARow]);
    Datumrechungfaellig := StrToDate(AdvStringGrid3.Cells[11, ARow]);
    if Datumrechungfaellig = Datumrechnung + 14 then
      ABrush.color := clred;
  end;
end;

Waldow 8. Jun 2010 19:10

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Hallo,
ich wußte es leider nicht besser aber das half:
Delphi-Quellcode:
if ARow <> 0 then
Da das AdvStrigGrid auch einen FloatingFooter hat muss ich jetzt nur noch die letzte Zeile herausfinden dann sollte es keine Fehler mehr geben
Danke für die tolle Hilfe und Geduld.

Gruss
Waldow

olaf 9. Jun 2010 08:25

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Hallo,

so funktioniert das mit TMS nie. Setze deinen Code unter GetCellColor.

procedure..
if ARow > 0 then //Spaltenüberschriften nicht mit einbeziehen
begin
if acol=1 then //Spalte mit deinem Rechnungsdatum
begin
if (AdvGrid1.cells[2], arow] =rdatum+14) then //Fälligkeitspalte
Color:=clred;
end;
end;


Die Spaltennummern mußt du selber anpassen. Ich denke das ist kein Problem.

Olaf

David Martens 10. Jun 2010 18:50

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Du kannst die Abfrage der Zeilennummer auch umgehen und mit TryStrToDate(const S: string; out Value: TDateTime): Boolean arbeiten. Gibt true zurück wenn in S ein "Datum" steht.

aber bei TMS gibt es auch

Delphi-Quellcode:
 
  AdvStringGrid1.FixedFooters
  AdvStringGrid1.FixedRows
  AdvStringGrid1.FixedCols
Das sind deine Start bzw. End-Spalten/Zeilen also:

Delphi-Quellcode:
if ARow > AdvStringGrid1.FixedRows then

Waldow 15. Jun 2010 10:14

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Danke, wie muss sich ich das mit dem FixedFooters machen um diese Reihe auszuschliessen?

Delphi-Quellcode:
if AdvStringGrid3.FixedFooters < 1
Damit funktioniert es nicht.

Gruss
waldow

rapante 15. Jun 2010 10:45

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Versuch es doch mal mit
Delphi-Quellcode:
if ARow < AdvStringGrid1.FixedFooters then

Waldow 15. Jun 2010 11:39

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Leider nicht, oder mache ich immer noch etwas falsch?
Delphi-Quellcode:
procedure TFRechnung.AdvStringGrid3GetCellColor(Sender: TObject; ARow,
  ACol: Integer; AState: TGridDrawState; ABrush: TBrush; AFont: TFont);
var
  Datumrechnung: TDate;
begin
  if ARow > 0 then
  begin
    if ARow < AdvStringGrid3.FixedFooters then
    begin
      if acol = 9 then
      begin
        Datumrechnung := StrToDate(AdvStringGrid3.Cells[9, Arow]);
        Label5.Caption := Format('%d', [DaysBetween(Datumrechnung, now)]);
        if strtoint(Label5.Caption) > 14 then abrush.color := clred;
      end;
    end;
  end;
end;
Gruss
Waldow

rapante 15. Jun 2010 11:45

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Welchen Wert hat denn FixedFooters?

Waldow 15. Jun 2010 11:55

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ich sende dir mal als Download eine Demo mit.

rapante 15. Jun 2010 12:02

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Ich kann' leider nich kompilieren,
aber so müsste es gehen

Delphi-Quellcode:
if ARow < ADVStringGrid3.RowCount - ADVStringGrid3.FixedFooters

Waldow 15. Jun 2010 13:20

AW: Wenn das Fälligkeitsdatum erreicht ist soll Zelle im Stringgrid rot angezeigt wer
 
Ja, es funktioniert nun 100%ig.
Dankeschön.


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