Differences

This shows you the differences between two versions of the page.

Link to this comparison view

egc:teme:2022:01 [2022/10/30 20:45]
maria_anca.balutoiu [Exemple de funcționalități bonus]
egc:teme:2022:01 [2022/11/13 11:59] (current)
alexandru.gradinaru [Arhivarea Proiectului]
Line 2: Line 2:
   * **Responsabili:​** Anca Băluțoiu, Alex Grădinaru, Chris Brandon   * **Responsabili:​** Anca Băluțoiu, Alex Grădinaru, Chris Brandon
   * **Lansare:​** 31 octombrie 2022   * **Lansare:​** 31 octombrie 2022
-  * **Termen de predare:​** ​13 noiembrie 2022, ora 23:59+  * **Termen de predare:​** ​16 noiembrie 2022, ora 23:59
   * **Regulament:​** [[egc:​teme:​regulament|]]   * **Regulament:​** [[egc:​teme:​regulament|]]
   * **Notă: Orice informație ce nu a fost acoperită în acest document este la latitudinea voastră!**   * **Notă: Orice informație ce nu a fost acoperită în acest document este la latitudinea voastră!**
  
 În cadrul temei 1, veți avea de implementat un joc de tipul Duck Hunt. Pentru inspirație,​ puteți testa jocul original aici: https://​www.duck-hunt.org/​. :) În cadrul temei 1, veți avea de implementat un joc de tipul Duck Hunt. Pentru inspirație,​ puteți testa jocul original aici: https://​www.duck-hunt.org/​. :)
 +
 +De asemenea, puteti viziona un mic demo construit rapid pe baza frameworkului de laborator care acopera cerintele, avand un aspect vizual minimal :).
 +
 +<​html>​
 +<iframe width="​560"​ height="​315"​ src="​https://​www.youtube.com/​embed/​eyZwa6lDm14"​ title="​YouTube video player"​ frameborder="​0"​ allow="​accelerometer;​ autoplay; clipboard-write;​ encrypted-media;​ gyroscope; picture-in-picture"​ allowfullscreen></​iframe>​
 +</​html>​
  
 ==== Rațe ==== ==== Rațe ====
Line 51: Line 57:
  
 ==== Vieți ==== ==== Vieți ====
-Jucătorul va porni inițial cu 3 vieți. În momentul în care o rață scapă (jucătorul a ratat să nimerească rața cu toate cele 3 gloanțe), acesta pierde o viață. Numărul de vieți rămase vor fi desenate pe ecran, în colțul stânga sus, sub forma unor cercuri roșii.+Jucătorul va porni inițial cu 3 vieți. În momentul în care o rață scapă (jucătorul a ratat să nimerească rața cu toate cele 3 gloanțe), acesta pierde o viață. Numărul de vieți rămase vor fi desenate pe ecran, în colțul stânga sus, de exemplu ​sub forma unor cercuri roșii.
  
 ==== Gloanțe ==== ==== Gloanțe ====
-La orice moment de timp, jucătorul trebuie să știe câte gloanțe mai are la dispoziție. Pentru asta, în colțul stânga sus (sub numărul de vieți) veți afișa și numărul de gloanțe disponibile în mod similar cu numărul de vieți, sub forma unor dreptunghiuri verzi.+La orice moment de timp, jucătorul trebuie să știe câte gloanțe mai are la dispoziție. Pentru asta, în colțul stânga sus (sub numărul de vieți) veți afișa și numărul de gloanțe disponibile în mod similar cu numărul de vieți, ​de exemplu ​sub forma unor dreptunghiuri verzi.
  
 ==== Scor ==== ==== Scor ====
Line 62: Line 68:
  
 ==== Gameplay ==== ==== Gameplay ====
-Scopul jocului este ca jucatorul sa impuste cat mai multe rate inainte sa ramana fara vieti. Jocul incepe ​cu un numar de vieti disponibile,​ dintre care se pierde ​cate una de fiecare ​data cand rata reuseste sa scape fara sa fie impuscata.+Scopul jocului este ca jucătorul să împuște cât mai multe rațe înainte să rămână fără vieți. Jocul începe ​cu un număr ​de vieți ​disponibile,​ dintre care se pierde ​câte una de fiecare ​dată când rața reușește să scape fără să fie împușcată.
  
