AGB  ·  Datenschutz  ·  Impressum  







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

Fehlersuche: Canvas

Ein Thema von ghostnw · begonnen am 5. Feb 2009 · letzter Beitrag vom 5. Feb 2009
Antwort Antwort
ghostnw

Registriert seit: 14. Jan 2008
7 Beiträge
 
#1

Fehlersuche: Canvas

  Alt 5. Feb 2009, 16:59
Hallo!

Ich bin relativ ratlos, warum ein kleiner Programmcode, den ich geschrieben habe, sich so verhält. Ich hoffe, ihr könnt mir helfen.
Undzwar habe ich mir zum Ziel gesetzt, eine möglichst reale Bewegung von Objekten zu simulieren. (Das heißt, das Programm soll die Wurfparabeln und die elastischen Stöße berechnen)
Ich habe also einen Timer genommen, und lasse die neuen Positionen immer neu berechnen und mit Canvas zeichnen.
Der Anfang sieht relativ realistisch aus, jedoch nach ca. 8 Sekunden passieren unerwartete Bewegungen,die ich mir nicht erklären kann, bzw. verschwinden auch einfach manche Kreise ganz.

Wenn ihr den Code compiliert, seht ihr sofort, was ich meine, ihr braucht nichts extra einstellen.

Liebe Grüße,
ghostnw
Angehängte Dateien
Dateityp: zip reale_bewegungen_145.zip (167,6 KB, 7x aufgerufen)
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Fehlersuche: Canvas

  Alt 5. Feb 2009, 17:05
Du braucsht das Image nur einmal zu löschen. Nicht bei jedem Schliefendurchlauf.
Delphi-Quellcode:
with Image1.Canvas do begin
 Rectangle(0,0,Image1.Width, Image1.Height); //hier reicht
 for i := 1 to maxObjects do begin
 vx[i] := vx[i];
 vy[i] := vy[i] + g*T ;
 sx[i] := sx[i] + vx[i]*T;
 sy[i] := sy[i] + vy[i]*T;
 Ellipse(ceil(sx[i]-r[i]),ceil(sy[i]-r[i]), ceil(sx[i]+r[i]), ceil(sy[i]+r[i]));
 end;
 end;

 for i := 1 to maxObjects-1 do begin
  for j := i+1 to maxObjects do begin
   if Power((r[i]+r[j]),2) > power((sx[i]-sx[j]),2)+power((sy[i]-sy[j]),2) then
    begin
    vx1 := vx[i];
    vx2 := vx[j];
    vy1 := vy[i];
    vy2 := vy[j];
    vx[i] := k*(2*m[j]*vx2+(m[i]-m[j])*vx1)/(m[i]+m[j]);
    vx[j] := k*(2*m[i]*vx1+(m[j]-m[i])*vx2)/(m[j]+m[i]);
    vy[i] := k*(2*m[j]*vy2+(m[i]-m[j])*vy1)/(m[i]+m[j]);
    vy[j] := k*(2*m[i]*vy1+(m[j]-m[i])*vy2)/(m[j]+m[i]);
    sx[i] := sx[i] + vx[i]*T;
    sx[j] := sx[j] + vx[j]*T;
    with Image1.Canvas do begin
    //weg mit dem Rechteck
    //Rectangle(0,0,Image1.Width, Image1.Height);
    Ellipse(ceil(sx[i]-r[i]),ceil(sy[i]-r[i]), ceil(sx[i]+r[i]), ceil(sy[i]+r[i]));
    Ellipse(ceil(sx[j]-r[j]),ceil(sy[j]-r[j]), ceil(sx[j]+r[j]), ceil(sy[j]+r[j]));
    end;

    end;
   end;
  end;

  for i := 1 to maxObjects do begin
   if sy[i]+r[i] >= Image1.Height then begin
    vx[i] := vx[i];
    vy[i] := -k*vy[i] + g*T;
    sy[i] := sy[i] + vy[i]*T;
    sx[i] := sx[i] + vx[i]*T;
    if sy[i] + r[i] > Image1.Height then begin
     sy[i] := Image1.Height - r[i];
    end;
    with Image1.Canvas do begin
    //und das hier auch
    //Rectangle(0,0,Image1.Width, Image1.Height);
    Ellipse(ceil(sx[i]-r[i]),ceil(sy[i]-r[i]), ceil(sx[i]+r[i]), ceil(sy[i]+r[i]));
    end;
   end;
  end;

end;
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  Mit Zitat antworten Zitat
ghostnw

Registriert seit: 14. Jan 2008
7 Beiträge
 
#3

Re: Fehlersuche: Canvas

  Alt 5. Feb 2009, 17:12
Achja, so ein Mist... da hätt ich auch selbst draufkommen können. Danke dir =)
  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 23:29 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