Tiny Ore Diver

Hier könnt ihr euch selbst, eure Homepage, euren Entwicklerstammtisch, Termine oder eure Projekte vorstellen.
Forumsregeln
Bitte Präfixe benutzen. Das Präfix "[Projekt]" bewirkt die Aufnahme von Bildern aus den Beiträgen des Themenerstellers in den Showroom. Alle Bilder aus dem Thema Showroom erscheinen ebenfalls im Showroom auf der Frontpage. Es werden nur Bilder berücksichtigt, die entweder mit dem attachement- oder dem img-BBCode im Beitrag angezeigt werden.

Die Bildersammelfunktion muss manuell ausgeführt werden, die URL dazu und weitere Details zum Showroom sind hier zu finden.

This forum is primarily intended for German-language video game developers. Please don't post promotional information targeted at end users.
Benutzeravatar
TomasRiker
Beiträge: 96
Registriert: 18.07.2011, 11:45
Echter Name: David Scherfgen
Wohnort: Hildesheim

Re: Tiny Ore Diver

Beitrag von TomasRiker »

Jonathan hat geschrieben: 14.10.2024, 12:31 Ich sehe das größere Problem ehrlich gesagt in den Normalen / Tangenten. Die Bitmap ist ja nicht die Geometrie, sondern ein niedrigaufgelöstes Sampling der Geometrie. Betrachtet man die Bitmap als echte Geometrie aus Blöcken dann gibt es nur perfekt senkrechte und perfekt waagerechte Linien, keine Schrägen. Natürlich kann man diese Treppen mit Kugeln kollidieren lassen, aber das Verhalten wird vermutlich nicht das sein, was man erwartet.
Da könnte man eine 2D-Version von "Marching Cubes" implementieren. Marching Squares?
Benutzeravatar
Schrompf
Moderator
Beiträge: 5040
Registriert: 25.02.2009, 23:44
Benutzertext: Lernt nur selten dazu
Echter Name: Thomas
Wohnort: Dresden
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Schrompf »

Ja, heißt Marching Squares, und jetzt klingt ihr mit Euren Bedenken exakt wie der Box2D-Discord, der meine Fragen gar nicht erst zur Kenntnis genommen hat, sondern gleich meinte, ich solle es sein lassen.

Was die Kontaktnormalen angeht, wollte ich das wie bei meinem Survival-Voxel-Spiel damals machen: die 5x5-Umgebung zu ner Normale verwursten. Ich mach aber erstmal Kugel vs. Bitmap, und da hast Du ganz bequem die Kugel-Richtung als Normale. Für Kugeln >> 1px Radius wird das schon ordentlich funktionieren. Kritisch wird's später bei Bitmap vs. Bitmap - da kann man sich Grenzfälle ausdenken, wo jede Heuristik scheitert. Aber erstmal soweit sein und dann sehen wir weiter.
Früher mal Dreamworlds. Früher mal Open Asset Import Library. Heutzutage nur noch so rumwursteln.
Benutzeravatar
Jonathan
Establishment
Beiträge: 2543
Registriert: 04.08.2004, 20:06
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Jonathan »

TomasRiker hat geschrieben: 14.10.2024, 13:05 Da könnte man eine 2D-Version von "Marching Cubes" implementieren. Marching Squares?
Aber Marching Cubes hat doch als Eingabe ein Signed Distance Field, und das gibts hier doch nicht, oder?
Ich mach aber erstmal Kugel vs. Bitmap, und da hast Du ganz bequem die Kugel-Richtung als Normale. Für Kugeln >> 1px Radius wird das schon ordentlich funktionieren.
Ich bin da skeptisch. Habs mal eben aufgemalt:
2024-10-15_11-30-56_inkscape.png
Nicht exakt gezeichnet, aber die selbe Kugel triff immer die selbe Ecke von dem mittleren 2-er Steinchen zuerst. Ich nehme an, das meintest du - Kugel mit exakten Quadraten kollidieren lassen und dann annehmen, dass die Berührungsebene tangential zur Kugel liegt.
Für den selben Kontaktpunkt kannst du jetzt aber sehr unterschiedliche Richtungen rausbekommen, nämlich alles zwischen den zwei roten Linien. Das ist dann doch arg ungenau. In "Wirklichkeit" approximieren die grünen Quadrate aber die blau Linie, wie man sieht ist die korrekte Normale also ungefähr zwischen den zwei maximalen.

