Einzelnen Beitrag anzeigen

TiGü

Registriert seit: 6. Apr 2011
Ort: Berlin
3.070 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: ListView im VirtualMode

  Alt 2. Nov 2017, 11:59
Sorry, aber selbst wenn man alle fehlenden Variablen ergänzt, kann das so nicht kompilieren.
Hast du das gerade kopiert oder abgetippt?

Wie ist die function Split definiert?
Ist das was selbst geschriebenes?

Du startest einen anonymen Thread und greifst auf VCL-Komponenten zu. Das ist schon mal grundsätzlich falsch. Sowas macht man nicht, dafür kommt man in die Programmierhölle!

Dein BeginUpdate der ListView ist richtig, aber du rufst EndUpdate innerhalb der Schleife auf. Das heißt, nach dem ersten Element hinzufügen hilft dir das nicht weiter.

Am Besten wäre es, wenn du uns anhand der eingehenden Daten erklärst, was du eigentlich machen möchtest. Ich vermute, man kann das alles einfacher und schneller lösen.
Vor allen mit der zweiten Schleife ist irgendwie unklar. Den StateIndex kannst du doch schon in der ersten Schleife setzen?

Ansonsten kannst du mal diese erste Verbesserung probieren:

Delphi-Quellcode:
var
  ListItem: TListItem;
  p: Integer;
  Strings, StringList: TStringList;
  FirstRun: Boolean;
  I: Integer;
  CurrentString: string;
  EntryString: string;
begin
  Strings := TStringList.Create;
  StringList := TStringList.Create;
  Strings.Text := MeinDatenString;

  Strings.BeginUpdate;
  StringList.BeginUpdate;
  ListView1.Items.BeginUpdate;
  try
    for I := 0 to Strings.Count - 1 do
    begin
      CurrentString := Strings.Strings[I];
      EntryString := Split(CurrentString, '|', 1);
      ListItem := ListView1.FindCaption(0, EntryString, False, True, False);

      if ListItem = nil then
      begin
        ListItem := ListView1.Items.Add;
        ListItem.Caption := EntryString;
        ListItem.SubItems.Add(Split(CurrentString, '|', 2));
        ListItem.SubItems.Add(Split(CurrentString, '|', 3));
        ListItem.SubItems.Add(Split(CurrentString, '|', 4));
        ListItem.SubItems.Add(Split(CurrentString, '|', 5));
        ListItem.SubItems.Add(Split(CurrentString, '|', 6));
      end
      else
      begin
        ListItem.StateIndex := 0;
        EntryString := Split(CurrentString, '|', 2);
        if ListItem.SubItems[0] <> EntryString then
          ListItem.SubItems[0] := EntryString;

        EntryString := Split(CurrentString, '|', 4);
        if ListItem.SubItems[2] <> EntryString then
          ListItem.SubItems[2] := EntryString;
      end;

      StringList.Add(ListItem.Caption);
    end;

    for I := ListView1.Items.Count - 1 downto 0 do
    begin
      ListItem := ListView1.Items[I];
      if ListItem.StateIndex = 2 then
      begin
        ListItem.Delete;
        Continue;
      end;

      p := StringList.IndexOf(ListItem.Caption);
      if p = -1 then
        ListItem.StateIndex := 2;
    end;

    FirstRun := False;
    ListView1.Refresh;
  finally
    ListView1.Items.EndUpdate;
    StringList.EndUpdate;
    Strings.EndUpdate;
    StringList.Free;
    Strings.Free;
  end;
end;
  Mit Zitat antworten Zitat