PDA

View Full Version : Ma un diagrammino UML...


Bonfo
30-12-2005, 17:04
Qualcuno ha, da qualche parte, un diagrammma UML per capire come interagiscono le varie parti...

...lo so che dovrebbero bastare i test per capire come funziona il sistema, ma purtroppo ci vuole un tempo e pazienza, anche solo per capire in che ordine guardare le classi.
Anche solo di massima per farsi un'idea.

GRAZIE
Ciao

71104
30-12-2005, 18:56
Bonfo, il corso di Ingegneria del Software ti ha fatto male!!! :D
se vuoi qualche linea orientativa posso dirti che Game è la Main class ma anche Grid e GridController sono due classi molto importanti; inizialmente infatti avevamo solo Grid, e siccome stava diventando un monnezzaio dove buttavamo tutto il codice che non aveva altro posto, l'abbiamo scissa e abbiamo creato GridController: il controller si occupa della gestione della sua griglia, mentre la griglia adesso... è solo una griglia :) altro non fa che disegnare le celle semitrasparenti e gestire e disegnare la matrice di gemme.

forse hai capito poco del codice perché sei andato leggendo a casaccio; prova invece a cercare di capire come funziona uno specifico aspetto del programma; per esempio, come fa il programma a gestire la pressione dei tasti freccia? allora, parti dal game loop (file Game.java), ci stanno queste chiamate:

updateGrid();

render();

processInput();
processWindow();

sleepOneMillisecond();

i nomi che gli abbiamo dato sono talmente esplicativi che capisci subito che:
- updateGrid aggiorna la matrice della griglia (se una gemma sta cadendo continua a farla cadere, se ha finito di cadere attende un certo timeout, se il timeout è passato ne inserisce un'altra, e così via)
- render costruisce e visualizza il frame corrente (per il rendering usiamo OpenGL tramite delle librerie Java)
- processInput fa il poll della tastiera e vede se ci sono tasti premuti da processare
- processWindow non lo so manco io, ma siccome il nome è molto esplicativo penso che si occupi banalmente di gestire la finestra aperta dalle librerie che ci interfacciano a OpenGL (ad es. servirà penso a gestire l'eventualità che l'utente la chiuda o la sposti trascinandola col mouse)
- ed infine sleepOneMillisecond (e non so per certo neanche questo a cosa serva) probabilmente serve a mettere il thread in stato di sleep per breve tempo per evitare che succhi tutta la CPU :)
dunque direi che per scoprire il funzionamento dell'aspetto che ci siamo chiesti dovremmo andare dritti dritti in processInput... lì dentro vediamo innanzitutto un controllo per terminare il gioco se dal poll risulta premuto il tasto Esc, e poi, dopo qualche controllo sul timer per gestire le pressioni prolungate di tasti, una chiamata a un certo reactToInput; una volta entrati in questo reactToInput scopriamo che fa parte di una certa classe InputReactor che, a giudicare dal nome, si occupa di fare la gestione vera e propria degli input da tastiera, allora continuiamo a leggere il codice e continuiamo a scoprire tante cose interessanti e così via. :D
scusa se non finisco ma era solo per darti un'idea di come dovresti fare ^^

Bonfo
30-12-2005, 19:53
Lo so che i corsi all'università fanno male !!! :cry: :cry: :cry: :cry: :cry:

Cmq grazie mille perchè hai capito al volo quale era il mio problema...trovare il bamdolo della matassa !!!! :muro: :muro:
Avevo intuito l'importanza della class Grid e GridController leggendo qua e la nel forum...ma non ero riuscito a mettere insieme i pezzi...è tutta roba nuova!!

Ora sto zitto finchè non ho capito tutto!!! .... o quasi :D
Mi sa infatti che fra non molto tornerò a supplicare :ave: :help:

Grazie per la disponibilità...spero non abbiate voglia di spararmi di già ;)

VICIUS
30-12-2005, 19:53
Qualcuno ha, da qualche parte, un diagrammma UML per capire come interagiscono le varie parti...

...lo so che dovrebbero bastare i test per capire come funziona il sistema, ma purtroppo ci vuole un tempo e pazienza, anche solo per capire in che ordine guardare le classi.
Anche solo di massima per farsi un'idea.

GRAZIE
Ciao
Piacerebbe pure a me avere un class diagram o un po di documentazione in javadoc ma per ora non è fattibile. Il codice cambia troppo rapidamente e non abbiamo tools che possano generare in automatico queste cose. :(

ciao ;)

Vifani
31-12-2005, 01:44
Certo che ci sono i tools che generano quel tipo di grafici in automatico.

Un esempio? Omondo!

http://www.omondo.com/download/free/eclipse_3x/index.html

Qui potete scaricare il tool in versione gratuita. Io ci ho fatto il diagramma delle classi e quello delle componenti della mia tesi di laurea ;)

VICIUS
31-12-2005, 02:25
Certo che ci sono i tools che generano quel tipo di grafici in automatico.

Un esempio? Omondo!

http://www.omondo.com/download/free/eclipse_3x/index.html

Qui potete scaricare il tool in versione gratuita. Io ci ho fatto il diagramma delle classi e quello delle componenti della mia tesi di laurea ;)
Cavolo non lo conoscevo questo :eek: grazie per il link, quando ho tempo lo provo e se va tutto liscio abbiamo pure il diagramma UML :D

ciao ;)

cover
31-12-2005, 03:13
Provo pure io :D
Vic, a proposito, hai dato un occhio a quelli riguardanti la code coverage?
Quale ti sembra meglio? Io sono per cobertura, per il fatto della complessità..se si riesce a mettere a posto ^^°°°

VICIUS
31-12-2005, 13:11
Provo pure io :D
Vic, a proposito, hai dato un occhio a quelli riguardanti la code coverage?
Quale ti sembra meglio? Io sono per cobertura, per il fatto della complessità..se si riesce a mettere a posto ^^°°°
Ne ho provati un po' ma alcuni non mi funzionavano neanche :muro:. Per ora direi che possiamo puntare tranquillamente su cobertura. Per quanto riguarda la complessità dove sta il problema ?

ciao ;)

fek
31-12-2005, 15:02
Cobertura fa il report in HTML ed e' pilotabile da Ant?

Considerate anche Emma. No, non e' una nota maiala di quartiere :D

(Vic, quando puoi vieni online che ho bisogno di domandarti un paio di cose?)

cover
31-12-2005, 15:32
fek, una prova che avevo fatto con cobertura: http://www.revoc.net/testreport/
non è male, emma non mette la complessità. Sì, è pilotabile da ant
Altra cosa che può essere carina è jester (http://jester.sourceforge.net/) che cambia direttamente i valori nei test e li prova..

vic: quando avevo provato risultava qualche classe con complessità a 0 (es layermanager), magari ho sbagliato io (anzi, molto probabile, visto che ant l'ho visto un pò quando ho fatto quella prova ^^°°° )