Hier wird es jetzt philosophisch, ob die grüne oder die blaue Geometrie die wahre ist. Die meisten Spieler werden aber intuitiv von der blauen ausgehen, nicht von der grünen. Wenn du hundert Bälle gegen diese grüne Wand prallen lässt, springt jeder in eine andere Richtung, auch wenn die Wand "glatt" ist.
Was die Kontaktnormalen angeht, wollte ich das wie bei meinem Survival-Voxel-Spiel damals machen: die 5x5-Umgebung zu ner Normale verwursten.
Das ist, denke ich, die richtige Lösung. Lokal an die Geometrie eine kontinuierliche Funktion fitten, deren Normale man dann an der Kontaktstelle exakt berechnen kann. So kannst du auch für Runde Objekte sehr glatte (im Sinne von differenzierbare) Normalen bekommen, und nicht nur Stückweis-Lineare Funktionen, bei denen die Normalen dann plötzlich springen, wenn man ein kleines bisschen anders aufkommt.
Lieber dumm fragen, als dumm bleiben!
https://jonathank.de/games/
Benutzeravatar
TomasRiker
Beiträge: 96
Registriert: 18.07.2011, 11:45
Echter Name: David Scherfgen
Wohnort: Hildesheim

Re: Tiny Ore Diver

Beitrag von TomasRiker »

Jonathan hat geschrieben: 15.10.2024, 10:35
TomasRiker hat geschrieben: 14.10.2024, 13:05 Da könnte man eine 2D-Version von "Marching Cubes" implementieren. Marching Squares?
Aber Marching Cubes hat doch als Eingabe ein Signed Distance Field, und das gibts hier doch nicht, oder?
Ja, stimmt. Ist nicht genau das gleiche. Die Idee dahinter wäre ähnlich. Man guckt sich an, welche der 4 Eckpunkte eines Quadrats 1 bzw. 0 sind, und erzeugt dann entsprechend Kanten.
Benutzeravatar
Schrompf
Moderator
Beiträge: 5040
Registriert: 25.02.2009, 23:44
Benutzertext: Lernt nur selten dazu
Echter Name: Thomas
Wohnort: Dresden
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Schrompf »

Marching Cubes war auch der Vorschlag der Box2D-Community, und nach meinem Wissen macht z.B. Noita das so. Anekdote am Rande: xq hatte mir erzählt, dass die jetzt ihr "FallingEverything"-Engine zur Lizenzierung anbieten. Ich hatte lange mit mir gerungen, ob ich das überhaupt will, aber bevor ich dann überhaupt mit Box2D und dem Kollisionsthema anfing, sendete ich ihnen doch erstmal ne Mail. Immerhin haben die ja all diese Probleme schon gelöst, nämlich mit Marching Squares und Konvex-Zerlegung, wie in dem dort verlinkten Video auch erklärt.

Leider haben sie nie geantwortet. Ist jetzt drei Wochen her oder so, da kommt also wohl nix mehr. Also hab ich selbst angefangen. Und bevor ich 64x pro Sekunde Marching Squares und Konkavkrieg betreibe, wollte ich doch erstmal gucken, ob ich nicht auch Pixel-Kollision in Box2D reingepatcht kriege. Würde ja reichen, wenn ich nur die bewegten Trümmerteile marchen und konvex zerlegen müsste.
Früher mal Dreamworlds. Früher mal Open Asset Import Library. Heutzutage nur noch so rumwursteln.
Benutzeravatar
Chromanoid
Moderator
Beiträge: 4273
Registriert: 16.10.2002, 19:39
Echter Name: Christian Kulenkampff
Wohnort: Lüneburg

