Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando
Abbiamo giocato a lungo a Battlefield 6, abbiamo provato tutte le modalità multiplayer, Redsec, e le numerose personalizzazioni. In sintesi, ci siamo concentrati su ogni aspetto del titolo per comprendere al meglio uno degli FPS più ambiziosi della storia dei videogiochi e, dopo quasi due mesi, abbiamo tirato le somme. In questo articolo, condividiamo con voi tutto ciò che è Battlefield 6, un gioco che, a nostro avviso, rappresenta esattamente ciò che questo genere attendeva da tempo
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2006, 12:46   #1
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
[TASK 10.2.3] nihil84 Vs. cionci

Oggi pomeriggio facciamo questo task...
Intanto tiro giù una test list approssimativa...

1. quando viene eseguito un handler devo poter recuperare una stringa contenete il nome della classe che viene eseguita seguita da un newline
2. ogni handler che viene eseguito deve "appendere" il proprio nome ad una stringa
3. in caso di evento causato dalla pressione di un tasto deve essere "appesa" una ulteriore stringa con scritto " 1" seguita da newline
4. in caso di evento causato dal rilascio di un tasto deve essere "appesa" una ulteriore stringa con scritto " 0" seguita da newline
5. se premo destra e sinistra insieme non deve essera "appeso" niente alla stringa
6. se la gestione di un evento non produce effetti (rilascio di alcuni tasti) allora non deve essere scritto niente nel file
7. playField deve creare un file nella directory data (il file deve essere rimosso alla fine dell'esecuzione del test)
8. playField al momento dell'apertura del file deve scrivere nel log file la stringa "seed " seguita dal random seed del RandomGenerator
9. playField deve leggere da gridController una stringa contenente la nuova coppia di gemme inserita da gridController in gioco
10. dopo che viene eseguito gridController.reactToInput, playField deve scrivere il numero sul file di log le seguenti informazioni:

<---riga vuota
#XXXX <----inputServed
pair XXXX YYYY<----coppia di gemme generate, se non ci sono linea vuota
ZZZZEventHandler 0/1<----stringa recuperata da gridController.reactToInput
<---riga vuota

11. se non ci sono coppie generate o eventi non deve essere scritto niente sul file

Ultima modifica di cionci : 16-02-2006 alle 17:39.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 12:54   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
La test list mi sembra buona. Anche se per i test scriverei in una zona di memoria o una stringa.

ciao
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 13:04   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Sì...è sicuramente meglio creare un mock...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 14:16   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Allora facciamo così... Ci aggironiamo alle 17:30-18, spero di essere tornato a casa per quell'ora...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 18:23   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ecco il primo test
Codice:
    
public void testLogStringOnEvent()
    {
        Config config = new Config("data/GameConfig");
        MockTimer timer = new MockTimer();
        Input input = Input.createForTesting(timer);
        
        PlayField playField = new PlayField(config, input, new RandomGenerator(), timer,
            new Point(0,0), new Point(0,0), new Point(0,0));
        
        input.notifyKeyEvent(KEY_LEFT, KeyEvent.PRESSED);
        
        String logString = new String();
        playField.getGridController().reactToInput(timer, logString);
        
        String className = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())
            .getClass().getCanonicalName() + "\n";
        
        assertEquals("Logged string must cotain class name", className, logString);
    }
Per ora la stringa immessa è troppo lunga, ma eventualmente ce ne preoccupiamo dopo...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 19:24   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Impemento il codice...
Faccio un refactoring di reactToInput (di GridController e di InputReactor) aggiungendo un parametro StringBuffer, inoltre aggiungo in InputReactor:
Codice:
    private void handleKeyEvent(KeyEvent event, StringBuffer logString)
    {
        if(eventHandlersMap.containsKey(event.key()))
        {
            eventHandlersMap.get(event.key()).handleEvent(this, event);
            logString.append(eventHandlersMap.get(event.key()).getClass().getName() + "\n");
        }
    }
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 20:02   #7
nihil84
Junior Member
 
L'Avatar di nihil84
 
Iscritto dal: Jan 2006
Città: Cecina (LI)
Messaggi: 10
creata la funzione sutUp per eliminare il codice ridondante...
Codice:
    public void setUp()
    {
        config = new Config("data/GameConfig");
        timer = new MockTimer();
        input = Input.createForTesting(timer);
        
        playField = new PlayField(config, input, new RandomGenerator(), timer,
            new Point(0,0), new Point(0,0), new Point(0,0));
    }
e scritto il secondo test:
Codice:
    public void testLogStringOnTwoEvents()

    {
        StringBuffer logString = new StringBuffer();

        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
        input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.PRESSED);

        playField.getGridController().reactToInput(timer, logString);
        
        String eventList = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())

            .getClass().getName() + "\n";
        eventList += new DropCommandHandler(playField.getGridController().getGrid())

            .getClass().getName() + "\n";

        

        assertEquals("Logged string must contain left and down events", eventList, logString.toString());       

    }
__________________
A Bright (http://www.the-brights.net)

Linux is user-friendly...
It is just selective about who its friends are
nihil84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 20:13   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Il test passa già !!!

Passo al prossimo test, ora facciamo sul serio:
Codice:
    public void testLogStringOnTwoEvents()
    {       
        input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.RELEASED);
        playField.getGridController().reactToInput(timer, new StringBuffer());

        StringBuffer logString = new StringBuffer();
       
        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
        input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.RELEASED);
        playField.getGridController().reactToInput(timer, logString);
                
        String eventList = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())
            .getClass().getName() + " 1\n";
        eventList += new DropCommandHandler(playField.getGridController().getGrid())
            .getClass().getName() + " 0\n";
        
        assertEquals("Logged string must contain left and down events", eventList, logString.toString());       
    }
Il test è lo stesso di prima, ma modificato...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 21:10   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Riporto le modifiche fatte da nihil84:
Codice:
    private void execute(InputReactor inputReactor, StringBuffer logString)
    {
        if(isKeyPressed())
        {
            executeWhenPressed(inputReactor);
            logString.append(this.getClass().getName() + " 1\n");
        }
        else
        {
            executeWhenReleased(inputReactor);
            logString.append(this.getClass().getName() + " 0\n");
        }
    }
con le relative modifiche agli altri metodi...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 21:11   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ora però mi nasce un refactoring !!!

Mmmmmhhh...mettere un bel metodo in inputReactor ??!?!!?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 21:33   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Bene...ho tolto tutti quegli string buffer passati ed ho aggiunto due metodi a InputReactor:
Codice:

    public void logEvent(AbstractKeyEventHandler handler)
    {
        Integer keyStatus = handler.isKeyPressed() ? 1 : 0;
        logString.append(handler.getClass().getName() + " " + keyStatus.toString() + "\n");
    }
    
    
    public String getLogString()
    {
        return logString.toString();
    }
Questo mi ha permesso di rendere semplicissima tutta la procedura di log !!!

Fatto questo cia ggiorniamo a domani...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 01:25   #12
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Mi proto un po' avanti...altrimenti non finiamo più...

5. se premo destra e sinistra insieme non deve essera "appeso" niente alla stringa
6. se la gestione di un evento non produce effetti (rilascio di alcuni tasti) allora non deve essere scritto niente nel file
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 02:10   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ho deciso di eliminare il test 5 perchè questo evento può essere anche messo nel log... Non crea problemi nella riproduzione degli eventi... Se vogliamo evitare di scrivere una sequenza di questo tipo lo faremo dopo...ora complica eccessivamente il design, mentre non produce errori...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 02:25   #14
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Mentre una situazione in cui non ci deve essere assolutamente log è quando viene premuto un LEFT che poi viene ripetuto nello stesso reactToInput in cui viene premuto RIGHT...
Codice:
    
    
    public void testNoLogOnLeftRepeatedAndRightPressed()
    {
        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);        
        playField.getGridController().reactToInput(timer);
        
        timer.advance(config.getInteger("NormalRepeatDelay") + 1);
        
        input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);
        playField.getGridController().reactToInput(timer);
        
        assertEquals("no log on left and right pressed", "", 
            playField.getGridController().getEventLogString());       
    }

    
    public void testNoLogOnRightRepeatedAndLeftPressed()
    {
        input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);        
        playField.getGridController().reactToInput(timer);
        
        timer.advance(config.getInteger("NormalRepeatDelay") + 1);
        
        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
        playField.getGridController().reactToInput(timer);
        
        assertEquals("no log on left and right pressed", "", 
            playField.getGridController().getEventLogString());       
    }
