AGB  ·  Datenschutz  ·  Impressum  







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

Überforderte For-Schleife oder was?

Ein Thema von Andreas L. · begonnen am 5. Aug 2004 · letzter Beitrag vom 6. Aug 2004
Antwort Antwort
Andreas L.
(Gast)

n/a Beiträge
 
#1

Überforderte For-Schleife oder was?

  Alt 5. Aug 2004, 14:33
Hi,
ich lasse mit folgender Procedure einen Ordner einlesen. Es wird ein Datei-Filter verwendet:

Delphi-Quellcode:
procedure GetAllFilesEM(Path, ExtMask: String; List: TStrings;
  SubFolder: Boolean);
var
  Attrib, k: Integer;
  Search: TSearchRec;
begin
  Attrib := faArchive + faReadOnly + faHidden;

  if Path[Length(Path)] <> '\then Path := Path + '\';

  with TStringList.Create do
  try
    CommaText := ExtMask;

    for k := 0 to Count - 1 do
    if FindFirst(Path + '*.' + Strings[k], Attrib, Search) = 0 then
      repeat
        List.Add(AnsiUpperCase(Path + Search.Name));
      until FindNext(Search) <> 0;

    FindClose(Search);
  finally Free end;

  if SubFolder then
  begin
    if FindFirst(Path + '*.*', faDirectory, Search) = 0 then
    begin
      repeat
        if ((Search.Attr and faDirectory) = faDirectory) and
          (Search.Name[1] <> '.') then
          GetAllFilesEM(Path + Search.Name, ExtMask, List, SubFolder);
      until FindNext(Search) <> 0;

      FindClose(Search);
    end;
  end;
end;
Der Aufruf:
Delphi-Quellcode:
procedure TForm4.Button1Click(Sender: TObject);
begin
 if jvdirectoryedit1.text='then
  begin
   ShowMessage('Bitte einen Grafikordner angeben!');
  end
   else
    if SpinEdit1.Text='0then
     begin
      ShowMessage('Der Interval muss min. 1 Sekunde betragen!');
     end
    else
     begin
     form1.timer1.interval:=strtoint(spinedit1.Text + '000'); //000 dazu zählen da angabe in milisekunden und nicht in sekunden
     GetAllFilesEM(jvdirectoryedit1.Text, 'bmp, gif, jpg, ico, jpeg, png', form1.ListBox1.Items, false); //dateien einlesen
     form1.timer1.enabled:=true;
     close;
     end;
end;
Das alles geschieht auf form4. die ganzen dateinamen werden in eine listbox auf form1 geladen, dies funktioniert auch.

Wenn ich nun folgende Procedure ausführe dauert es etwas und das Programm stürzt ab, ohne Meldungen...

Delphi-Quellcode:
procedure TForm1.Timer1Timer(Sender: TObject);
var
 i : Integer;
begin
  for i:=0 to Listbox1.Count-1 do
   begin
    Image1.Picture.LoadFromFile(listbox1.Items.Strings[i]);
   end;
end;
Wo liegt mein fehler?

Greetz und thx
  Mit Zitat antworten Zitat
Benutzerbild von leddl
leddl

Registriert seit: 13. Okt 2003
Ort: Künzelsau
1.613 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Überforderte For-Schleife oder was?

  Alt 5. Aug 2004, 15:00
Wenn ich das richtig verstehe, willst du so ne Art Diashow machen, richtig?

Kanns mir nich hundertprozentig erklären, aber denke, der Fehler könnte daran liegen, daß du bei jedem Aufruf von onTimer ALLE (Also z.B jede Sekunde ALLE Bilder nacheinander. Das macht dann bei 10 Bildern schon 1 Bild alle 100ms) Bilder nacheinander darstellst. Warhscheinlich kommt da Delphi nicht mit. Aber warum das Programm ohne Fehlermeldung abstürzt?! Kein Plan!
Versuchs evtl mal über nen Zähler, der bei jedem Aufruf von onTimer hochgezählt wird. Und dann schreibst du eben
Image1.Picture.LoadFromFile(listbox1.Items.Strings[counter]); Ohne die For-Schleife.

