Kuinka ohjelmoida pelejä C. Oppitunti yksi

01

05

Johdanto peliohjelmointiohjeisiin

Tämä on ensimmäinen monista peleistä, jotka ohjelmoivat C-oppaita aloittelijoille. Sen sijaan, että keskittyisit opettelemaan C: tä ja näyttämään esimerkkejä ohjelmista, he opettavat C: tä tarjoamalla sinulle täydelliset ohjelmat (ts. Pelit) C: ssä

Pidä se yksinkertaisena

Sarjan ensimmäinen peli on konsoli (ts. Star Empires -niminen tekstipohjainen peli). Star Empires on yksinkertainen peli, jossa sinun täytyy kaapata kaikki 10 galaksin järjestelmää pysäyttämättä AI-vastustajasi tekemästä samaa.

Alat omistaa Järjestelmä 0, kun taas vihollisesi oma järjestelmä 9. Loput kahdeksan järjestelmää (1-8) alkavat kaikki neutraalilta. Kaikki järjestelmät alkavat 5 jäsentävällä x 5 jäsentävällä neliöllä, joten mikään järjestelmä ei ole enempää kuin 6 jäsentävällä toisistaan. Kaksi etäisintä pistettä ovat (0,0) ja (4,4). Pythagoras-lauseen mukaan etäisyys kaikista kahdesta järjestelmästä on neliöjuuri ((4)2 + (4)2), joka on 32: n neliöjuuri, joka on noin 5.657.

instagram viewer

Huomaa, että tämä ei ole lopullinen versio, ja sitä muutetaan. Viimeisin muutos: 21. elokuuta 2011.

Vuoropohjainen ja reaaliaikainen

Peli on vuoropohjainen, ja jokaisella vuorolla annat käskyn siirtää minkä tahansa määrän laivastoja mistä tahansa omistamistasi järjestelmästä mihin tahansa muuhun järjestelmään. Jos omistat useita järjestelmiä, voit tilata laivastoja siirtyäksesi kaikista järjestelmistä kohdejärjestelmään. Tämä tehdään suhteessa pyöristettyyn, joten jos omistat kolme järjestelmää (1,2,3), joissa on 20, 10 ja 5 laivastoa ja tilaat 10 laivastoa siirtymään järjestelmään 4, niin 6 siirtyy järjestelmästä 1, 3 järjestelmästä 2 ja 1 järjestelmästä 3. Jokainen laivasto liikkuu yhden parsan kierrosta kohti.

Jokainen käännös kestää 5 sekuntia, mutta voit muuttaa nopeutta nopeuttaaksesi tai hidastamalla sitä muuttamalla koodirivin 5 arvoksi 3 tai 7 tai mihin tahansa valitset. Etsi tämä koodirivi:

onesec = kello () + (5 * CLOCKS_PER_SEC);

C-ohjelmoinnin opas

Tämä peli on ohjelmoitu ja siinä oletetaan, että et tiedä mitään C-ohjelmointia. Esittelen C-ohjelmointiominaisuudet tässä ja seuraavissa kahdessa tai kolmessa opetusohjelmassa niiden edetessä. Ensin tarvitset kuitenkin kääntäjän Windowsille. Tässä on kaksi ilmaista:

  • Yrittää CC386
  • Tai Visual C ++ 2010 Express

CC386-artikkeli opastaa sinua projektin luomisessa. Jos asennat kyseisen kääntäjän, sinun tarvitsee vain ladata Hello World -ohjelma kuvatulla tavalla, kopioida ja liittää lähdekoodi esimerkin päälle, tallentaa se ja napsauttaa sitten F7 kääntääksesi se ja suorittamalla se. Samoin Visual C ++ 2010 -artikkeli luo hello world -ohjelman. Korvaa se ja paina F7 rakentaaksesi Star Empires., F5 suorittaaksesi sen.

Seuraavalla sivulla - Panostamalla tähtiimperiumit toimimaan

