AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Stringgrid Zelleninhalt verändern und speichern
Thema durchsuchen
Ansicht
Themen-Optionen

Stringgrid Zelleninhalt verändern und speichern

Ein Thema von vanilla · begonnen am 24. Apr 2007 · letzter Beitrag vom 24. Apr 2007
Antwort Antwort
vanilla

Registriert seit: 23. Mär 2007
44 Beiträge
 
Delphi 7 Professional
 
#1

Stringgrid Zelleninhalt verändern und speichern

  Alt 24. Apr 2007, 14:03
Datenbank: access • Version: 2000 • Zugriff über: ado
hallo leute,

ich lass mir eine zeile aus einer access tabelle in einer stinggrid ausgeben



Delphi-Quellcode:
procedure TForm1.getDBRow;
var
  a, column: Integer; //a ist counter

begin
    StringGrid1.EditorMode := true;

    getDBRowValue('BW', m_idNorm, m_idNAD);
    //ADODataSet1.Open;

    //Zeilenanzahl entspricht gleich der Spaltenanzahl im Grid
    StringGrid1.RowCount:=ADODataSet1.FieldCount+1;

    //Spaltenanzahl entspricht der Anzahl der Einträge (datasets, zeilen) im Grid
    StringGrid1.ColCount:=ADODataSet1.RecordCount+1;

    //Spaltennamen in die erste Zelle der Zeilen schreiben
    for a:=0 to ADODataSet1.FieldCount-1 do
       StringGrid1.Cells[0,a+1]:=ADODataSet1.Fields[a].FieldName; //Cells[spalte/zeile]

    //laden...

    ADODataSet1.First;

    column:=1;

    while not ADODataSet1.Eof do
    begin
        for a:=0 to ADODataSet1.FieldCount-1 do
          StringGrid1.Cells[column,a+1]:=ADODataSet1.Fields[a].DisplayText;
        ADODataSet1.Next;
        Inc(column);
    end;


end;
mit der folgenden methode färbe ich die zelle, in die gesprungen wird, rot an.


Delphi-Quellcode:

procedure TForm1.StringGrid1DrawCell(Sender: TObject; ACol,ARow: Integer; Rect: TRect; State: TGridDrawState);
var outRect : TRect; // Die Ausmaße der Zelle
    Text : String; // Der Inhalt der Zelle

begin
Text := StringGrid1.Cells[ACol, ARow]; // Holt sich den Text
outRect:=Rect; // Holt sich die Größe der Zelle

if (gdselected in state) then
StringGrid1.canvas.brush.color := clRed;
StringGrid1.Canvas.Fillrect(Rect); // markieren der Zelle

DrawText(StringGrid1.Canvas.Handle,PChar(Text),length(Text),outRect,DT_Left //=Linksbündig, DT_Center=Zentiert, DT_Right=Rechtsbündig
or DT_WordBreak); //=Umbruch, DT_SingleLine=ohne Umbruch

end;

nun möchte ich die Inhalte der Zellen verändern und diese direkt in die access datenbank speichern. goEditing ist auf true gesetzt. Ich glaube ich brauche eine funktion der überprüft in welchem feld der access tabelle ich mich genau befinde wenn ich eine bestimmte zelle im sgrid anklicke.

Weis nicht wie ich das anstellen soll :gruebel: Kann mir jemand helfen ??
  Mit Zitat antworten Zitat
Benutzerbild von DGL-luke
DGL-luke

Registriert seit: 1. Apr 2005
Ort: Bad Tölz
4.149 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Stringgrid Zelleninhalt verändern und speichern

  Alt 24. Apr 2007, 14:13
Hallo,

mit

StringGrid1.Cells[column,a+1]:=ADODataSet1.Fields[a].DisplayText; schreibst du aus der datenbank ins stringgrid. aus dem stringgrid in die datenbank geht wohl genau andersrum. in welchem feld du gerade bist, bekommst du über die Eigeschaften Delphi-Referenz durchsuchenRow und Delphi-Referenz durchsuchenCol des stringgrids.
Lukas Erlacher
Suche Grafiktablett. Spenden/Gebrauchtangebote willkommen.
Gotteskrieger gesucht!
For it is the chief characteristic of the religion of science that it works. - Isaac Asimov, Foundation I, Buch 1
  Mit Zitat antworten Zitat
vanilla

Registriert seit: 23. Mär 2007
44 Beiträge
 
Delphi 7 Professional
 
#3

Re: Stringgrid Zelleninhalt verändern und speichern

  Alt 24. Apr 2007, 14:54
okay danke,

ich versuch das gerade auszuprobieren, aber ich kann die Zellen nicht editieren. obwohl ich goediting und editormode auf true gesetzt habe. hast du ne idee was ich noch tun könnte ?

Delphi-Quellcode:
StringGrid1.Options := StringGrid1.Options + [goEditing];
StringGrid1.EditorMode := true;
  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 21:32 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