AGB  ·  Datenschutz  ·  Impressum  







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

DBGrid -> Mehrere Zeilen farblich

Ein Thema von HolgerCW · begonnen am 13. Nov 2009 · letzter Beitrag vom 13. Nov 2009
Antwort Antwort
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#1

DBGrid -> Mehrere Zeilen farblich

  Alt 13. Nov 2009, 09:02
Hallo zusammen,

ich möchte in meinem DBGrid die Zeilen farblich machen, welche alle das Datum der selektierten Zeile beinhalten.

So habe ich es versucht:

Hier wird das Datum der selektierten Zeile in eine Globale Variabel geschrieben:
Delphi-Quellcode:
procedure TDM_Query_UP.DS1DataChange(Sender: TObject; Field: TField);
begin

 Arbeitsplan_Datum_Selektiert := '';
 
 if DM_Query_UP.Query1.isempty then exit;

 Arbeitsplan_Datum_Selektiert := datetostr(DM_Query_UP.Query1['DATUM']);
 
end;
Hier wird dann das ganze farblich gemacht:
Delphi-Quellcode:
procedure TForm1.DBG1DrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin

 if DM_Query_UP.Query1.isempty then exit;

 DBG1.Canvas.Brush.Color := clGradientInactiveCaption;
 DBG1.DefaultDrawColumnCell(Rect, DataCol, Column, State);
 
 if (datetostr(DM_Query_UP.Query1['DATUM']) = Arbeitsplan_Datum_Selektiert) then
 begin

  DBG1.Canvas.Brush.Color := clInfoBK;
  DBG1.DefaultDrawColumnCell(Rect, DataCol, Column, State);

 end;

end;
Wenn ich nun die verschiedenen Zeilen selektiere werden die Zeilen nicht richtig farblich gezeichnet.

Führe ich nach dem selektieren ein Refresh der Query1 durch klappt es.

Wie kann ich nun meinen Code verbessern, das es klappt oder wo könnte ich den Refresh implementieren ?

Gruss

Holger
  Mit Zitat antworten Zitat
Benutzerbild von stahli
stahli

Registriert seit: 26. Nov 2003
Ort: Halle/Saale
4.336 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: DBGrid -> Mehrere Zeilen farblich

  Alt 13. Nov 2009, 11:38
Hallo Holger,

wenn ich Dich richtig verstehe, willst Du auf den aktuellen Datensatz abgleichen...?

Ich habe mal einen alten Auszug von mir herausgekramt:
Delphi-Quellcode:
procedure TFormAw.DBGridSchuldnerDrawColumnCell(Sender: TObject;
  const Rect: TRect; DataCol: Integer; Column: TColumn;
  State: TGridDrawState);
var FaelligFlag:Boolean;
begin
  if (Sender is TDBGrid) then with (Sender as TDBGrid) do begin
    FaelligFlag:=False;
    if Assigned(Column.Field) then begin
      if (Column.Field.DataSet.FindField('Faellig')<>nil) then begin
        FaelligFlag:=(((Column.Field.DataSet.FieldByName('Faellig').AsDateTime<=Date) or (Column.Field.DataSet.FieldByName('Faellig').AsString='31.12.9999')) and (Column.Field.DataSet.FieldByName('Faellig').AsString<>''));
      end;
    end;
    if (not FaelligFlag) then begin
      Canvas.Font.Color:=clSilver;
      if (Copy(Column.Title.Caption,1,3)='OFF') then begin
        if (Column.Title.Caption='OFFBETR') then Canvas.Font.Style:=[fsBold];
        if (Column.Field.DataSet.FieldByName(Column.Title.Caption).AsFloat<0) then Canvas.Font.Color:=clGreen;
      end;
      if (Canvas.Brush.Color=clHighlight) then Canvas.Brush.Color:=$00FEF8F5;
      DefaultDrawColumnCell(Rect,DataCol,Column,State);
    end
    else begin
      Canvas.Font.Color:=clBlack;
      if (Column.Title.Caption='FAELLIG') then Canvas.Brush.Color:=$00B3B3FF;
      if (Copy(Column.Title.Caption,1,3)='OFF') then begin
        if (Column.Title.Caption='OFFBETR') then Canvas.Font.Style:=[fsBold];
        if (Column.Field.DataSet.FieldByName(Column.Title.Caption).AsFloat<0) then Canvas.Font.Color:=clGreen
        else
        if (Column.Field.DataSet.FieldByName(Column.Title.Caption).AsFloat>0) then Canvas.Font.Color:=clRed;
      end;
      if (Canvas.Brush.Color=clHighlight) then Canvas.Brush.Color:=$00FEF8F5
      DefaultDrawColumnCell(Rect,DataCol,Column,State);
    end;
  end;
end;
Ich bin nicht ganz sicher, aber vielleicht musst Du über Column.Field.DataSet.FieldByName(xxx) auf Deine Zellenwerte abgleichen.

Stahli
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.429 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: DBGrid -> Mehrere Zeilen farblich

  Alt 13. Nov 2009, 11:57
@HolgerCW
Im DS1DataChange das Grid informieren, daß die Darstellung nicht mehr aktuell ist.
FForm1.DBG1.Invalidate;
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#4

Re: DBGrid -> Mehrere Zeilen farblich

  Alt 13. Nov 2009, 13:40
Das klappt super mit dem Invalidate

Danke

Holger
  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 12:51 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