-Ratele ​apar cate una singura ​pe ecran, pe rand, fiecare ​dupa disparitia ​(prin evadarea sau impuscarea) celei anterioare. O rata va cadea pe sol cand este impuscata, si va zbura vertical ​in sus pentru a simboliza evadarea (sunt descrise deja detalii ​in sectiunile ​"Rate Afisare" ​si "Rate Miscare"). Ele se misca dupa regulile descrise la sectiunea ​"Rate Miscare"​. ​Dupa generarea a cate rate, viteza de miscare ​a acestora va creste si, ca atare, dificultatea jocului va creste.+Rațele ​apar câte una singură ​pe ecran, pe rând, fiecare ​după dispariția ​(prin evadarea sau împușcarea) celei anterioare. O rață ​va cădea ​pe sol când este împușcată și va zbura vertical ​în sus pentru a simboliza evadarea (sunt descrise deja detalii ​în secțiunile ​"Rațe Afișare" ​și "Rațe Mișcare"). Ele se mișcă după regulile descrise la secțiunea ​"Rațe Mișcare"​. ​După generarea a câte rațe, viteza de mișcare ​a acestora va crește și, ca atare, dificultatea jocului va crește.
  
-De exemplu: ​daca primele 5 rate se misca la o viteza v0, urmatoarele ​5 ar putea avea viteza v1 = v0 + v0 / 5, urmatoarele ​v2 = v0 + 2 * v0 / 5 si asa mai departe, pentru a avea o modificare ​incrementala ​dificultatii.+De exemplu: ​dacă primele 5 rațe se mișcă ​la o viteza v0, următoarele ​5 ar putea avea viteza v1 = v0 + v0 / 5, următoarele ​v2 = v0 + 2 * v0 / 5 și așa mai departe, pentru a avea o modificare ​incrementală ​dificultății.
  
-=== Trasul cu pusca === +=== Trasul cu pușca ​=== 
-Pentru a impusca ​ratajucatorul ​are la dispozitie ​gloante ​care se reincarca ​de fiecare ​data cand apare o noua rata. De fiecare ​data cand acesta face clic pe ecran, se va considera ca un glont a fost tras in acel punct pe ecran si numarul ​de gloante ​disponibile va scadea ​cu 1. Daca punctul de pe ecran (detalii ​sectiunea ​"Intersectia glontului ​cu rata") care a fost impuscat intersecteaza rata, ea va fi considerata impuscata, scorul (detalii ​sectiunea ​"​Scor"​) va creste, si rata va cadea pe sol (detalii ​sectiunea ​"Rate Miscare").+Pentru a împușca ​rațăjucătorul ​are la dispoziție ​gloanțe ​care se reîncarcă ​de fiecare ​dată când apare o nouă rață. De fiecare ​dată când acesta face clic pe ecran, se va considera ca un glonț ​a fost tras în acel punct pe ecran și numărul ​de gloanțe ​disponibile va scădea ​cu 1. Dacă punctul de pe ecran (detalii ​secțiunea ​"Intersecția glonțului ​cu rața") care a fost împușcat intersectează rața, ea va fi considerată împușcată, scorul (detalii ​secțiunea ​"​Scor"​) va crește și rața va cădea ​pe sol (detalii ​secțiunea ​"Rațe Mișcare").
  
-=== Intersectia glontului ​cu rata === +=== Intersecția glonțului ​cu rața === 
-Avand in vedere ​ca ratele ​au o forma destul de complexa, ar fi greu de calculat exact ce puncte de pe ecran se intersecteaza ​cu ele. Asadar, le puteti ​aproxima sub forma unui dreptunghi ​in care este incadrata rata (similar figurii de mai jos). Pentru a calcula  +Având în vedere ​că rațele ​au o formă ​destul de complexă, ar fi greu de calculat exact ce puncte de pe ecran se intersectează ​cu ele. Așadar, le puteți ​aproxima sub forma unui dreptunghi ​în care este încadrată rața (similar figurii de mai jos). Pentru a calcula  
-coordonatele ​colturilor ​acestui ​patratputeti ​folosi ​cateva notiuni ​de geometrie ​in plan, aplicate ​in functie ​de coordonatele la care se afla punctele de pe silueta ​ratei.+coordonatele ​colțurilor ​acestui ​pătratputeți ​folosi ​câteva noțiuni ​de geometrie ​în plan, aplicate ​în funcție ​de coordonatele la care se află punctele de pe silueta ​raței.
  