02

05

Tähtimpereenien tekeminen toimimaan

Tähtimpereenien tekeminen toimimaan

Meidän on tallennettava tiedot pelikoneisiin ja järjestelmiin. Laivasto on yksi tai useampi alus, jolla on määräys siirtyä järjestelmästä toiseen. Tähtijärjestelmä on useita planeettoja, mutta se on enemmän abstrakti kokonaisuus tässä pelissä. Meidän on pidettävä seuraavia tietoja laivastosta.

  • Lähtöjärjestelmä (1-10).
  • Kohdejärjestelmä (1-10)
  • Kuinka monta alusta (1-monta)
  • Kääntyy saapumiseen
  • Kenen laivasto se on? 0 = pelaaja, 9 = vihollinen

Käytämme C-rakennetta tämän pitämiseen:

rakennelaivasto {
int järjestelmästä;
int tosysteemi;
int käännökset;
int laivaston koko;
int omistaja;
};

Rakenne on kokoelma tietoja, tässä tapauksessa 5 numeroa, joita käsittelemme yhtenä. Jokaisella numerolla on nimi, esimerkiksi järjestelmästä, tosysysteemistä. Nämä nimet ovat muuttuvia nimiä C: ssä ja niissä voi olla alleviivauksia, kuten_tätä, mutta ei välilyöntejä. C: ssä luvut ovat joko kokonaislukuja; kokonaislukuja, kuten 2 tai 7, kutsutaan intsiksi tai desimaalilukuna olevia numeroita, kuten 2.5 tai 7.3333, ja näitä kutsutaan kelluviksi. Koko Tähti-imperiumeissa käytämme kelluvia vain kerran. Kahden paikan välisen etäisyyden laskevaa koodipalaa. Jokainen numero on int.

Joten laivasto on nimi tietorakenteelle, jolla on viisi intimuuttujaa. Nyt se on yhden laivaston. Emme tiedä kuinka monta laivastoa meidän on pidettävä, joten varaamme antelias tila 100: lle käyttämällä taulukkoa. Ajattele rakennetta kuin ruokapöytä, jossa on tilaa viidelle hengelle (tuumaa). Ryhmä on kuin pitkä ruokapöytä. 100 taulukkoa tarkoittaa, että siihen mahtuu 100 x 5 henkilöä.

Jos palvelemme tosiasiassa näitä 100 ruokapöytää, meidän olisi tiedettävä mikä pöytä oli mikä ja teemme tämän numeroimalla. Kohdassa C numeroidaan aina taulukon elementit, jotka alkavat arvosta 0. Ensimmäinen ruokapöytä (laivasto) on numero 0, seuraava on yksi ja viimeinen on 99. Muistan aina, kuinka monta ruokapöytää tämä pöytä on alusta alkaen? Ensimmäinen on alussa, joten on 0 pitkin.

Näin ilmoitamme laivastot (eli päivällispöydät).

rakennelaivaston laivasto [100];

Lue tämä vasemmalta oikealle. Struct-laivasto tarkoittaa rakennettamme pitää yksi laivasto. Nimi laivastot on nimi, jonka annamme kaikille laivastoille, ja [100] kertoo, että laivastomuuttujassa on 100 x rakenteellista laivastoa. Jokainen int vie 4 muistipaikkaa (kutsutaan tavuiksi), joten yksi laivasto vie 20 tavua ja 100 laivastoa on 2000 tavua. On aina hyvä idea tietää, kuinka paljon muistia ohjelmamme tarvitsee tietojen säilyttämiseen.

Rakenteellisessa laivastossa jokaisella intsillä on kokonaisluku. Tämä luku tallennetaan 4 tavuun ja tämän alue on välillä 2 147 483 647 - 2 147 483 648. Käytämme suurimman osan ajasta pienempiä arvoja. Järjestelmiä on kymmenen, joten sekä järjestelmällä että tosysteemillä on arvot 0 - 9.

