Game Engine in C: Unterschied zwischen den Versionen
Fake (Diskussion | Beiträge) K (wrong category) |
HKay (Diskussion | Beiträge) (How it should have been) |
||
(2 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
==Idee== |
==Idee== |
||
Um Wissensdurstigen einen Einblick in die fortgeschrittene C Programmierung zu geben wird die [http://de.wikipedia.org/wiki/Quake_III_Arena Tech 3] Gameengine von idsoftware weiterentwickelt. An Hand des Open Source Projekts [http://ioquake3.org/ ioquake3] werden die Teilnehmer in die praktische C-Programmierung abseits der Schulbuecher eingefuehrt. Der im Workshop |
Um Wissensdurstigen einen Einblick in die fortgeschrittene C Programmierung zu geben wird die [http://de.wikipedia.org/wiki/Quake_III_Arena Tech 3] Gameengine von idsoftware weiterentwickelt. An Hand des Open Source Projekts [http://ioquake3.org/ ioquake3] werden die Teilnehmer in die praktische C-Programmierung abseits der Schulbuecher eingefuehrt. Der im Workshop gezeigte Code wird produktiv eingesetzt. [http://www.q3df.org/] |
||
==Zielgruppe== |
|||
* Neulinge in der C-Programmierung |
|||
==Todo-Liste== |
==Todo-Liste== |
||
* Existierenden Code |
* Existierenden Code aufräumen |
||
* Konzept für verschiedene Ebenen des Anspruchs erstellen |
* Konzept für verschiedene Ebenen des Anspruchs erstellen |
||
==Verantwortlich== |
==Verantwortlich== |
||
* Daniel "hk" Steuer |
* Daniel "hk" Steuer |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
===Kommunikation=== |
===Kommunikation=== |
||
Der ID Tech 3 Engine behandelt jedes geladene Spiel als ein Modul. Dieses Modul liegt üblicherweise als Bytecode vor und ist daher kompatibel zu sämtlichen Plattformen. Die Kommunikation zwischen dem ClientServer, welcher die eingehenden Daten für die Virtuelle Maschine (VM) aufbereitet überträgt diese mit sog. "Syscalls" zur VM. Die Kommunikation zwischen VM und Server läuft ausschließlich über Syscalls. Zwischen dem ClientServer und dem Server auf dem das eigentliche Spiel läuft wird wahlweise eine IPX oder eine UDP verbindung aufgebaut. |
Der ID Tech 3 Engine behandelt jedes geladene Spiel als ein Modul. Dieses Modul liegt üblicherweise als Bytecode vor und ist daher kompatibel zu sämtlichen Plattformen. Die Kommunikation zwischen dem ClientServer, welcher die eingehenden Daten für die Virtuelle Maschine (VM) aufbereitet überträgt diese mit sog. "Syscalls" zur VM. Die Kommunikation zwischen VM und Server läuft ausschließlich über Syscalls. Zwischen dem ClientServer und dem Server auf dem das eigentliche Spiel läuft wird wahlweise eine IPX oder eine UDP verbindung aufgebaut. |
||
Zeile 18: | Zeile 28: | ||
'''ClientVM''' <-syscall-> '''ClientServer''' <--IP--> '''Server''' <-syscall-> '''ServerVM''' |
'''ClientVM''' <-syscall-> '''ClientServer''' <--IP--> '''Server''' <-syscall-> '''ServerVM''' |
||
===Eigenheiten=== |
===Eigenheiten=== |
||
* Der |
* Der gesamte Engine ist vollständig SingleThreaded. Das bedeutet, dass innerhalb des Spiels niemals zwei Dinge gleichzeitig berechnet werden, was gewaltige Vorteile bei der Speicherverwaltung mit sich bringt. |
||
* Die mathematischen Optimierungen für häufige Berechnungen sind sehr tiefgreifend und führen zu nur für C-Liebhaber gut lesbaren Quellcode. |
* Die mathematischen Optimierungen für häufige Berechnungen sind sehr tiefgreifend und führen in den untiefen der math.c zu nur für C-Liebhaber gut lesbaren Quellcode. |
||
==Lehrinhalt== |
==Lehrinhalt== |
||
* Die Furcht vor Strukturen und Zeigern ablegen. |
|||
* Abfangen und Manipulieren von Syscalls zwischen VM und Server (transparenter Proxy) |
|||
* Die Furcht vor Bit-Operationen ablegen. |
|||
* Erzeugen von Modulen die zur Laufzeit ge- und enladen werden können |
|||
* Schreiben einer einfachen Modifikation fuer ioquake3. |
|||
* Erzeugung und Benutzung von Threads |
|||
* Erstellen einer Datenbankschnittstelle (MySQL) |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
* Die im Vortrag demonstrierte Mod [http://gungame.kexe.org/] |
|||
Aktuelle Version vom 26. September 2010, 17:18 Uhr
Idee
Um Wissensdurstigen einen Einblick in die fortgeschrittene C Programmierung zu geben wird die Tech 3 Gameengine von idsoftware weiterentwickelt. An Hand des Open Source Projekts ioquake3 werden die Teilnehmer in die praktische C-Programmierung abseits der Schulbuecher eingefuehrt. Der im Workshop gezeigte Code wird produktiv eingesetzt. [1]
Zielgruppe
- Neulinge in der C-Programmierung
Todo-Liste
- Existierenden Code aufräumen
- Konzept für verschiedene Ebenen des Anspruchs erstellen
Verantwortlich
- Daniel "hk" Steuer
Der Engine
ID Tech 3 ist ein Dauerbrenner unter den Gameengines. In vielen Spielen schlägt ihr Herz, dass, wenn auf gute Spielerbewegung und Interaktion Wert gelegt wird, selbst nach 10 Jahren immer wieder aktuellen Engines vorgezogen wird.[2]
Kommunikation
Der ID Tech 3 Engine behandelt jedes geladene Spiel als ein Modul. Dieses Modul liegt üblicherweise als Bytecode vor und ist daher kompatibel zu sämtlichen Plattformen. Die Kommunikation zwischen dem ClientServer, welcher die eingehenden Daten für die Virtuelle Maschine (VM) aufbereitet überträgt diese mit sog. "Syscalls" zur VM. Die Kommunikation zwischen VM und Server läuft ausschließlich über Syscalls. Zwischen dem ClientServer und dem Server auf dem das eigentliche Spiel läuft wird wahlweise eine IPX oder eine UDP verbindung aufgebaut.
ClientVM <-syscall-> ClientServer <--IP--> Server <-syscall-> ServerVM
Eigenheiten
- Der gesamte Engine ist vollständig SingleThreaded. Das bedeutet, dass innerhalb des Spiels niemals zwei Dinge gleichzeitig berechnet werden, was gewaltige Vorteile bei der Speicherverwaltung mit sich bringt.
- Die mathematischen Optimierungen für häufige Berechnungen sind sehr tiefgreifend und führen in den untiefen der math.c zu nur für C-Liebhaber gut lesbaren Quellcode.
Lehrinhalt
- Die Furcht vor Strukturen und Zeigern ablegen.
- Die Furcht vor Bit-Operationen ablegen.
- Schreiben einer einfachen Modifikation fuer ioquake3.