-Patratul incadrator ​este mult mai usor de calculat ​daca toate coordonatele locale ale primitivelor din care este construita rata sunt calculate ​fata de un punct cat mai apropiat de centrul ​ratei (detalii ​sectiunea ​"Rata Constructie").+Pătratul încadrator ​este mult mai ușor de calculat ​dacă toate coordonatele locale ale primitivelor din care este construită rața sunt calculate ​față ​de un punct cât mai apropiat de centrul ​raței ​(detalii ​secțiunea ​"Rața Construcție").
  
-Mai multe detalii despre aproximarea coliziunilor 2D: https://​developer.mozilla.org/​en-US/​docs/​Games/​Techniques/​2D_collision_detection+Mai multe detalii despre aproximarea coliziunilor 2D: https://​developer.mozilla.org/​en-US/​docs/​Games/​Techniques/​2D_collision_detection ​.
  
-Pentru a afla daca mouse-ul se afla in interiorul dreptunghiului ​incadrator ​al ratei, trebuie ​facuta ​o conversie din coordonate de vizualizare ​catre coordonatele logice ​in care rata se plimba ​pe ecran. ​Daca va folositi ​de scheletul laboratorului 3, aceste 2 spatii ​de coordonate corespund 1:1 intrucat spatiul ​de desenare este limitat la rezolutia portii ​de afisare si se poate considera ​ca pozitia ​cursorului ​de mouse este si pozitia ​sa in coordonate logice. Altfel, va trebui ​aplicata ​o transformare ​similara ​cu cea fereastra poarta ​(detaliata ​tot in laboratorul 3), doar ca inversaAtentie ​la corectia ​coordonatei Y.+Pentru a afla dacă mouse-ul se află în interiorul dreptunghiului ​încadrator ​al raței, trebuie ​făcută ​o conversie din coordonate de vizualizare ​către ​coordonatele logice ​în care rața se plimbă ​pe ecran. ​Dacă va folosiți ​de scheletul laboratorului 3, aceste 2 spații ​de coordonate corespund 1:1 întrucât spațiul ​de desenare este limitat la rezoluția porții ​de afișare și se poate considera ​că poziția ​cursorului mouse-ului este și poziția ​sa în coordonate logice. Altfel, va trebui ​aplicată ​o transformare ​similară ​cu transformarea fereastră - poartă ​(detaliată ​tot în laboratorul 3), doar ca inversăAtenție ​la corecția ​coordonatei Y.
  
-Dupa ce cursorul ​si dreptunghiul se afla in acelasi spatiu ​de coordonate, verificarea ​intersectiei ​se rezuma ​la verificarea ​daca un punct in plan se afla intr-un dreptunghi aliniat cu axele Ox si Oy. Detaliile acestui calcul sunt lasate ​ca exercitiu ​pentru student.+După ce cursorul ​și dreptunghiul se află în același spațiu ​de coordonate, verificarea ​intersecției ​se rezumă ​la verificarea ​dacă un punct în plan se află într-un dreptunghi aliniat cu axele Ox și Oy. Detaliile acestui calcul sunt lăsate ​ca exercițiu ​pentru student.
  
