![]() |
Re: Pong - Problem bei der Ballkollision
Ja hab eben schonmal kurz gegooglet, aber nich wirklich ansprechende Sachen gefunden, aber wenn ich da mal laenger suche finde ihc sicher was!
Mal sehn ob ich damit klar komme, Mathe is eigentlich nich wirklich eins meiner Probleme ^^ (Auch wenn sich das fuer mich grad alles mega kompliziert darstellt :P) Danke vielmals für eure Hilfe!!! |
Re: Pong - Problem bei der Ballkollision
dafür ist die DP ja da.
Ich hab da auch irgendwo für die Physik engine ne Mega Mathe unit die könnte ich dir auch mal zukommen lassen wenn du willst. |
Re: Pong - Problem bei der Ballkollision
@ Corpsman: Wenn ich mich nicht irre, behandelst du das quadratische Hindernis in der Kollisionsabfrage doch wie einen Kreis. Denn die Kugeln prallen ja z.B. nicht von den Ecken ab.
@ Chicken: Wo liegt jetzt eig. dein Problem? Weißt du jetzt, wie du prüfst, ob die Kugel kollidiert und wo? Falls du Probleme damit hast, wie sich die Kugel verhält, wenn sie auf eine Ecke prallt, ist hier ein kurzer Code, der das löst (aus nem kleinen Billard-Spiel von mir, als ich die Kollisionen fertig hatte, hatte ich allerdings keine Motivation mehr weiter zu machen :oops: ):
Delphi-Quellcode:
Als Parameter werden die Koordinaten der Ecke übergeben, mit der kollidiert wird. BallRadius ist der Radius des Balles, der mit der Ecke kollidiert, FXSpeed und FYSpeed ergeben seine Geschwindigkeit, FXPos und FYPos sind die Koordinaten des Mittelpunktes des Balles.
procedure TBall.CollideWith(PointX, PointY: Extended);
var TotalDist: Extended; XDist: Extended; YDist: Extended; begin XDist := FXPos - PX; YDist := FYPos - PY; TotalDist := Hypot(XDist, YDist); FXPos := FXPos + (BallRadius / TotalDist - 1) * XDist; FYPos := FYPos + (BallRadius / TotalDist - 1) * YDist; FXSpeed := 2 * YDist * (FXSpeed * YDist - FYSpeed * XDist) / Sqr(TotalDist) - FXSpeed; FYSpeed := 2 * XDist * (FYSpeed * XDist - FXSpeed * YDist) / Sqr(TotalDist) - FYSpeed; end; |
Re: Pong - Problem bei der Ballkollision
@Cöster
lol, In dem Code ist aber schon noch irgendwo eine Prüfung drin ob du die Ecke überhaupt berührst ? Und eigentlich dachte ich nicht das ich das Rechteck als Kreis drin habe. Der Code ist aber acuh schon ein bischen alt. |
Re: Pong - Problem bei der Ballkollision
Zitat:
Delphi-Quellcode:
Edges ist ein Konstanten-Array, in dem die Ecken gelagert sind.
if Hypot(FXPos - Edges[I].X, FYPos - Edges[I].Y) < BallRadius then
Zitat:
|
Re: Pong - Problem bei der Ballkollision
Mein eigentliches Problem liegt darin, dass ich die Sinus und Cosinus und Tangens bzw ArcTanges Funktionsweisen nicht kenne. Ich könnte nun zwar den Code von Corpsman einfach kopieren, haette ich aber nichts von! ;-)
Ich glaub deine Mathe Datei hilft mir da nicht wirklich weiter Corpsman, trotzdem danke, ein Tutorial in (ja was is das eigentlich? Trigonometrie oder Vektorrechnung oder einfach Geometrie?), waere sicher hilfreicher ich muss da mal suchen... MfG BTW: Kannst du deine ArcTangens Funktion vielleicht nochmal erlaeutern?
Delphi-Quellcode:
Function arcTangens(x, y: Extended): Extended;
Begin Result := 0; If (x = 0) Then Begin If (Y >= 0) Then result := 90; If (Y < 0) Then result := 270; End Else Begin result := radtodeg(arctan(Y / X)); If ((X < 0) And (y > 0)) Or ((x < 0) And (Y <= 0)) Then result := 180 + result; If (X > 0) And (Y < 0) Then result := 360 + result; End; End; Und wenn wer ne gute Seite im Internet zu Sinus und son Kram hat dann sagt sie mir doch bitte, hab nicih viel brauchbares gefunden, wiipedia.de hat mir zB irgendwie ueberhaupt nich geholfen ^^ |
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:22 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz