Bonjour à tous, je viens vous demander un peu d'aide, je débute en programmation et donc j'ai un projet en javascript (algoscript ) à faire
C'est donc une horloge qui marche parfaitement SAUF à un unique endroit. J'ai décider d'implémenter un chronomètre (programme appelé "Chrono()" ici ) qui finalement s'avère faire planter l'environnement de programmation.
"
function Horloge() {
var x0;
var y0;
var x1;
var y1;
tortueEnabled = false;
for (i = 108; i <= 110; i = i + 1) {
Cercle(650, 350, i, 'black');
}
for (i = 108; i <= 110; i = i + 1) {
Cercle(350, 350, i, 'black');
}
for (i = 0; i <= 5; i = i + 1) {
Cercle(650, 350, i, 'black');
}
for (i = 750; i <= 754; i = i + 1) {
Cercle(500, 500, i, 'black');
}
for (i = 696; i <= 700; i = i + 1) {
Cercle(500, 500, i, 'black');
}
for (i = 0; i <= 10; i = i + 1) {
Cercle(500, 500, i, 'black');
}
for (i = 0; i <= 59; i = i + 1) {
x0 = (54 * Math.cos(i * 2 * Math.PI / 60) + 650);
y0 = (54 * Math.sin(i * 2 * Math.PI / 60) + 350);
if (i % 5 == 0) {
x1 = (50 * Math.cos(i * 2 * Math.PI / 60) + 650);
y1 = (50 * Math.sin(i * 2 * Math.PI / 60) + 350);
} else {
x1 = (52 * Math.cos(i * 2 * Math.PI / 60) + 650);
y1 = (52 * Math.sin(i * 2 * Math.PI / 60) + 350);
}
Ligne(x0, y0, x1, y1);
}
for (i = 0; i <= 59; i = i + 1) {
x0 = (375 * Math.cos(i * 2 * Math.PI / 60) + 500);
y0 = (375 * Math.sin(i * 2 * Math.PI / 60) + 500);
if (i % 5 == 0) {
x1 = (350 * Math.cos(i * 2 * Math.PI / 60) + 500);
y1 = (350 * Math.sin(i * 2 * Math.PI / 60) + 500);
} else {
x1 = (362.5 * Math.cos(i * 2 * Math.PI / 60) + 500);
y1 = (362.5 * Math.sin(i * 2 * Math.PI / 60) + 500);
}
Ligne(x0, y0, x1, y1, '#000000');
}
}
function Aiguille(temps, taille, couleur, centrex, centrey) {
var x0;
var y0;
var x1;
var y1;
temps = temps - 15;
x0 = centrex - ((taille / 10) * Math.cos(temps * 2 * Math.PI / 60));
y0 = centrey - ((taille / 10) * Math.sin(temps * 2 * Math.PI / 60));
x1 = (taille * Math.cos(temps * 2 * Math.PI / 60) + centrex);
y1 = (taille * Math.sin(temps * 2 * Math.PI / 60) + centrey);
Ligne(x0, y0, x1, y1, couleur);
}
function Chrono() {
var aujourdhui3;
var sec;
var msec;
var sec2;
var sec3;
var msec2;
var msec3;
while (input !== 13) {
aujourdhui2 = new Date();
}
aujourdhui3 = new Date();
sec2 = aujourdhui2.getSeconds();
sec3 = aujourdhui3.getSeconds();
msec2 = aujourdhui2.getMilliseconds();
msec3 = aujourdhui3.getMilliseconds();
sec = sec3 - sec2;
msec = msec3 - msec2;
Aiguille(sec, 45, 'red', 650, 350);
Aiguille(((msec * 6) / 100), 30, 'black', 650, 350);
}
function Temps(heure, minutes, secondes) {
var aujourdhui;
var millisecondes;
var jour;
var mois;
var annee;
var time;
var time2;
aujourdhui = new Date();
annee = aujourdhui.getFullYear();
mois = aujourdhui.getMonth();
jour = aujourdhui.getDate();
heure = aujourdhui.getHours();
minutes = aujourdhui.getMinutes();
secondes = aujourdhui.getSeconds();
millisecondes = aujourdhui.getMilliseconds();
ShadowOn();
Aiguille((heure + (minutes / 60)) * 5, 175, 'black', 500, 500);
Aiguille(minutes + (secondes / 60), 275, 'black', 500, 500);
Aiguille(secondes + (millisecondes / 1000), 325, 'red', 500, 500);
ShadowOff();
if (secondes <= 9) {
secondes = '0' + secondes;
}
if (minutes <= 9) {
minutes = '0' + minutes;
}
if (heure <= 9) {
heure = '0' + heure;
}
if (jour <= 9) {
jour = '0' + jour;
}
if (mois <= 9) {
mois = '0' + mois;
}
time = jour + '/' + mois + '/' + annee
time2 = heure + ':' + minutes + ':' + secondes;
Texte(325, 340, time2, 'black');
Texte(320, 360, time, 'black');
}
function ResetGraph() {
Initialiser();
Horloge();
Temps();
Chrono()
}
/* Debut */
var aujourdhui2;
var input = 1;
document.addEventListener('keydown', function(ChronoTrigger) {
input = ChronoTrigger.keyCode
});
setInterval('ResetGraph()', 1);
/* Fin */
"
La fonction Chrono est donc sensée récupérer la date dans une variable aujourdhui2 (variable globale, je sais pas si c'est le problème ) tant que le chrono n'est pas déclenché puis dans une autre variable aujourdhui3 (variable locale cette fois ).
Une fois le chrono déclenché, la variable aujourdhui2 n'est plus "actualisée" tandis que aujourdhui3 l'est toujours.
Je fais ensuite une soustraction de ces deux variable et j'affiche les aiguilles associées mais malheureusement ça ne fonctionne pas
Merci 