Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Anzeige der Daten im DBGrid zur Laufzeit ändern (https://www.delphipraxis.net/26361-anzeige-der-daten-im-dbgrid-zur-laufzeit-aendern.html)

kico 26. Jul 2004 11:21

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
@aschne1: also deine Lösung gefällt mir da am Besten. Wie ich ja auch schon in meiner Frage geschrieben habe brauche ich dieses "neue Feld" nur zur Visualisierung. Es sollen keine Daten in DB gespreichert werden - nur im DBgrid angezeigt werden (readonly).

Hab mal deinen Code in mein Query.CalcFields eingefügt, soweit so gut. Dann in meinem Feld editor das neue feld hinzugefügt und
bevor ich das dbgrid anzeige mein autocalcfield auf true gestellt. Leider sürzt mein programm ab sobald ich das dbgrid anzeigen lasse...

eddy 26. Jul 2004 12:40

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo kico,

vielleicht hilft Dir das weiter:

Code:
procedure TFBP.DBGridDrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
var
  Grid : TDBGrid;
  x, y : integer;
begin
  // selektierte Zeile wird original angezeigt
  if (gdSelected in State) or (gdFocused in State) then exit;
  // alle anderen Zeilen
  Grid:= TDBGrid(Sender);
  s := lowercase(Grid.Columns.Items[DataCol].FieldName);    // wenn man den Feldnamen verwendet
  // die Spalte "einheit" enthält ST, PR, ....
  // im Beispiel wird "ST" zu "Stück", "PR" zu "Paar",
  //   also kann man aus "0" auch "bestellt" machen
  // das funktioniert sowohl bei Feldern vom Typ ftString als auch vom Typ ftFloat  
  if s = 'einheit' then begin
    tx := Grid.DataSource.DataSet.FieldByName(s).AsVariant;
    x := rect.Left+12;
    y := rect.Top+2;
    if tx = 'ST' then Grid.Canvas.TextOut(x, y, 'Stück');
    if tx = 'PR' then Grid.Canvas.TextOut(x, y, 'Paar');
  end;
end;
Ganz perfekt ist das Ganze leider nicht, da ich nicht herausgefunden haben, wie man den
ursprünglichen Inhalt des Feldes unterdrücken kann. Der Fehler wird sichtbar, wenn man die
Spalte breit genug zieht. Dann steht links "Stück" und irgendwo rechts daneben das originale "ST"
(Problem siehe Bild)

Aber vielleicht weiß da ja auch noch jemand eine Lösung.

mfg
eddy

Memo 26. Jul 2004 13:06

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
Code:
procedure TForm1.Table1NrGetText(Sender: TField; var Text: String;
  DisplayText: Boolean);
begin
   case Table1Nr.AsInteger of
    0 : Text := 'geliefert';
    1 : Text := 'nicht gelefert';
   //..usw, usw
   end;
end;

eddy 26. Jul 2004 13:40

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
Hallo Memo,

ist ja noch besser.

Wie kann man diese Prozedure nutzen, ohne vorher im ObjectInspector die Felder der Tabelle als TField hinterlegen zu müssen?


mfg
eddy

Memo 26. Jul 2004 14:26

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
Zitat:

Zitat von eddy
ist ja noch besser.

Nun ja, ich erwähnte onGetText bereits im ersten Post.
Zitat:

Zitat von eddy
Wie kann man diese Prozedure nutzen, ohne vorher im ObjectInspector die Felder der Tabelle als TField hinterlegen zu müssen?

Ich verstehe jetzt zwar nicht was das mit der ursprünglichen Frage zu tun hat, aber TField läßt sich auch zur Laufzeit erzeugen. Warum sollte man den OI nicht bemühen?

aschne1 26. Jul 2004 15:11

Re: Anzeige der Daten im DBGrid zur Laufzeit ändern
 
Hallo kico

Hast Du beide Felder (Integerwert und BerechnetesFeld) in Deiner Abfrage hinzugefügt? Zur Kontrolle habe ich das Programm bei mir getestet und es funktioniert einwandfrei. Bitte füge die Felder mit dem Editor (Doppelclick auf die Abfrage) hinzu.

Im Beispiel greife ich über eine TADOConnection auf eine Accessdatenbank zu. Die Datasource des DBGrids ist mit einer TADODataSet verbunden, diese wiederum mit der TADOConnection.
Zur Illustration einmal ein Ausschnitt vom Interface-Teil

Delphi-Quellcode:
type
  TForm1 = class(TForm)
    ADOConnection: TADOConnection;
    query: TADODataSet;
    DBGrid: TDBGrid;
    queryIntegerwert: TIntegerField;              //Integerwert (Dein Datenbankfeld)
    DataSource: TDataSource;
    queryBerechnetesFeld: TStringField;           //Berechnetes Feld
    procedure queryCalcFields(DataSet: TDataSet); //
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;
Die Abfrage muss beim Starten aktiv sein!

Gutes Gelingen

mfg

Armin


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:51 Uhr.
Seite 2 von 2     12   

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