• Das Erstellen neuer Accounts wurde ausgesetzt. Bei berechtigtem Interesse bitte Kontaktaufnahme über die üblichen Wege. Beste Grüße der Admin

[FRAGE] start und endzeit begrenzen nach aktueller Zeit, in einer bewegung

mrbelvedere58

New member
Hallo an alle,

Ich bin neu hier und habe nicht so viel Ahnung von js und hoffe ihr könnt mir helfen.

ich möchte das sich die Sonne nur zwischen der Startzeit und der Endzeit bewegt so das der Stand der Sonne abzulesen ist.

Das ganze ist teil einer Hauautomation, als Browser läuft nur der Firefox rund um die Uhr.

nur bekomme ich es nicht hin das es nach aktueller Zeit läuft.
Hier mein Skript:

Schon mal Danke im voraus, hoffe Ihr könnt mir helfen :)
Code:
<!DOCTYPE HTML>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 //EN" "">
<HTML>
<HEAD>
<meta charset="utf-8">
<title>Sonnenscheinzeit</title>

<STYLE type="text/css">
BODY {margin-top:0px;margin-left:0px;color: #ffffff;font-family: "Times New Roman",serif; font-size: 20px; }
.sun {position:absolute;left:150;top:13}
.maske{width:300px; height:132px; background-color:#000; border:1px solid #000000 }
.unter{margin-left:218px; margin-top:25px;position: absolute;display: block;}
.auf{margin-left:20px;margin-top:25px;position: absolute;display: block;}
.sonne {
	left: 20px; top: 0px; width: 23px; height: 23px; position: absolute; pointer-events: none; 
	background-image: none, url("");
 background-repeat: no-repeat; background-size: 100% 100%;
}
.bogen {
	height: 65px; top: 23Px; padding-bottom: 10px;left: 10px; width: 318px; display: block; position: relative; background-image: none, url(""); background-repeat: no-repeat; background-size: 100% 100%;
}
</STYLE>
 
<SCRIPT>
sunauf = '06:30';
sununter = '18:33';

start = 1.09 * Math.PI;  
ende = 1.91 * Math.PI;
radius=101;

function bewegen()
 {
    x=114+radius*Math.cos(start);
    y=114+radius*Math.sin(start);
 
     with(document.getElementById("sun").style)
      {
        left=x+"px";
        top=y+"px";
       }
       
  		start=start+0.05;  // schrittweite

		document.getElementById('auf').innerHTML = sunauf;
		document.getElementById('unter').innerHTML = sununter;
   window.setTimeout("bewegen()",300);
} 
 		


</SCRIPT>

</HEAD> 

<BODY onload="bewegen()">
	<div class= "maske">
		<div class= "bogen"></div>
		<div id="auf" class="auf"></div>
		<div id="unter" class="unter"></div>

	</div>	
	
	<DIV class="sun" id="sun">
		<div class="sonne"></div>
	</DIV>





</BODY>
</HTML>
 
Zuletzt bearbeitet:
Ich verstehe nicht ganz, was du machen willst. Willst du den aktuellen Sonnenstand anzeigen? Was soll in der Nacht angezeigt werden?

PS: Ich will dir ja nicht zu Nahe treten, aber das
nicht so viel Ahnung von js
merkt man sehr stark. Hast du den Code selber geschrieben? Der ist nämlich wirklich nicht gut: HTML ist invalide und inkonsistent geschrieben, inkonsistenter Codestil, globale Variablen im JS, Fehler in der Fehlerkonsole, Verwendung des "with"-Statements, String als Parameter von window.setTimeout(), unnötige DOM-Manipulation (du musst doch nicht in jedem Animationsframe die Zeitangabe schreiben).
 
Ich verstehe nicht ganz, was du machen willst. Willst du den aktuellen Sonnenstand anzeigen? Was soll in der Nacht angezeigt werden?

PS: Ich will dir ja nicht zu Nahe treten, aber das merkt man sehr stark. Hast du den Code selber geschrieben? Der ist nämlich wirklich nicht gut: HTML ist invalide und inkonsistent geschrieben, inkonsistenter Codestil, globale Variablen im JS, Fehler in der Fehlerkonsole, Verwendung des "with"-Statements, String als Parameter von window.setTimeout(), unnötige DOM-Manipulation (du musst doch nicht in jedem Animationsframe die Zeitangabe schreiben).

Hallo und vielen Dank für deine Antwort,
ja ich möchte den Aktuellen Sonnenstand anzeigen. Wenn die Sonne untergegangen ist soll die kleine Sonne auf ihrer Position stehen bleiben und um 00:00 zur Aufgangs zeit springen um dann am nächsten Tag wieder bei Sonnenaufgang starten, in der Nacht wird soweit nichts weiter Angezeigt.
Erst wieder am nächsten Tag wenn die Sonne auf geht.

ich habe Zeile 49 gelöscht sie gehört dort nicht hin.

Ich habe mir das ganze aus im Internet zusammen gestückelt und war schon stolz das sich überhaut was bewegt hat auch wenn es viele Fehler hat und unsauber Programmiert ist.
Aber man lernt immer dazu.
 
Zuletzt bearbeitet:
OK - woher willst du die Sonnenaufgangs- und -untergangszeiten nehmen? Berechnen? Tabelle?

Ich würde die Sonne ja wirklich "untergehen" lassen. Also langsam hinter dem Horizont verschwinden lassen.

Ich habe mir das ganze aus im Internet zusammen gestückelt und war schon stolz das sich überhaut was bewegt hat auch wenn es viele Fehler hat und unsauber Programmiert ist.
Ist ja auch OK, wenn man Anfänger ist. Jeder war das irgendwann mal. Wollte dich nur auf die Schwachstellen hinweisen.

Aber man lernt immer dazu.
Dazu ist ja so ein Forum auch da.

Deswegen können wir ja mal zusammen erarbeiten, wie man dein Problem löst. Ein Ansatz ist ja schon vorhanden.

Als erstes brauchen wir die aktuelle Zeit. Schau' dir dazu das an: https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/Date
Und als nächstes brauchen wir die Zeit seit dem Sonnenaufgang und die zwischen Sonnenauf- und untergang. Am besten schön dynamisch und das geht auch mit dem Date-Objekt.
 
Vielen Dank das du mir deine Hilfe anbietest,

ich habe jetzt die die Zeiten die benötigt werden in das Script eingefügt ich hoffe das du das so in etwa gemeint hast.

Code:
<STYLE>
.ausgabe {margin-top:0px;margin-left:0px;color: #000000;font-family: "Times New Roman",serif; font-size: 20px; }
</STYLE>
 
<SCRIPT>

var	startzeit = new Date();       // Sonnenaufgang
	 	startzeit.setHours(06);
		startzeit.setMinutes(30);
		startzeit.setSeconds(00);

var	endzeit = new Date();         // Sonnenuntergang
		endzeit.setHours(18);
		endzeit.setMinutes(15);
		endzeit.setSeconds(00);

function Uhr() {

 	aktuellezeit = new Date();
 	istzeit = aktuellezeit.getTime();						// startzeit
        vergangen = aktuellezeit.getTime() - startzeit.getTime(); 			// vergangene Zeit zwischen, Sonnenaufgang und Aktuelle Zeit
	sonnendauer = endzeit.getTime() - startzeit.getTime();				//  Zeit zwischen, Sonnenaufgang und Untergang

	document.getElementById('ausgabe').innerHTML = 'ist Zeit : '+istzeit+'<br>vergangene Zeit : '+vergangen +'<br>zwischen auf & unter : '+sonnendauer;
	
	window.setTimeout("Uhr()", 1000); // takt der uhr 1 sec	
}



sunauf = startzeit.getHours()+':'+startzeit.getMinutes();
sununter = endzeit.getHours()+':'+endzeit.getMinutes();

start = 1.09 * Math.PI;  
ende = 1.91 * Math.PI;
radius=101;

function bewegen()
 {
    x=114+radius*Math.cos(start);
    y=114+radius*Math.sin(start);
 
     with(document.getElementById("sun").style)
      {
        left=x+"px";
        top=y+"px";
       }
       
  		start=start+0.05;  // schrittweite

		document.getElementById('auf').innerHTML = sunauf;
		document.getElementById('unter').innerHTML = sununter;
   window.setTimeout("bewegen()",300);



} 
</SCRIPT>

</HEAD> 

<BODY onload="bewegen(), Uhr()" >
	<div class= "maske">
		<div class= "bogen"></div>
		<div id="auf" class="auf"></div>
		<div id="unter" class="unter"></div>

	</div>	
	
	<DIV class="sun" id="sun">
		<div class="sonne"></div>
	</DIV>

	<DIV id="ausgabe" class="ausgabe">
	</DIV>



</BODY>
</HTML>

habe leider nicht die Komplette html rein bekommen daher habe ich die Grafiken weg gelasse
 
Zuletzt bearbeitet:
Sehr schön - das sieht doch nicht schlecht aus.

Wenn man jetzt die beiden Skripte kombiniert und den Code noch etwas aufhübscht, kann in etwas sowas rauskommen:
Code:
<!DOCTYPE html>
<html>
<head>
<style>
BODY {margin-top:0px;margin-left:0px;color: #ffffff;font-family: "Times New Roman",serif; font-size: 20px; }
.sun {position:absolute;left:150;top:13}
.maske{width:300px; height:132px; background-color:#000; border:1px solid #000000 }
.unter{margin-left:218px; margin-top:25px;position: absolute;display: block;}
.auf{margin-left:20px;margin-top:25px;position: absolute;display: block;}
.sonne {
	left: 20px; top: 0px; width: 23px; height: 23px; position: absolute; pointer-events: none; 
	background-image: none, url("");
 background-repeat: no-repeat; background-size: 100% 100%;
}
.bogen {
	height: 65px; top: 23Px; padding-bottom: 10px;left: 10px; width: 318px; display: block; position: relative; background-image: none, url(""); background-repeat: no-repeat; background-size: 100% 100%;
}
</style>
 
<script>
window.onload = function(){
	var sonnenaufgang = {
		hours: 6,
		minutes: 45,
		seconds: 0
	}
	var sonnenuntergang = {
		hours: 19,
		minutes: 30,
		seconds: 0
	}
	
	document.getElementById('auf').innerHTML = sonnenaufgang.hours + ":" + sonnenaufgang.minutes;
	document.getElementById('unter').innerHTML = sonnenuntergang.hours + ":" + sonnenuntergang.minutes;
	
	function setSun(position){console.log(position);
		var sun = document.getElementById("sun");
		sun.style.display = (position < 0 || position > 1)? "none": "";
		
		var start = 1.09;  
		var ende = 1.91;
		var radius = 101;
		var angle = start + position * (ende - start);
		console.log(angle);
		
		angle *= Math.PI;
		
		sun.style.left = (114 + radius*Math.cos(angle)) + "px";
		sun.style.top = (114 + radius*Math.sin(angle)) + "px";
	}
	
	function Uhr(){
		var aktuellezeit = new Date();
		var now = aktuellezeit.getTime();
		
		aktuellezeit.setHours(sonnenaufgang.hours);
		aktuellezeit.setMinutes(sonnenaufgang.minutes);
		aktuellezeit.setSeconds(sonnenaufgang.seconds);
		
		var start = aktuellezeit.getTime();
		
		aktuellezeit.setHours(sonnenuntergang.hours);
		aktuellezeit.setMinutes(sonnenuntergang.minutes);
		aktuellezeit.setSeconds(sonnenuntergang.seconds);
		
		var end = aktuellezeit.getTime();
		
		setSun((now - start) / (end - start));
		
		window.setTimeout(Uhr, 1000); // takt der uhr 1 sec	
	}
	Uhr();
}
</script>

</head> 

<body>
	<div class= "maske">
		<div class= "bogen"></div>
		<div id="auf" class="auf"></div>
		<div id="unter" class="unter"></div>

	</div>	
	
	<dic class="sun" id="sun">
		<div class="sonne"></div>
	</div>
</body>
</html>
- geh' einfach alles Zeile für Zeile durch und melde dich, wenn du irgendwas nicht verstehst.
 
Zurück
Oben