Einzelnen Beitrag anzeigen

marcus

Registriert seit: 13. Okt 2003
37 Beiträge
 
#12

Re: .... nochmals VirtualStringTree

  Alt 14. Okt 2004, 08:55
Sodala, funktioniert eigentlich schon ganz gut, bis auf das "füllen" der ChildNodes.
Hier mal der Code

Delphi-Quellcode:
type
PVSTData = ^TVSTData;
TVSTData = record
  monat: string;
  projektnr: string;
end;


procedure TFrmMain.InitForm;
var count : integer;
    strMonths : string;
    actMonth,actYear,foo : word;
    result : pmysql_res;
    row : pmysql_row;
    rowCount : my_ulonglong;
    rootNode,childNode : PVirtualNode;
    rootData,childData : PVSTData;
begin
  .
  .
  .

  StringTree.BeginUpdate;
  StringTree.NodeDataSize := SizeOf(PVSTData);

  for count := 1 to CMONTHS do
  begin
    rootNode := StringTree.AddChild(nil);
    rootData := StringTree.GetNodeData(rootNode);
    rootData^.monat := CboxMonth.Items.Strings[count - 1];

    Query('SELECT p_nummer FROM projekte WHERE (p_monat = '+inttostr(count)+')');
    result := mysql_store_result(SqlHnd);
    rowCount := mysql_num_rows(result);
    while (rowCount > 0) do
    begin
      row := mysql_fetch_row(result);
      childNode := StringTree.AddChild(rootNode);
      childData := StringTree.GetNodeData(childNode);
  --> childData^.projektnr := row[0];
      //showmessage(row[0]);
      dec(rowCount);
    end;
    mysql_free_result(result);
  end;
  StringTree.EndUpdate;
end;

Wenn die Zeile mit Pfeil auskommentiert wird dann funktioniert das ganze wunderbar. Es werden alle 12 Monate angelegt und für jeden Monat wird auch die richtige Anzahl an ChildNodes entsprechend den Projekten in dem jeweiligen Monat angelegt. Nur wenn ich die Projektnummer auch anzeigen möchte in dem VirtualStringTree, dann gibts eine AccessViolation. An dem MySQL Ergebnis liegt es nicht, denn die Nummer kann ich mir mit showmessage anzeigen lassen. Ich habe auch mal versucht in den gleichen Record zu schreiben (rootData), hat auch nicht funktioniert.

Marcus
  Mit Zitat antworten Zitat