Hyper-Horst Geschrieben 11. Dezember 2009 Geschrieben 11. Dezember 2009 (bearbeitet) Hallo zusammen, ich brauche Hilfe bei einem kleinen Softwareprojekt, an dem ich mich gerade versuche. Und zwar kurz zum "SOLL-Zustand": Ich brauche ein Programm/eine Weboberfläche/wie auch immer, wo ich 4x4 Kreise sehe, auf die ich Klicken kann. Wenn ich sie angeklickt habe, sollen sie die Farbe wechseln (oder irgendwie erkennbar machen, dass sie geklickt wurden). Und wenn ich nochmal klicke, sollen sie wieder in den Ursprungszustand zurück. Die Kreise sollen übrigens LEDs darstellen! Jede LED hat eine bestimmte Bezeichnung (z.b. LED 1, Ebene 1). Diese Bezeichnung soll nun wenn ich eine LED anklicke noch in ein Textdokument geschrieben werden. Wenn ich die nächste anklicke, soll diese Bezeichnung einfach unten drunter geschrieben werden, usw. Diese 4x4 LEDs gibts noch dazu 4 Mal, eben in 4 "Ebenen". Ich hab schon mehrere Ansätze, aber komm einfach nicht weiter! Erst habe ichs mit HTML und Javascript versucht (kleiner Ausschnitt aus meinem Code): <map name="ebene1"> <area shape="circle" coords="18,20,20" onclick="LED1()" alt="LED 1, Ebene 1" title="LED 1, Ebene 1"> <area shape="circle" coords="94,20,20" onclick="LED2()" alt="LED 2, Ebene 1" title="LED 2, Ebene 1"> usw... Hab im Hintergrund einfach eine schematische Grafik gemappt ... Bei onclick rufe ich eine Funktion auf, allerdings kann Javascript leider ja nicht auf ein Dateisystem zugreifen?! Und die Kreise verändern kann ich ja auch nicht direkt ... oh mann Dann hab ichs noch mit HTML/CSS versucht, hab einfach pro LED einen Verweis auf "#" gemacht mit dem Zeichen '°'. In CSS dann eben formatiert dass visited anders aussieht als der normale Link .. aber das ist ja ne total bescheuerte Lösung, und in eine Datei schreiben .. nuja Im Angang mal ein Screenshot von der Javascript-Lösung, so in etwa stell ich mir das halt vor vom optischen her ... Hoffe ihr versteht mein Anliegen und könnt mir ein paar Tipps und Vorschläge geben! Danke schonmal im Vorraus! Bearbeitet 11. Dezember 2009 von Hyper-Horst Zitieren
_n4p_ Geschrieben 11. Dezember 2009 Geschrieben 11. Dezember 2009 Hab im Hintergrund einfach eine schematische Grafik gemappt ... Bei onclick rufe ich eine Funktion auf, allerdings kann Javascript leider ja nicht auf ein Dateisystem zugreifen?! Und die Kreise verändern kann ich ja auch nicht direkt ... oh mann also eine große grafik ist ein problem ^^ mach 2 kleine 1 kreis normal und einmal "angeklickt" dann kannst die grafik per js austauschen. javascript hat kein zugriff auf das dateisystem, is richtig. käme jetzt drauf an wo die datei geschrieben werden soll. auf dem server -> stichwort AJAX auf dem client -> nun, gibts nich. möglichkeit wäre den text in ner textbox bzw anderem fenster anzuzeigen damit der benutzer es selbst speichert. Zitieren
Hyper-Horst Geschrieben 14. Dezember 2009 Autor Geschrieben 14. Dezember 2009 Mh okay, also für jede LED jeweils 2 kleine Grafiken ... bzw. kann ja immer die 2 geichen verwenden, nur anders positioniert. Das hört sich gut an! Mh, das mit der Textbox ist zwar nicht wirklich kompfortabel, aber wäre mal eine erste Lösung ... vielleicht gibts da noch andere Ideen? Aber vielen Dank schonmal Zitieren
mbembenek Geschrieben 15. Dezember 2009 Geschrieben 15. Dezember 2009 Hallo, da wirst du mit Javascript, CSS und HTML arbeiten müssen. 2 Bilder Pro LED ist schon rechtens Javascript: die erste Anzeige der Bilder sind in Links und ein link pro LED Dann schreibst du in den Link by OnMouseOver das 2. Bild und bei dem Click auf der LED eine Javascriptfunktion die Überprüft welche LED geklickt wurde und ob sie aktiv oder inaktiv ist. Dementsprechend kannst du dann auch die Text schreiben und entsprechend das Bild tauschen. Du kannst ja jeden Link mit einer id bezeichnen. zb: id="led1" und schon weißt du auch was geklickt wurde. Gruß Mike Zitieren
Hyper-Horst Geschrieben 16. Dezember 2009 Autor Geschrieben 16. Dezember 2009 So, natürlich treten nun weitere Fehler auf ... Ich hab den Bildwechsel vorgendermaßen realisiert: <div style="position:absolute; top:35px;left:10px;"> <img id="img" name="led1,1" src="aus.png" width="30" heigth="30" onclick="wechsel();schreiben('LED1')"> </div> <div style="position:absolute; top:100px;left:10px;"> <form name="herkunft" action="#"> <input name="textfeld"> </div> Und die entsprechenden JS-Funktionen: intImage = 2; function wechsel() { switch (intImage) { case 1: img.src = "aus.png" intImage = 2 return(false); case 2: img.src = "ein.png" intImage = 1 return(false); } } function schreiben(bla){ document.herkunft.textfeld.value=bla; } Jetzt habe ich ja aber ganz viele "LEDs" die ich jeweils tauschen muss, denen muss ich jeweils ja eine andere ID im <img>-Tag geben. Das heißt aber, es müsste für jede einzelne LED eine extra Funktion vorhanden sein, die im Endeffekt aber immer genau das gleiche macht ... geht es, die Quelle über eine anderes "Attribut" zuzuweisen, als über die ID? So, dann zum Thema Textbox. Wenn ich die zweite LED drücke (und dort über onlick die Funktion schreiben() aufrufe, überschreibt er mir das, was bereits ins Textfeld reingeschrieben wurde einfach wieder mit dem neuen ... also es steht quasi immer nur die als letztes gedrückte LED drin! Boa, so schwer ist das alles doch gar nicht, aber hab total den Hänger :upps Danke für eure Hilfe schonmal! Zitieren
Hyper-Horst Geschrieben 16. Dezember 2009 Autor Geschrieben 16. Dezember 2009 Das Problem mit dem Textfeld hab ich gelöst! Er schreibt jetzt immer schön untereinander, welche LED ich angeklickt habe Und zwar hab ich meine Funktion folgendermaßen verändert: function schreiben(bla){ document.herkunft.textfeld.value +=bla+"\n"; } Jetzt könnte ich das Ganze im Prinzip schon fertig machen, allerdings wird meine Javascript-Datei, wenn ich für jeden LED eine eigene "wechsel()"-Funktion schreiben muss, mit insgesamt 64 LEDs schnell sehr unübersichtlich ... wenns da noch andere Ideen gäbe ... Zitieren
_n4p_ Geschrieben 16. Dezember 2009 Geschrieben 16. Dezember 2009 für das schreiben haste doch auch nur eine funktion, oder? 1) inline events sind nicht standardkonform, zu lösen wäre das auch in javascript, stichworte: getElementsByTagName() und compat addEventHandler 2) in der funktion kannst du this.src nutzen um das bild des angeklickten elementes zu ändern (weil dein click event direkt am bild hängt) Zitieren
Hyper-Horst Geschrieben 10. Februar 2010 Autor Geschrieben 10. Februar 2010 Hey Leute, hab schon lang nix mehr von mir hören lassen, sorry! Mein Vorhaben funktioniert mittlerweile wunderbar ... nur hab ich immernoch das Problem, dass ich für jede LED eine eigene "Bildwechsel-Funktion" brauche! Mit der "getElementsByName"-Geschichte ist mir da nämlich immernoch nicht geholfen! Hier mal ein Ausschnitt aus meinem Code: n = 2; function wechsel(bla1,bla2,i) { switch (n) { case 1: document.getElementsByName("img")[i].src = "aus.png"; n = 2; document.herkunft.textfeld.value +=bla1+"\n"; return(false); case 2: document.getElementsByName("img")[i].src = "ein.png"; n = 1; document.herkunft.textfeld.value +=bla2+"\n"; return(false); } } Das Problem liegt auf der Hand, denn ich aktiviere z.B. die erste LED. Wenn ich nun eine weitere aktivieren will, springt die Funktion logischerweise ja aber in Fall 1 .. also "aus"! Die LED ist ja aber noch aus ... Wie kann ich das Lösen? Hab schon versucht, "n" als Array zu deklarieren (als Index könnt ich ja wieder "i" nehmen) aber das hat auch nicht funktioniert ... Bin über jeden sinnvollen Kommentar froh! Danke schonmal Zitieren
_n4p_ Geschrieben 10. Februar 2010 Geschrieben 10. Februar 2010 du könntest auch einfach prüfen was grad in .src steht function wechsel(bla1,bla2,i) { if (document.getElementsByName("img")[i].src == "aus.png") { document.getElementsByName("img")[i].src = "ein.png"; } else { document.getElementsByName("img")[i].src = "aus.png"; } } Zitieren
kingofbrain Geschrieben 11. Februar 2010 Geschrieben 11. Februar 2010 Warum übergibst Du denn nicht die ID des "img" an die Funktion? Dann kannst Du mit diesem Parameter und *einer* Funktion jedes beliebige Bild austauschen. Peter Zitieren
Hyper-Horst Geschrieben 11. Februar 2010 Autor Geschrieben 11. Februar 2010 (bearbeitet) Ich übergebe eine fortlaufende Nummer ("i"). Die ist ist in der Funktion ja der Array-Index ... Wie genau meinst du das mit der img-ID? Die Lösung mit if-else funktioniert auch nicht, denn jetzt springt er immer in den "Ja-Teil" der Verzweigung, egal wo ich wann draufklicke! Edit: Das Prinzip ist mir schon klar, das Problem liegt aber daran, dass die "Tausch-Variable" für jede LED getrennt "ein" oder "aus" schaltbar sein muss! Das hab ich ja auch schon mit nem Array versucht ... Bearbeitet 11. Februar 2010 von Hyper-Horst Zitieren
_n4p_ Geschrieben 11. Februar 2010 Geschrieben 11. Februar 2010 hab da mal kurz was zusammen gebastelt, vielleicht hilft dir das weiter.blub.zip Zitieren
kingofbrain Geschrieben 11. Februar 2010 Geschrieben 11. Februar 2010 Wie genau meinst du das mit der img-ID? Du hast ein img-Element: <img id="img" name="led1,1" src="aus.png" width="30" heigth="30" onclick="wechsel();schreiben('LED1')"> Jedem dieser Elemente gibst Du eine eindeutige ID (z.B. "LED 1"). Jetzt gibst Du der Funktion "wechsel()" auch diese ID mit (wechsel("LED 1"). Dann kannst Du mit getElementById(idParameter) auf dieses eine Element zugreifen. Peter Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.