Seuraavalla sivulla: Järjestelmät ja satunnaislukut

03

05

Tietoja järjestelmistä ja satunnaislukuista

Jokainen neutraali järjestelmä (1-8) alkaa 15 aluksella (numeron, jonka valitsin ilmasta!) Aloittaaksesi, ja kahdella muulla (sinun: järjestelmä 0 ja tietokoneesi vastustaja järjestelmässä 9) on 50 alusta. Jokaisella kierroksella laivan lukumäärä järjestelmässä kasvaa 10% pyöristettynä alas. Joten yhden kierroksen jälkeen, jos et siirrä niitä, 50: stä tulee 55 ja jokaisessa neutraalissa järjestelmässä on 16 (15 + 1,5 pyöristetty alas). Huomaa, että toiseen järjestelmään siirtyvien laivastojen lukumäärä ei kasva.

Laivojen määrän lisääminen tällä tavalla voi tuntua hiukan outolta, mutta olen tehnyt sen pitääkseni pelin liikkumassa. Sen sijaan, että häiritsisimme tätä opetusohjelmaa liikaa suunnittelupäätöksiin, kirjoitin erillisen artikkelin Star Empires -suunnittelupäätöksistä.

Toteutusjärjestelmät

Aluksi meidän on luotava kaikki järjestelmät ja asetettava ne kartalle, korkeintaan yksi järjestelmä sisään Jokainen sijainti, koska 5 x 5-ruudukossamme on 25 sijaintia, meillä on kymmenen järjestelmää ja 15 tyhjää paikoissa. Luomme ne toiminnolla GenMapSystems (), jota tarkastelemme seuraavalla sivulla.

Järjestelmä tallennetaan rakenteeseen seuraavien 4 kentän kanssa, jotka kaikki ovat int.

rakennejärjestelmä {
int x, y;
int-numerot;
int omistaja;
};

Galaksi (kaikki 10 järjestelmää) on tallennettu toiseen ryhmään aivan kuten laivastoihin, paitsi meillä on 10 järjestelmää.

rakennejärjestelmän galaksi [10];

Satunnaiset numerot

Kaikki pelit tarvitsevat satunnaislukuja. C: llä on sisäänrakennettu toiminto rand (), joka palauttaa satunnaisen int. Voimme pakottaa tämän alueelle ohittamalla maksimimäärän operaattorilla% ja käyttämällä% operaattoria. (Moduuli). Tämä on kuin kelloaritmeettinen paitsi, että 12 tai 24 sijaan siirrymme int-numeroon nimeltään max.

/ * palauttaa luvun välillä 1 - max * /
int satunnainen (int max) {
tuotto (rand ()% max) +1;
}

Tämä on esimerkki toiminnosta, joka on säiliön sisään kääritty koodinpätkä. Ensimmäinen rivi, joka alkaa / * ja loppuu * /, on kommentti. Se kertoo mitä koodi tekee, mutta kääntäjä, joka lukee C-ohjeet ja muuntaa ne ohjeiksi, joita tietokone ymmärtää ja pystyy suorittamaan erittäin nopeasti, jättää huomioimatta.

  • Mietitkö mitä kääntäjä on? Lukea Mikä on kääntäjä? (Artikla)

Funktio on kuin matemaattinen funktio, kuten Sin (x). Tätä toimintoa on kolme osaa:

int satunnainen (int max)

Int sanoo, minkä tyyppinen numero se palauttaa (yleensä int tai float). Satunnainen on funktion nimi ja (int max) sanoo, että kuljemme int-numerolla. Voimme käyttää sitä seuraavasti:

int noppaa;
noppaa = satunnainen (6); / * palauttaa satunnaisluvun välillä 1-6 * /

Linja:

tuotto (rand ()% max) +1;

Seuraavalla sivulla: Satunnaisen aloituskartan luominen