Re: Tiny Ore Diver

Beitrag von Chromanoid »

Clonk hat das ganze glaube ich mit wenigen "Testpixeln" gelöst. Die sind dann die Eckpunkte der Gefährte. Das spielt vor allem bei den Loren eine Rolle. Es kann dabei natürlich passieren, dass man den Loren auf einen "Erdspieß" schiebt und die Testpixel links und rechts vom Erdspieß hängen. Dadurch dass Clonk von einem frickeligen Spielgefühl lebt, hat mich das nie gestört. Ich glaube bei den Ubooten in Clonk gibt es mindestens drei Testpunkte. Vielleicht reicht das ja? Ich bin mir allerdings nicht sicher, wie die auf der Basis eine Normale zum schieben der Objekte berechnen. Vermutlich einfach ein paar Lookups entlang der Bewegungsrichtung oder so.
antisteo
Establishment
Beiträge: 928
Registriert: 15.10.2010, 09:26
Wohnort: Dresdem

Re: Tiny Ore Diver

Beitrag von antisteo »

Chromanoid hat geschrieben: 15.10.2024, 12:47 Clonk hat das ganze glaube ich mit wenigen "Testpixeln" gelöst. Die sind dann die Eckpunkte der Gefährte. Das spielt vor allem bei den Loren eine Rolle. Es kann dabei natürlich passieren, dass man den Loren auf einen "Erdspieß" schiebt und die Testpixel links und rechts vom Erdspieß hängen. Dadurch dass Clonk von einem frickeligen Spielgefühl lebt, hat mich das nie gestört. Ich glaube bei den Ubooten in Clonk gibt es mindestens drei Testpunkte. Vielleicht reicht das ja? Ich bin mir allerdings nicht sicher, wie die auf der Basis eine Normale zum schieben der Objekte berechnen. Vermutlich einfach ein paar Lookups entlang der Bewegungsrichtung oder so.
Aber bei den U-Booten von Clonk ist man auch ständig in der Landschaft hängen geblieben. Ich hätte mir ein paar mehr Kollisionspunkte gewünscht (mindestens noch einen zweiten an der Unterseite

Ich bin da eher ein Freund von Kollisionsvolumen. Konkave Objekte werden einfach durch mehrere konvexe Hüllen beschrieben
http://fedoraproject.org/ <-- freies Betriebssystem
http://launix.de <-- kompetente Firma
In allen Posts ist das imo und das afaik inbegriffen.
Benutzeravatar
Jonathan
Establishment
Beiträge: 2543
Registriert: 04.08.2004, 20:06
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Jonathan »

Ich hab nochmal darüber nachgedacht, das Thema ist kompliziert und interessiert mich dann doch schon irgendwie:

These: Physiksimulation sollte so passieren, als ob die rote Linie hier die wahre Geometrie wäre:
2024-10-16_17-17-23_inkscape.png
Wie gesagt: Intuitiv denkt niemand, dass die Welt aus Blöcken besteht. Intuitiv denkt jeder, die Blöcke sind nur eine "schlechte" Annäherung an die Realität. Weil über mehrere Dekaden Computerspiele halt pixelig waren, aber immer schon kontinuierliche Flächen dargestellt haben. Vergleichbar mit schwarzen Linien um Comic-Charaktere: Die sind ein Artefakt der Darstellung (man braucht die um Flächen sauber abzugrenzen), kein Mensch denkt, dass alle Charaktere von einer Art schwarzen Öl-Films umgeben sind. Die Linien sind nicht Teil der Realität. Und die Inseln im Bild sind nicht eckig, sondern haben weiche Kurven, nämlich die roten Linien.

Das Bild oben ist aus Inkscape, aus der Bitmap wurde ein Pfadobjekt berechnet. Nicht überall perfekt, aber auch nicht so schlecht. Wie man sieht, hat man schöne, weiche Kanten an denen Kugelobjekte sehr schön und reibungsarm entlang gleiten könnten. Die Idee wäre also, eine solche kontinuierliche Linie aus den Pixel zu schätzen (eine handvoll Pixel samplen und darein nach einer festen Formel die Parameter für eine glatte Funktion (Spline, Polynom, etc.) zu fitten) und dann die Kollision damit zu machen. Nicht ganz billig, aber es gibt ja auch keine 1000 Objekte, selbst wenn man die Schnittteste numerisch macht und da 5-10 Schritte fürs Root-Finding in einem iterativen Solver braucht, ist das Performance-technisch kein Problem (solange man das für Spielobjekte benutzt und nicht für einzelne Sandpartikel).

Für eine Heightmap wäre das einfach und würde sicher gut funktionieren. Wie bei Splines mit stückweise lokalem Support braucht man nur ein paar Pixel anschauen, kann da (für jeden Test neu) sein Teil der Funktion dran fitten und den Schnitttest machen / die Normale berechnen. Aber hier hat man keine Heightmap sondern komplexe Geometrie. Im linken Block hat man an der rechten Hälfte etwa eine sehr steile, aber nicht senkrechte Kante. Was ich eigentlich nett finde. Aber: Dafür braucht man ja ein 10 Pixel Fenster.
Andererseits hat man in der Mitte zwischen den zwei Inseln nur 2 oder 3 Pixel freien Raum. Wenn man darauf besteht sich ein paar Nachbarpixel anzuschauen und dann eine Linie durchzulegen, wird man an dieser Stelle sehr schnell scheitern, und Spezialfälle wie diesen wird es dutzende geben. Bei derartiger Geometrie kann man die Normale dann also nicht wirklich lokal berechnen, sondern man müsste global die Form ausrechnen (z.B. ein Floodfill um alle Pixel der Außenkanten zu finden) und zwischenspeichern. Damit sollte man dann die meisten Sonderfälle recht gut und robust abdecken können.

Effektiv macht man dann also keine Kollision auf Pixelbasis mehr, sondern man rechnet sich seine Collisionshape vorher aus und speichert sie. Ähnlich zu der Idee, die Bitmap in konvexe Polygone zu zerlegen. Das schöne am lokalen Fit war aber, dass er sehr schnell geht und man ihn für jeden Test neu machen kann, aber wenn man es global macht, muss man in jedem Frame das ganze Level neu tracen (weil sich die Geometrie ja ständig ändern kann, soweit ich das verstanden habe).

Hoffe das war halbwegs verständlich, ich hatte jetzt keine Lust 5 mal so viel Text zu schreiben um alles detailliert zu erklären. Insgesamt ist das Problem aber wohl schwieriger als ich zunächst dachte :D
Lieber dumm fragen, als dumm bleiben!
https://jonathank.de/games/
Benutzeravatar
Schrompf
Moderator
Beiträge: 5040
Registriert: 25.02.2009, 23:44
Benutzertext: Lernt nur selten dazu
Echter Name: Thomas
Wohnort: Dresden
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Schrompf »

Tja, was soll ich sagen. Da gibt's viele Ansätze, und Du hast schon echt schön dargelegt, was dieser Ansatz gut kann und was Probleme machen wird. Ich bin bisher weiter stumpf auf Bitmasken fokussiert, und der Ansatz liefert dank moderner Speicherbandbreiten jetzt Ergebnisse in Nanosekunden:
screenshot0001.png
Dabei habe ich nochmal so richtig unter die Nase gerieben bekommen, dass mein Debug-Linien-Renderer genau einen Pixel vertikal daneben liegt. Dieser Pixelshiejt bringt mich noch um meine grauen Haare.
Früher mal Dreamworlds. Früher mal Open Asset Import Library. Heutzutage nur noch so rumwursteln.
Benutzeravatar
Jonathan
Establishment
Beiträge: 2543
Registriert: 04.08.2004, 20:06
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Jonathan »

Schrompf hat geschrieben: 17.10.2024, 22:22 Dabei habe ich nochmal so richtig unter die Nase gerieben bekommen, dass mein Debug-Linien-Renderer genau einen Pixel vertikal daneben liegt. Dieser Pixelshiejt bringt mich noch um meine grauen Haare.
Oh, wie damals als meine Terrain-Tessellierung Off-by-one war und die Flüsse an einer Seite dunkle Schatten hatte :D
Lieber dumm fragen, als dumm bleiben!
https://jonathank.de/games/
Benutzeravatar
Jonathan
Establishment
Beiträge: 2543
Registriert: 04.08.2004, 20:06
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Jonathan »

Schrompf hat geschrieben: 17.10.2024, 22:22Ich bin bisher weiter stumpf auf Bitmasken fokussiert,
Eh, ich meine, am Ende des Tages kann auch die schönste Theorie durch einen simplen Playtest widerlegt werden. Wenn die Kollision funktioniert und sich gut anfühlt, ist das Problem halt gelöst. Wäre nicht das erste mal dass ich sehe, wie ein "simpler Hack" viele andere Teile eines Projekte überleben kann, weil er doch zu gut funktioniert.
Lieber dumm fragen, als dumm bleiben!
https://jonathank.de/games/
Benutzeravatar
joeydee
Establishment
Beiträge: 1117
Registriert: 23.04.2003, 15:29
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von joeydee »

Schrompf hat geschrieben: 17.10.2024, 22:22 Dabei habe ich nochmal so richtig unter die Nase gerieben bekommen, dass mein Debug-Linien-Renderer genau einen Pixel vertikal daneben liegt.
Dein Debug-Linien-Renderer liegt genau einen Pixel vertikal daneben.

Nur um es nochmal erwähnt zu haben.
Benutzeravatar
Schrompf
Moderator
Beiträge: 5040
Registriert: 25.02.2009, 23:44
Benutzertext: Lernt nur selten dazu
Echter Name: Thomas
Wohnort: Dresden
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Schrompf »

joeydee hat geschrieben: 18.10.2024, 18:14
Schrompf hat geschrieben: 17.10.2024, 22:22 Dabei habe ich nochmal so richtig unter die Nase gerieben bekommen, dass mein Debug-Linien-Renderer genau einen Pixel vertikal daneben liegt.
Dein Debug-Linien-Renderer liegt genau einen Pixel vertikal daneben.

Nur um es nochmal erwähnt zu haben.
Hintern :-)
Früher mal Dreamworlds. Früher mal Open Asset Import Library. Heutzutage nur noch so rumwursteln.
Benutzeravatar
TomasRiker
Beiträge: 96
Registriert: 18.07.2011, 11:45
Echter Name: David Scherfgen
Wohnort: Hildesheim

Re: Tiny Ore Diver

Beitrag von TomasRiker »

Horizontal könnte man ja noch verstehen, aber vertikal?! :)
Benutzeravatar
Schrompf
Moderator
Beiträge: 5040
Registriert: 25.02.2009, 23:44
Benutzertext: Lernt nur selten dazu
Echter Name: Thomas
Wohnort: Dresden
Kontaktdaten:

Re: Tiny Ore Diver

Beitrag von Schrompf »

Oh, gibt viele Anlässe. Ich nehm ja noch DX9, und da ist (0,0) bei Rendertargets nicht etwa die äußerste Ecke des äußerten Pixels, sondern die Mitte des äußersten Pixels. Ich hab auch ein Nachziehen in der Bewegung, sprich manchmal sind's 2 Pixel Offset. Es ist ein Elend.

Teile davon könnte ich vermeiden, indem ich ENDLICH mal auf Vulkan wechsle, oder zumindest auf DX11.
Früher mal Dreamworlds. Früher mal Open Asset Import Library. Heutzutage nur noch so rumwursteln.
Antworten