Vielleicht geht das an dem vorbei, was du willst. Vielleicht willst du ja ALLE Bilder jede Sekunde (oder eben alle 2,3,... Sekunden, je nach Angabe) nacheinander durchlaufen. Aber das is jetzt das einzige, was mir direkt aufgefallen is.

Werds jetzt gleich bei mir mal ausprobieren obs klappt.

//Edit:
Was mir grad aufgefallen is: Die Anweisung
if Path[Length(Path)] <> '\then Path := Path + '\'; kannst dir einfacher gestalten. Dafür gibts
Path := IncludeTrailingPathDelimiter[Path]; Mann, bin ich doof! Is doch klar, warum das "abstürzt"! Du hast ja "close" geschrieben. Und Delphi wartet net, bis dein Timer alle Bilder durchlaufen hat. Mach mal das close im ButtonClick weg und schreib die TimerFunktion um wie folgt:
Delphi-Quellcode:
procedure TForm1.Timer1Timer(Sender: TObject);
Begin
  If Counter <= ListBox1.Items.Count - 1 Then
  Begin
    Form1.Caption := IntToStr(Counter);
    Image1.Picture.LoadFromFile(listbox1.Items.Strings[Counter]);
    inc(Counter);
  End
  Else
  Begin
    Timer1.Enabled := false;
    close;
  End;
End;
Den Counter würd ich mir global deklarieren und vor dem Setzen von Enabled auf true auch bitte auf 0 setzten. Ich weiß, da ham manche Probleme mit, ich würds aber trotzdem machen. Kannst aber theoretisch auch den Timer1.Tag dafür benutzen.

Ach ja: Ich bekomm beim Laden von JPGs und GIFs ne Fehlermeldung. Hab noch nie zur Laufzeit Bilder in ne TImage geladen, deswegen kenn ich mich damit nich aus. Aber kanns sein, daß man solche Bilder erst in BMP umwandeln muß?
Naja, aber mit BMPs gehts bei mir jetzt.
Axel Sefranek
  Mit Zitat antworten Zitat
Andreas L.
(Gast)

n/a Beiträge
 
#3

Re: Überforderte For-Schleife oder was?

  Alt 6. Aug 2004, 11:07
Zitat:
Den Counter würd ich mir global deklarieren und vor dem Setzen von Enabled auf true auch bitte auf 0 setzten.
Wie jetzt?
  Mit Zitat antworten Zitat
Benutzerbild von leddl
leddl

Registriert seit: 13. Okt 2003
Ort: Künzelsau
1.613 Beiträge
 
Delphi 2006 Professional
 
#4

Re: Überforderte For-Schleife oder was?

  Alt 6. Aug 2004, 11:22
Ok, sorry. Nochmal ganz langsam. Hab mich selbst in Rage geschrieben!

Du kannst wählen, wie dus machen willst. Entweder du deklarierst dir ne globale Variable (Mögen manchen nicht, deswegen die Alternative) oder du benutzt einfach den Timer1.Tag.

1) Du deklarierst dir die globale Variable (zb Counter) als Integer und setzt sie im Button4Click VOR Zeile 14 auf 0.
Dann schreibst du deinen Timer um, wie ichs geschrieben hab.

2) Wenn dir die globale Variable nich gefällt, dann benutzt du, wie gesagt, den Timer1.Tag. Das läuft eigentlich analog. Um eventuelle Wiederholungen möglich zu machen (dafür müßtest du aber das close im Timer weglassen) solltest du auch hier den Tag vor dem enablen des Timers auf 0 setzen.
Ansonsten überall "Counter" durch "Timer1.Tag" ersetzen.
Ausnahme: inc(counter)! Bin mir nich sicher, ob inc(Timer1.Tag) funktioniert. Evtl mußt du da Timer1.Tag := Timer1.Tag + 1 schreiben.
Axel Sefranek
  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 02:44 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