04

05

Satunnaisen aloituskartan luominen

Star Empires kartta

Tämä alla oleva koodi luo alkukartan. Se on se osoitettu yllä.

mitätön GenMapSystems () {
int i, x, y;
for (x = 0; x for (y = 0; y asettelu [x] [y] = '';
}
InitSystem (0,0,0,50,0);
InitSystem (9,4,4,50,1);
/ * Löydä tyhjä tila jäljellä oleville 8 järjestelmälle * /
varten (i = 1; teen {
x = satunnainen (5) -1;
y = satunnainen (5) -1;
}
while (asettelu [x] [y]! = '');
InitSystem (i, x, y, 15, -1);
}
}

Järjestelmien luominen tarkoittaa pelaajan ja vastustajien järjestelmien (pisteissä 0,0) ja (4,4) lisäämistä ja sitten satunnaisesti 8 järjestelmän lisäämistä jäljellä oleviin 23 tyhjään sijaintiin.

Koodi käyttää kolmea rivin määrittelemää int-muuttujaa

int i, x, y;

Muuttuja on sijainti muistissa, jolla on int-arvo. Muuttujat x ja y pitävät järjestelmien koordinaatteja ja pitävät arvoa alueella 0-4. Muuttujaa i käytetään silmukoiden laskemiseen.

Jotta 8 satunnaista järjestelmää sijoitettaisiin 5x5-ruudukkoon, meidän on tiedettävä, onko paikalla jo järjestelmä, ja estettävä toisen sijoittaminen samaan sijaintiin. Tätä varten käytämme yksinkertaista kaksiulotteista merkistöryhmää. Tyyppi char on toinen muuttujan tyyppi C: ssä ja sillä on yksi merkki, kuten 'B' tai 'x'.

Aluetyyppi datatyypeistä C: ssä

C: n muuttujien perustyyppi on int (kokonaislukuja, kuten 46), char (yksi merkki, kuten 'A') ja kelluva (niiden numeroiden pitämiseksi, joiden liukuluku on kuten 3.567). Taulukot [] on tarkoitettu saman elementin luetteloiden pitämiseen. Joten char [5] [5] määrittelee luettelon; kaksiulotteinen merkkijono. Ajattele sitä kuten 25 Scrabble-kappaletta, jotka on järjestetty 5 x 5 ruudukkoon.

Nyt me silmukka!

Jokainen merkki asetetaan alun perin välilyöntiin kaksoissilmukassa käyttämällä kahta lauseisiin. Lausunnolla on kolme osaa. Alustus, vertailuosa ja muutososa.

for (x = 0; x for (y = 0; y asettelu [x] [y] = '';
}

  • x = 0; Tämä on alustusosa.
  • x
  • X ++. Tämä on muutososa. Se lisää 1 x: iin.

Joten (varten (x = 0; x

Sisällä for (x-silmukka on y-silmukalle, joka tekee saman y: lle. Tämä y-silmukka tapahtuu jokaiselle X: n arvolle. Kun X on 0, Y silmukka 0 - 4, kun X on 1, Y silmukka ja niin edelleen. Tämä tarkoittaa, että jokainen asettelujoukon 25 sijainnista alustetaan välilyönniksi.

For-silmukan jälkeen toiminto InitSystem kutsutaan viidellä int-parametrilla. Toiminto on määritettävä ennen kuin sitä kutsutaan. Kääntäjä ei tiedä kuinka monta parametria sillä pitäisi olla. InitSysteemillä on nämä viisi parametria.

Seuraavalla sivulla: Satunnaisen aloituskartan luominen jatkuu ...

05

05

Satunnaisen aloituskartan luominen jatkuu

Nämä ovat InitSystem-parametrit.

  • systemindex - arvo välillä 0 -9.
  • x ja y - järjestelmän koordinaatit (0-4).
  • numshipit - kuinka monta alusta tässä järjestelmässä on.
  • omistaja. Kuka omistaa järjestelmän. 0 tarkoittaa pelaajaa, 9 tarkoittaa vihollista.

Joten rivi InitSystem (0,0,0,50,0) alustaa järjestelmän 0 paikoissa x = -0, y = 0 50 aluksella omistajalle 0.

C: llä on kolmen tyyppisiä silmukoita, silmukoita silmukoille ja silmukoille. Käytämme ja teemme toiminnassa GenMapSystems. Täällä meidän on sijoitettava loput 8 järjestelmää jonnekin galaksiin.

varten (i = 1; teen {
x = satunnainen (5) -1;
y = satunnainen (5) -1;
}
while (asettelu [x] [y]! = '');
InitSystem (i, x, y, 15,0);
}

Tässä koodissa on kaksi sisäkkäistä silmukkaa. Ulkosilmukka on lauseketta varten, joka laskee i-muuttujan alkuarvosta 1 lopulliseen arvoon 8. Käytämme i viitataksesi järjestelmään. Muista, että olemme jo alustaneet järjestelmän 0 ja 9, joten alustamme nyt järjestelmiä 1-8.

Kaikki tehtävästä {aina siihen asti (asettelu [x] [y]) on toinen silmukka. Sen syntaksi on tehdä {jotain} kun (ehto on totta); Joten annamme satunnaisarvot x: lle ja y: lle, jokainen arvo on alueella 0-4. Satunnainen (5) palauttaa arvon välillä 1 - 5, vähentämällä 1 saadaan alue 0-4.

Emme halua laittaa kahta järjestelmää samoille koordinaateille, joten tämä silmukka etsii satunnaista sijaintia, jossa on tilaa. Jos siellä on järjestelmä, asettelu [x] [y] ei ole välilyönti. Kun kutsumme InitSysteemeksi, se tuo toisen arvon. BTW! = Tarkoittaa yhtä kuin ja == tarkoittaa yhtä.

Kun koodi saavuttaa InitSysteemin jonkin ajan kuluttua (asettelu [x] [y]! = ''), X ja y viittaavat ehdottomasti paikkaan asettelussa, jossa on tilaa. Joten voimme soittaa InitSystemille ja sitten käydä ympäri for-silmukkaa löytääksesi satunnaisen sijainnin seuraavalle järjestelmälle, kunnes kaikki 8 järjestelmää on sijoitettu.

Ensimmäinen puhelu InitSystemille asettaa järjestelmän 0 sijaintipaikkaan 0,0 (ruudukon vasen yläosa) 50 laivastolla ja voitin ne. Toinen puhelu alkaa järjestelmästä 9 sijainnista 4,4 (alhaalta oikealta) 50 laivastolla ja se on pelaajan 1 omistama. Katsomme tarkemmin mitä InitSystem todella tekee seuraavassa opetusohjelmassa.

#määritellä

Nämä rivit ilmoittavat kirjaimelliset arvot. On tapana laittaa ne isoiksi. Kaikkialla missä kääntäjä näkee MAXFLEETS, se käyttää arvoa 100. Muuta niitä täällä, ja se koskee kaikkialla:

  • #define WIDTH 80
  • #define HEIGHT 50
  • #define MAXLEN 4
  • #define MAXFLEETS 100
  • #define MAXSYSTEMS 10
  • #define FIGHTMARKER 999

johtopäätös

Tässä opetusohjelmassa olemme käsittäneet muuttujat ja int, char ja struct -sovellusten käytön ryhmittämällä ne sekä taulukon luomiseen taulukon. Sitten yksinkertainen silmukointi käyttämällä ja tehdä. Jos tutkit lähdekoodia, samat rakenteet nähdään kerta toisensa jälkeen.

  • varten (i = 0; i
  • varten (i = 0; i

Tutorial Twowill tarkastelee tässä opetusohjelmassa mainittuja C-näkökohtia.