Nei nostri siti in Flash avvolte è necessario inserire un orario Analogico o Digitale

Il codice base per un ora Digitale è da inserire su un movie clip nell’evento onClipEvent(enterFrame):
onClipEvent (enterFrame) {
myDate = new Date(); // creo l’oggetto Date
this.ora.text = myDate.getHours(); // ora
this.minuti.text = myDate.getMinutes(); // minuti
this.secondi.text = myDate.getSeconds(); // secondi
}
Dovrete creare nel clip, testi dinamici di nome istanza ora, minuti, secondi
Ma qual’è la vera difficoltà a creare un orologio Analogico? Esatto! La rotazione delle lancette!
Vediamo la funzione che ci viene in aiuto e che nel tutorial capirete meglio:
function tickHands() {
var _loc1 = new Date(); // creo oggetto Data
hours = _loc1.getHours(); // ora
minutes = _loc1.getMinutes(); // minuti
seconds = _loc1.getSeconds(); // secondi
milSeconds = _loc1.getMilliseconds(); // millisecondi
hourHand._rotation = 30*(hours+1.666667E-002*minutes); // ruoto la lancetta delle ore
minHand._rotation = 6*(minutes+1.666667E-002*seconds); // ruoto la lancetta dei minuti
secondsRotation = 6*(seconds+1.000000E-003*milSeconds); // ruoto la lancetta dei secondi
multiple = secondsRotation%6; // imposto la variabile multiple
if (multiple<3) {
secondsRotation = Math.floor(secondsRotation/6)*6;
} else {
secondsRotation = Math.round(secondsRotation/6)*6;
}
// Imposto la rotazione della lancetta dei secondi
if (secondsRotation>180) {
if (secondsRotation == 186) {
secHand._rotation = -179;
}
// end if
secondsRotation = secondsRotation-360;
}
// Imposto il ritorno della lancetta
bounce(”_rotation”, secondsRotation, secHand, 3, 6.000000E-001);
++bounced;
}
Scarica il sorgente
Guarda il Tutorial
ABC, Design, Flash, Sviluppo, Tutorial

tag abilitati: <code> </code> | <a href=""> </a> | <b> </b> | <i> </i>
DoZ
2 Agosto 2007 alle 18:27 pm
Anchio avevo fatto il mio, qualche anno fa…
http://www.dozarte.com/what/portfol/orologio.htm
(credo ancora con Flash 4)
Julius
2 Agosto 2007 alle 20:52 pm
Veramente bello Doz, mi piace la prospettiva delle lancette bravo!
DoZ
4 Settembre 2007 alle 17:27 pm
Grazie.
Mi sono poi ricordato che avevo anche fatto un articolo nel blog, collegandomi ad un tutorial che avevo scritto per MMkit….
http://www.dozarte.com/wordpress/2006/08/14/costruiamo-un-orologio-analogico-flash5/
Julius
5 Settembre 2007 alle 9:06 am
good
MAnu
26 Febbraio 2008 alle 12:27 pm
Ciao
inanzitutto COMPLIMENTI!
una domanda:
è possibile aggiungere più orologi digitali con differenti fusi orari?
dovrei creare almeno 5 orologi Roma Tokyo NewYork Sydney Dubai..
Potrei aggingere o togliere le ore di differenza ma nn so come fare.
Mi aiuti? grazie!!!
Julius
26 Febbraio 2008 alle 20:09 pm
Ciao, ti basta individuare la variabile delle ore e sottrai il numero di ore di differenza per creare i diversi orari…
hours = _loc1.getHours()-1;