Jadi, Anda harus mulai dengan melihat artikel Wikipedia di id Tech 3 . Itu dapat ditambah dengan ringkasan pembicaraan Brian Hook dari GDC dan beberapa hal lama di blog Element 61 . Selain itu, Anda harus melihat-lihat tutorial mod lama apa pun yang dapat Anda temukan untuk mencoba dan merekonstruksi apa yang terjadi.
Saya sarankan mulai dari rilis sumber asli dari id, alih-alih ioquake3 atau apa-apa, untuk benar-benar melihat konteks apa yang terjadi (bagaimana input ditangani dan diarahkan di dalam mesin, seperti apa kejadian yang mendasarinya struktur digunakan, dll.).
Beberapa poin penting yang membantu saya ketika saya sedang bekerja dengannya:
- Selalu ada server; mungkin juga ada logika klien yang duduk di atas menangani sebuah bingkai.
- Input diarahkan pertama ke konsol, jika tertarik, lalu ke GUI, lalu ke gim yang sesuai.
- Mesinnya sendiri dipisahkan (keras!) Dari logika permainan, menggunakan fungsi perangkap. Lihat (jika ingatanku) proyek cgame dan render untuk menemukan kode mesin yang sebenarnya.
- Logika game dapat sepenuhnya ditulis untuk dijalankan di mesin virtual Quake 3. Saat modding dan menggunakan dll asli, Anda harus menjalankan gim seperti
quake3.exe +set sv_pure 0 +set vm_game 0 +set vm_cgame 0 +set vm_ui 0
untuk memungkinkan mesin untuk menjalankan kode asli bukan kode VM.
- UI untuk sistem menu adalah tumpukan struktur dan panggilan balik yang aneh, jahat, bengkok. Ini dapat digunakan setelah Anda memecahkannya, tetapi itu dapat mengambil beberapa trial and error. Ingat, ini tumpukan.
- Jika Anda menulis kode dalam .dlls asli, jangan ragu untuk mengalokasikan memori, menulis dalam C ++, atau apa pun yang mengapung perahu Anda. Anda dapat menggunakan STL juga - tidak ada alasan untuk secara kaku mengikuti idiom C kecuali di mana Anda langsung berinteraksi dengan mesin.
Beberapa hal rapi yang saya buat untuk itu dengan seorang rekan kerja:
- Antarmuka baris perintah sederhana untuk memanggil perintah shell dari konsol dan membuang aliran stdout / stderr kembali ke konsol (konsol Gempa).
- Interface dengan database SQL untuk menarik dan menampilkan catatan.
- Jendela fleksibel dan toolkit widget untuk membuat tampilan fleksibel pada hud klien (menggunakan diagram batang, kotak teks, kotak gambar, menu konteks, jendela yang dapat diubah ukurannya, dll.)
- Roket lambat. :)
Secara pribadi, saya menemukan bahwa mesin itu adalah kombinasi yang hebat dari hal-hal yang benar-benar cerdas yang dilakukan dengan cara yang benar-benar bodoh, hal-hal yang benar-benar bodoh dilakukan dengan cara yang sangat cerdas, dan hal-hal yang sangat cerdas dilakukan dengan cara yang sangat cerdas. Ini adalah contoh yang bagus tentang bagaimana memiliki modularitas dan desain terstruktur yang baik dalam proyek C skala menengah.
Terakhir, jangan merasa buruk jika perlu waktu untuk melakukan grok. Butuh waktu sebulan mungkin untuk benar-benar dapat mengetahui di mana menemukan apa yang saya cari di mesin; jika semuanya gagal, mulailah dari init aplikasi dan langsung turun ke fungsi, meninggalkan komentar untuk diri sendiri sebagai rambu-rambu. Monitor saya pada akhirnya tercakup dalam catatan post-it pink dengan nama fungsi, nomor baris, dan deskripsi singkat tentang apa yang mereka lakukan.