-Inputul de la mouse se poate trata in functia ​"​OnMouseMove"​ din framework. Aceasta are 4 parametri: mouseX, mouseY, deltaX, deltaY. Primele 2 se refera ​la pozitia ​la care se afla cursorul ​in momentul ​in care se apeleaza functiain pixeli. Numerotarea ​incepe ​din coltul stanga-sus al ferestrei de vizualizare ​in (0, 0). Cei 2 parametri din urma se refera ​la deplasarea ​exacta ​(tot in pixeli) a cursorului de la pozitia ​sa in frame-ul anterior pana la pozitia ​sa in frame-ul ​in care a fost apelata functia. De exemplu, daca mouse-ul s-a miscat ​de la pozitia ​(1200, 300) la pozitia ​(1220, 294) in intervalul de la ultimul frame pana la cel curent, vom avea urmatoarele ​valori: mouseX = 1220, mouseY = 294, deltaX = 20, deltaY = 294.+Inputul de la mouse se poate trata în funcția ​"​OnMouseMove"​ din framework. Aceasta are 4 parametri: mouseX, mouseY, deltaX, deltaY. Primele 2 se referă ​la poziția ​la care se află cursorul ​în momentul ​în care se apelează funcțiaîn pixeli. Numerotarea ​începe ​din colțul stânga-sus al ferestrei de vizualizare ​în (0, 0). Cei 2 parametri din urmă se referă ​la deplasarea ​exactă ​(tot în pixeli) a cursorului de la poziția ​sa în frame-ul anterior pana la poziția ​sa în frame-ul ​în care a fost apelată funcția. De exemplu, daca mouse-ul s-a mișcat ​de la poziția ​(1200, 300) la poziția ​(1220, 294) în intervalul de la ultimul frame până ​la cel curent, vom avea următoarele ​valori: mouseX = 1220, mouseY = 294, deltaX = 20, deltaY = -6.
  
-Atentie! Aceste valori sunt intregiaveti grija la tipurile de date daca intentionati sa le impartiti. De asemenea, deltaX ​si deltaY deja sunt calculate ​fata de frame-ul anterior. Ca atare, nu mai este nevoie ​sa ne legam de deltaTimeSeconds pentru a avea o miscare independenta ​de frame rate.+<​note>​Atenție! Aceste valori sunt întregiaveți grijă ​la tipurile de date dacă intenționați să le împărțiți. De asemenea, deltaX ​și deltaY deja sunt calculate ​făță ​de frame-ul anterior. Ca atare, nu mai este nevoie ​să ne legăm ​de deltaTimeSeconds pentru a avea o mișcare independentă ​de frame rate.</​note>​
  
 {{ :​egc:​teme:​2022:​duck_mouse_t1_2022.png?​300 |}} {{ :​egc:​teme:​2022:​duck_mouse_t1_2022.png?​300 |}}
  
-=== Evadarea ​ratei === +=== Evadarea ​raței ​=== 
-In momentul ​in care toate cele 3 gloante ​au fost consumate ​fara a fi fost impuscata rata, aceasta ​evadeaza. De asemenea, ​daca rata nu a fost impuscata ​timp de un numar de secunde, va evada. ​In ambele ​situatii in care rata evadeazajucatorul ​va pierde o viata (detalii ​sectiunea ​"Vieti"​) ​si nu va primi scorul aferent ​ratei respective.+În momentul ​în care toate cele 3 gloanțe ​au fost consumate ​fără ​a fi fost împușcată rața, aceasta ​evadează. De asemenea, ​dacă rața nu a fost împușcată ​timp de un număr ​de secunde, va evada. ​În ambele ​situații în care rața evadeazăjucătorul ​va pierde o viață ​(detalii ​secțiunea ​"Vieți"​) ​și nu va primi scorul aferent ​raței ​respective.
  
  
 ==== Funcționalități obligatorii (150 puncte) ==== ==== Funcționalități obligatorii (150 puncte) ====
-  * Miscare/animatii rata (75p total) +  * Mișcare/animații rață ​(75p total) 
-    * Desenare/​asamblare ​figura geometrica rata 15p +    * Desenare/​asamblare ​figură geometrică rață ​15p 
-    * Deplasare ​activa ​(deplasare ansamblu ​rata si animatii ​aripi) 20p +    * Deplasare ​activă ​(deplasare ansamblu ​rață și animații ​aripi) 20p 
-    * Pozitionare si directie initiala ​10p+    * Poziționare și direcție inițială ​10p
     * Reflexii 10p     * Reflexii 10p
-    * Impuscat ​10p+    * Împușcat ​10p
     * Evadare 10p     * Evadare 10p
   * Gameplay (75p total)   * Gameplay (75p total)
