• Super User

    senza if e esle if i cavalli si muovono ?


  • User

    si muovono grazie al comando this._x++;


  • Super User

    Allora,
    all'inizio del ciclo, scrivi cavalli_array*.id=i;

    Poi if e else if diventano così:
    if (this._x>=variabili_array[this.id]) {
    this._x = variabili_array[this.id];
    this.onEnterFrame = null;
    } else if (this._x>=traguardo) {
    this.onEnterFrame = null;
    _root.gotoAndStop(2);


  • User

    Ci sono!!!! :vai:
    **
    l'istruzione:**
    cavalli_array*.onEnterFrame = function() {

    va cambiata in this.onEnterFrame = function() e posizionata prima delle:
    var variabili_array:Array = new Array(this.a, this.b, this.c, this.d, this.e, this.f);
    var cavalli_array:Array = new Array(f_blu, f_rosso, f_verde, f_giallo, f_viola, f_arancio);

    Yessssssss :fumato:

    Ora l'unico problema rimane che il filmato deve passare al secondo frame solo dopo che i primi passano il traguardo e non solo il primo. :mmm:

    Cmq, grazie Flep! grazie Onsitus
    E scusate per la rottura di scatole! :ciauz:

    Pri


  • User

    Col metodo LoadVars non riuscivo a caricare le variabili della posizione dei cavalli.
    Alla fine il buon vecchio loadVariables mi ha salvato la vita!! :yuppi:

    Un'altra cosa Flep. Mi dicevi che per far aumentare la velocità al cavallo con il punteggio più alto sarebbe bastato inserire al posto di:

    cavalli_array*._x++

    questo codice:
    cavalli_array*._x+=variabili_array*; :arrabbiato:

    Ma non va bene così. La variabile della posizione, infatti, rappresenta solo il numero sul quale si dovrà fermare il cavallo una volta arrivato.
    Forse però se facessi una proporzione tra il punteggio massimo e il numero dei cavalli.....
    :mmm:


  • User

    Ed ecco il codice giusto!
    Spero possa essere d'aiuto a chi come me si è trovata di fronte a questo problema:

    stop();
    loadVariables("file.txt",this);
    this.onEnterFrame = function() {
    var traguardo:Number = 750;
    var variabili_array:Array = new Array(this.a, this.b, this.c, this.d, this.e, this.f);
    var cavalli_array:Array = new Array(this.f_blu, this.f_rosso, this.f_verde, this.f_giallo, this.f_viola, this.f_arancio);
    for (var i:Number = 0; i<cavalli_array.length; i++) {
    //cavalli_array*._x++;
    cavalli_array*._x = cavalli_array*._x + (variabili_array*/600);
    //trace(cavalli_array*);
    //trace(variabili_array*);
    if (cavalli_array*._x>=variabili_array*) {
    cavalli_array*._x = variabili_array*;
    cavalli_array*.onEnterFrame = null;
    } else if (cavalli_array*._x>=traguardo) {
    cavalli_array*.onEnterFrame = null;
    _root.gotoAndStop(2);
    }
    }
    };

    :ciauz:
    Pri


  • User

    Dimenticavo...
    Manca ancora l'istruzione che invia al secondo frame solo dopo che almeno 3 cavalli abbiamo raggiunto l'obiettivo...

    Vabbé...non credo manchi molto...vero Flep? vero Onsitus?
    Ancora grazie...
    Pri


  • Super User

    @priscilla73 said:

    Dimenticavo...
    Manca ancora l'istruzione che invia al secondo frame solo dopo che almeno 3 cavalli abbiamo raggiunto l'obiettivo...

    Sara perche il traguardo e di 750, posizione a quale nessun cavallo arriva.:bho:


  • Super User

    Crei un' altra variabile numerica all' inizio:
    var counter:Number=0;

    poi ogni volta che un cavallo supera il traguardo aumenti di 1 counter e controlli se è = 3 fai eseguire 🙂


  • User

    Grazie Flep!
    Non sono riuscita a fare proprio come dicevi tu ma il risultato penso che sia piu' o meno lo stesso.
    Ho inserito il la variabile counter, come puoi vedere, ma ho dovuto assegnargli il valore 1.
    Non so bene perchè ma ad un certo punto del loop, credo, il comando:
    cavalli_array*.onEnterFrame = null
    annulla praticamente l'aggiunta di +1 alla variabile counter che cosi riparte da dalla somma precedente.
    Ho ovviato facendo partire il counter da 1 e non dandogli così il tempo di diminuire ma credo di sia una sporcatura. Credo che se i cavalli avessero punteggi molto distanti tra loro (tipo 1600, 1000 e 800) a quel punto la mia soluzione non funzionerebbe, perchè il counter avrebbe tutto il tempo di diminuire....

    stop();
    loadVariables("file.txt",this);
    this.onEnterFrame = function() {
    var traguardo:Number = 700;
    var counter:Number = 1;
    var variabili_array:Array = new Array(this.a, this.b, this.c, this.d, this.e, this.f);
    var cavalli_array:Array = new Array(this.f_blu, this.f_rosso, this.f_verde, this.f_giallo, this.f_viola, this.f_arancio);
    for (var i:Number = 0; i<cavalli_array.length; i++) {
    //cavalli_array*._x++;
    cavalli_array*._x = cavalli_array*._x + (variabili_array*/300);
    trace(cavalli_array*);
    trace(variabili_array*);
    trace(counter);
    if (cavalli_array*._x>=variabili_array*) {
    cavalli_array*._x = variabili_array*;
    cavalli_array*.onEnterFrame = null;
    } else if (cavalli_array*._x>=traguardo) {
    counter = counter+1;
    cavalli_array*.onEnterFrame = null;
    //_root.gotoAndStop(2);
    } else if (counter>=3) {
    _root.gotoAndStop(2)
    ;
    }
    }
    }


  • Super User

    metti

    if(counter>=3)

    all' interno dell' esle if, dopo che fermi l'onEnterFrame


  • User

    Grande Flep!
    Ora funziona a meraviglia!

    Grazie moltissime!:D
    Kiss
    Pri