Ho risolto spostando l'aggiornamento del log all'interno dei due handler...ovviamente per far funzionare tutto il resto devo spostarlo anche per gli altri handler...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 02:30   #15
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ora devo testare che non venga effettuato il log al rilascio di tutti i tasti meno down...
Codice:
    public void testNoLogOnKeysReleased()
    {
        input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);        
        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);        
        input.notifyKeyEvent(KeyEvent.BUTTON1, KeyEvent.PRESSED);        
        input.notifyKeyEvent(KeyEvent.BUTTON2, KeyEvent.PRESSED);        
        input.notifyKeyEvent(KeyEvent.BUTTON3, KeyEvent.PRESSED);        
        playField.getGridController().reactToInput(timer);
        
        input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.RELEASED);        
        input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.RELEASED);        
        input.notifyKeyEvent(KeyEvent.BUTTON1, KeyEvent.RELEASED);        
        input.notifyKeyEvent(KeyEvent.BUTTON2, KeyEvent.RELEASED);        
        input.notifyKeyEvent(KeyEvent.BUTTON3, KeyEvent.RELEASED);                
        
        playField.getGridController().reactToInput(timer);
        
        assertEquals("no log on right, left, down, button 1, 2, 3 release", "", 
            playField.getGridController().getEventLogString());       
    }
Ho risolto mettendo la chiamata a logEvent solo dove serve...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 11:20   #16
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Prossimo test:
Codice:
    
    
    public void testLogFileCreated()
    {
        playField.createLogFile("data/playField.log");
        LogFile log = playField.getLogFile();
        assertTrue("log file was not correctly created", log.isCreated());
    }

Ultima modifica di cionci : 17-02-2006 alle 11:30.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 11:59   #17
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Prossimo test:
Codice:
    

    public void testLogFileWritingAndReading()
    {
        playField.createLogFile("data/playField.log");
        LogFile log = playField.getLogFile();
        
        log.write("xxxx");
        log.write("yyyy");
        
        log.openForReading();
        
        StringBuffer string;
        
        log.read(string);
    
        assertTrue("log file was not correctly written", "xxxx", string.toString());

        log.read(string);

        assertTrue("log file was not correctly written", "yyyy", string.toString());
    }
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 14:54   #18
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Help...ragazzi serve un pair programmer... Io devo andare via e mi sa che non posso lavorarci per il fine settimana... C'è qualcuno che può aiutare nihil84 per completare il task ?

La classe di log è già pronta...basta integrare le varie infomazioni (seed eventi e gemme) e produrre l'output...
Ricordatevi che le gemme sono lì solo a titolo informativo, infatti il random seed è sufficiente a determinare la sequenza di gemme estratte...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 15:31   #19
nihil84
Junior Member
 
L'Avatar di nihil84
 
Iscritto dal: Jan 2006
Città: Cecina (LI)
Messaggi: 10
Ragazzi ho bisogno d'aiuto!
Ci sono dei particolari della meccanica del gioco che non mi sono ancora perfettamente chiari.

Il mio account emme esse enne dovebbe essere pubblico, altrimenti contattatemi in privato e decidiamo come comunicare.

mi dispiace, ma ancora non sono in grado di proseguire da solo

non manca molto, dai!
__________________
A Bright (http://www.the-brights.net)

Linux is user-friendly...
It is just selective about who its friends are
nihil84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Starlink Mobile: SpaceX potrebbe lanciar...
Volkswagen trasforma lo stabilimento di ...
Meta AI più reattivo e imparziale...
In Cina la prima GPU discreta al mondo c...
Vertiv CoolCenter, il sistema di raffred...
Konecta entra nel Kraken BPO Partner Pro...
Un dialogo con l'AI sposta voti meglio d...
iPhone 17 al minimo storico: oggi il 256...
Gli utenti italiani scelgono ChatGPT: &e...
Anche Xiaomi avrà il suo trifold:...
È Natale in casa Tesla: arriva la...
Shai-Hulud diventa più cattivo: e...
Aereo ultraleggero si schianta in atterr...
Windows 11 ha una nuova schermata Esegui...
Netflix si prende HBO, Harry Potter e il...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 18:56.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v