-    * Aparitie ratecate una pe ecran 5p +    * Apariție rațecâte una pe ecran 5p 
-    * Incrementare ​viteza rate 5p+    * Incrementare ​viteză rațe 5p
     * Temporizare evadare 5p     * Temporizare evadare 5p
-    * Trasul cu pusca +    * Trasul cu pușca 
-      * Tintire ​20p +      * Țintire ​20p 
-      * Coliziuni ​rata 20p +      * Coliziuni ​rață ​20p 
-    * Interfata grafica ​(functionalitate si afisare+    * Interfața grafică ​(funcționalitate și afișare
-      * Vieti 5p +      * Vieți ​5p 
-      * Gloante ​5p+      * Gloanțe ​5p
       * Scor 10p       * Scor 10p
  
Line 121: Line 127:
   * Realizarea gazonului de jos în spatele căruia apare rața, astfel încât să nu apară brusc pe ecran de nicăieri.   * Realizarea gazonului de jos în spatele căruia apare rața, astfel încât să nu apară brusc pe ecran de nicăieri.
   * Rațe mai detaliate/​complexe ca geometrie.   * Rațe mai detaliate/​complexe ca geometrie.
-  * Crosshair pe mouse și eventual ​o pușcă/​armă animată în funcție de poziția cursorului pe ecran (să fie îndreptată/​rotită spre cursor).+  * Crosshair pe mouse și o pușcă/​armă animată în funcție de poziția cursorului pe ecran (să fie îndreptată/​rotită spre cursor).
   * Sistem de tragere animat (gloanțe vizibile, o mică animație în momentul în care se atinge rața - de exemplu sar niște ‘pene’ aproximate în direcții aleatorii).   * Sistem de tragere animat (gloanțe vizibile, o mică animație în momentul în care se atinge rața - de exemplu sar niște ‘pene’ aproximate în direcții aleatorii).
   * Rațe “speciale” care dau jucătorului anumite abilități (o viață extra, un glonț extra, toate rațele se vor mișca foarte încet pentru câteva secunde). Fiecare astfel de rață va avea o culoare specifică power up-ului pe care îl acordă si va exista un indicator de timp care arata cat timp mai dureaza acea abilitate (de ex o bara similara cu cea de scor, care scade in timp si dispare cand nu mai e valabila abilitatea).   * Rațe “speciale” care dau jucătorului anumite abilități (o viață extra, un glonț extra, toate rațele se vor mișca foarte încet pentru câteva secunde). Fiecare astfel de rață va avea o culoare specifică power up-ului pe care îl acordă si va exista un indicator de timp care arata cat timp mai dureaza acea abilitate (de ex o bara similara cu cea de scor, care scade in timp si dispare cand nu mai e valabila abilitatea).
Line 147: Line 153:
       * Click dreapta pe proiect în **Solution Explorer** -> **Clean Solution**       * Click dreapta pe proiect în **Solution Explorer** -> **Clean Solution**
       * Ștergeți folderul __**/​build/​.vs**__ (dacă nu îl vedeți, **este posibil să fie ascuns**)       * Ștergeți folderul __**/​build/​.vs**__ (dacă nu îl vedeți, **este posibil să fie ascuns**)
-    * SAU ștergeți complet folderul __**/​build**__ 
   * În cazul în care arhiva tot depășește limita de 50MB (nu ar trebui), puteți să ștergeți și folderul __**/​deps**__ sau __**/​assets**__ întrucât se pot adăuga la testare. Nu este recomandat să faceți acest lucru întrucât îngreunează mult testarea în cazul în care versiunea curentă a bibliotecilor/​resurselor diferă de versiunea utilizată la momentul scrierii temei.   * În cazul în care arhiva tot depășește limita de 50MB (nu ar trebui), puteți să ștergeți și folderul __**/​deps**__ sau __**/​assets**__ întrucât se pot adăuga la testare. Nu este recomandat să faceți acest lucru întrucât îngreunează mult testarea în cazul în care versiunea curentă a bibliotecilor/​resurselor diferă de versiunea utilizată la momentul scrierii temei.
 </​note>​ </​note>​
  
  
egc/teme/2022/01.1667155535.txt.gz · Last modified: 2022/10/30 20:45 by maria_anca.balutoiu
CC Attribution-Share Alike 3.0 Unported
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0