1_Vorwort
Mit diesem Buch wollen wir den Einstieg in das Skripting mithilfe von JavaScript erleichtern.[br][br]Die nächste Seite zeigt exemplarisch im Kontext linearer Funktionen erste Möglichkeiten auf, die die Benutzung von JavaScript bieten kann. Hier dürft ihr zunächst einfach mal "spielen" und ausprobieren, wie es auch Schülerinnen und Schüler bei der Benutzung von GeoGebra-Applets oft tun.[br][br]Die nachfolgenden Informationen und Übungen in diesem Buch sollen dann dabei helfen, die Grundbefehle von JavaScript in GeoGebra kennenzulernen, zu verstehen und anzuwenden.[br][br]Im Workshop mussten Schwerpunkte gesetzt werden. Die darüber hinausgehenden Inhalte dieses GeoGebra-Books wie z.B. das mit * markierte Kapitel "Eigenes Applet als Vorlage für Variationen" sind als Anknüpfungspunkte für spätere individuelle Vertiefungen gedacht. [br][br][b]Und nun viel Erfolg bei den ersten Schritten in Javascript![br][br][/b]Ingo und Olaf
Präsentation - GeoGebra-Javascript
1_Ausgabe
Hier lernst du, wie man mit JavaScript Rückmeldungen in einem GeoGebra-Applet geben kann.[br][br]Das nachfolgende Applet dient als Vorlage für Skripting-Lösungen. Du kannst es über die drei Punkte [b]⫶[/b] (oben rechts) direkt in der App (in einem neuen Fenster) öffnen und dort parallel weiterarbeiten:[br][img][/img][br][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u][size=150]Arbeitsauftrag zum Befehl "alert":[/size][/u][/b][br]Lass dir einen beliebigen Rückmeldetext einfallen, der nach Mausklick auf den Button erscheinen soll. [br]Erstelle dann mit dem Befehl [i][b]alert(...)[/b][/i] ein passendes kurzes Skript (im Register [i]Skripting[/i] unter den Einstellungen der Schaltfläche). Denke daran, auf JavaScript umzustellen. Gerne kannst du dabei die Formatierungsmöglichkeiten von unten testen.
[quote][u]CODE zum Kopieren:[/u][br][color=#6557d2][b]alert("Hallo");[br][/b][/color][/quote]
[b][u][icon]/images/ggb/toolbar/mode_zoom.png[/icon][/u] [u][size=150]Mögliche Formatierung der Alert-Ausgabe:[/size][/u][/b][br]\' einfaches Anführungszeichen innerhalb einer Zeichenkette[br]\" normales Anführungszeichen innerhalb einer Zeichenkette[br]\n Zeilenumbruch ([i]New Line[/i])[br]\t Tabulatorzeichen für tabellarische Ausgabe[br][br]alert("Die Zahl ist"+a); verbindet einen Text mit dem Wert der Variablen a, für a = 42 ergibt sich z.B. die Ausgabe: Die Zahl ist 42.
Hier gehts zum Lösungsvorschlag:[br][url=https://www.geogebra.org/m/m2bhcerb]https://www.geogebra.org/m/m2bhcerb[/url]
1_Grundlagen - Skripting
In einem GeoGebra-Applet kann man über die [b]⚙️Einstellungen[/b] eines Objektes (rechte Maustaste) den Tab für das Skripting aufrufen:
Skripte sind eine Abfolge von Befehlen, die nacheinander ausgeführt werden. GeoGebra bietet zwei Skriptsprachen um Befehle anzugegeben:[br][color=#6557d2][b]GeoGebra Skript[/b][/color] und [color=#6557d2][b]JavaScript[/b][/color] . [br][size=85](entnommen aus: [url=https://wiki.geogebra.org/de/Skripting]https://wiki.geogebra.org/de/Skripting[/url])[/size][br][br]Die Ausführung eines Skriptes (siehe Bild oben) kann ausgelöst werden durch:[br][list][*]"[b][color=#8e7cc3]Bei Mausklick[/color][/b]" (GeoGebra Skript oder JavaScript): Klicken auf ein bestimmtes Objekt[/*][*]"[b][color=#00ff00]Bei Update[/color][/b]" (GeoGebra Skript oder JavaScript): Aktualisierung ([i]Wert-Veränderung, Neudefinition[/i]) eines bestimmten Objektes[/*][*]"[b][color=#ff7700]Globales JavaScript[/color][/b]" (nur JavaScript): Laden der Datei ([i][color=#ff7700]function ggbOnInit() { ... }[/color][/i])[/*][*](nicht in diesem Workshop behandelt: Javascript Listeners - z.B. Benutzeraktionen überwachen)[/*][/list][br][icon]/images/ggb/toolbar/mode_zoom.png[/icon] [b][size=150][u]Beide Skripting-Arten im Vergleich:[/u][/size][/b][br]Einfacher ist zunächst die Verwendung von [color=#6557d2][b]GeoGebra Skript[/b][/color], denn es wird i.d.R. nur eine Auflistung von deutschsprachigen GeoGebra-Befehlen angegeben, wie man sie auch in der Eingabezeile eingeben kann. Beim Aufruf des Skriptes werden die Befehle dann hintereinander ausgeführt. Befehle von GeoGebra Skript sind auch auf der [url=https://wiki.geogebra.org/de/Skripting_(Befehle)]GeogebraWiki-Seite[/url] hinterlegt. Viele Anwendungen kommen mit einem einfachem GeoGebra Skript aus.[br][br][color=#6557d2][b]JavaScript[/b][/color] ist eine Programmiersprache, die vor allem im Internet eingesetzt wird. Im Gegensatz zu GeoGebra Skript kann man damit Befehle nicht nur einfach hintereinander ausführen lassen, sondern es können auch Kontrollstrukturen (wie [code]if[/code], [code]while[/code] und [code]for) [/code]verwendet werden. [br]JavaScript ist zwar in Englisch - findet man jedoch einen GeoGebra-Befehl auf Deutsch, kann man am Seitenende der [url=https://wiki.geogebra.org/de/Skripting_(Befehle)]GeogebraWiki-Seite[/url] schnell auf Englisch umstellen, um diesen Befehl ggf. in JavaScript benutzen zu können:[br][img][/img][br][br]JavaScript erlaubt das Benutzen aller in GeoGebra Skript hinterlegten Befehle.[br][br]Zusätzlich kann man über JavaScript seine Ausgabe eleganter gestalten.[br][br]Ein Vorteil liegt darin, dass die Programmstruktur übersichtlicher ist als in GeoGebra Skript.[br]So kann man z.B. an zentraler Stelle globale Funktionen mit Anweisungen erstellen, die in einem Skript von verschiedensten Objekten aufgerufen werden können. Das erspart erheblich Arbeit, vor allem wenn man immer mal wieder etwas ändern muss.[br][br]Abschließend kann man zusammenfassen:[br]Das Skripting mit JavaScript ist aufgrund der Kontrollstrukturen sehr vielseitig einsetzbar. Allerdings lassen sich viele Aufgaben mit dem einfacheren GeoGebraSkript bewältigen.[br]Bei der Ausführung eines Skriptes (z.B. nach Klicken einer Schaltfläche) muss man sich vorher entscheiden, welche Skriptsprache man verwendet - in einem Applet jedoch kann man bei Bedarf eine Schaltfläche mit GeoGebra Skript und eine andere Schaltfläche mit JavaScript verwenden, was folgendes Applet zeigt:
[size=85][b][u]Quellen:[/u][/b][br][url=https://wiki.geogebra.org/de/Skripting_(Befehle)]https://wiki.geogebra.org/de/Skripting_(Befehle)[/url][br][url=https://wiki.geogebra.org/de/Skripting]https://wiki.geogebra.org/de/Skripting[br]https://geogebra-institut.uni-landau.de/index.php/Programmieren_in_GeoGebra_mit_GeoGebra-_bzw._Java-Script[/url][/size]
1_Vorlage
Nun bist du selbst dran - wir werden versuchen mit dieser Schritt-für-Schritt-Anleitung das Einstiegs-Applet nachzubauen, um so die wichtigsten Grundbefehle in JavaScript kennenzulernen.[br][br][br][icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u][size=150]Arbeitsauftrag:[/size][/u][/b][br]Das nachfolgende Applet dient als Vorlage. Du kannst es über die drei Punkte [b]⫶[/b] (oben rechts) direkt in der App (in einem neuen Fenster) öffnen und dort parallel weiterarbeiten:[br][img][/img]
[icon]/images/ggb/toolbar/mode_zoom.png[/icon] [b][u][size=150]Für Interessierte - das Applet im Detail:[/size][/u][/b][br][i][u]1. Schritt:[/u][/i] Koordinatengitter anpassen[br]Art des Gitters: weites Gitter mit Abstand 0.5[br][img][/img][br]Punktfang (rot markiert): Am Koordinatengitter fixiert[br][br][i][u]2. Schritt:[/u][/i] Punkte eintragen - Gerade zeichnen[br]Die beiden Punkte [math]A[/math] und [math]B[/math] können nur die Koordinaten annehmen, die durch das Koordinatengitter (und den Punktfang) vorgegeben sind, hier in "0.5er-Schritten".[br]Die Gerade [math]f[/math] verläuft durch die beiden Punkte und ist somit "beweglich".[br][br][i][u]3. Schritt:[/u][/i] Zufallszahlen - Gerade erzeugen[br]Für Steigung [math]m[/math] und y-Achsenabschnitt [math]c[/math] werden Zufallswerte erzeugt - der Faktor 0.5 passt die Zahlen auf die oben erwähnten 0.5er Schritte an. Die Größe des Koordinatensystems muss sich an die Kombination der Maxima und Minima dieser Zahlen orientieren.[br]Die Gerade [math]g[/math] ist mit [math]y=m\cdot x+c[/math] zufällig erzeugt.[br][br][i][u]4. Schritt:[/u][/i] Textfeld[br]Aktuelle Definition der Geraden [math]g[/math] wird dem Benutzer durch ein Textfeld im Grafik-Fenster 2 angezeigt.[br][br][i][u]5. Schritt:[/u][/i] Schaltflächen[br]Erstelle zwei Schaltflächen im Grafik-Fenster 2 und benenne sie sinnvoll.
1_Ziele - neue Vorlage
Nun hast du zwar die beiden Schaltflächen mit JavaScript versehen - man kann aber seinen Score recht schnell erhöhen, indem man immer bei richtiger Lösung mehrmals auf den Button[img][/img]drückt .[br][br]Außerdem werden die Versuche nicht mitgezählt, so dass man jederzeit beliebig ausprobieren kann.[br][br][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u][size=150]Arbeitsauftrag:[/size][/u][/b][br]Falls du dein bisheriges Applet nicht gespeichert hast, kannst du mit dem nachfolgenden Applet als Vorlage weitermachen. Du kannst es wieder über die drei Punkte [b]⫶[/b] (oben rechts) direkt in der App (in einem neuen Fenster) öffnen und dort parallel weiterarbeiten:[br][img][/img]
Ideen für die weitere Verwendung deines Applets
Du hast nun ein Applet gestaltet, das Eingaben prüfen sowie Versuche und richtige Antworten zählen kann:[br][br][center][img][/img][/center]Damit hast du die Grundlage für diverse Anwendungsmöglichkeiten - du musst dein Applet jeweils nur geringfügig anpassen.[br][br][i][u][b]Hier ein paar Beispiele für die Verwendung deines Applets:[/b][/u][/i][br]- Punkt im Koordinatensystem einzeichnen[br]- Koordinaten von Punkten im Koordinatensystem ablesen (Umkehrung)[br][br]- Steigung einer Geraden im Koordinatensystem darstellen[br]- Wert der Steigung einer Geraden im Koordinatensystem ablesen (Umkehrung)[br][br]- Normalparabel im Koordinatensystem darstellen - Scheitelform[br]- Gleichung einer Normalparabel - Scheitelform - im Koordinatensystem ablesen (Umkehrung)[br][br]- Streckfaktor einer Parabel mit Scheitel (0|0) im Koordinatensystem darstellen[br]- Streckfaktor einer Parabel mit Scheitel (0|0) im Koordinatensystem ablesen (Umkehrung)[br][br]- Punktprobe in der Ebene und im Raum[br]- Lage zweier Geraden untersuchen[br][br]... und vieles, vieles mehr![br][br][br]Auf den Folgeseiten findest du konkret ausgearbeitete Umsetzungsbeispiele.
Einführendes Beispiel
Auf den letzten beiden Beispielseiten (und auch im Einstiegsbeispiel zum Workshop: https://www.geogebra.org/m/phwtkzma) sind mehrere Applets innerhalb einer Aktivität miteinander verknüpft.[br][br][br][icon]/images/ggb/toolbar/mode_zoom.png[/icon] [b][u]Arbeitsauftrag:[br][/u][/b]Drücke auf [b][color=#38761d]START [/color][/b]- den Rest erledigen die gekoppelten Applets.
[size=50][i]Die Applets wurden teilweise aus dem Buch "Einfache Symmetrie von Graphen" entnommen ([url=https://www.geogebra.org/m/zuvmcwf3]https://www.geogebra.org/m/zuvmcwf3[/url]) - sie sind mithilfe von JavaScript miteinander verknüpft.[br][/i][/size][br][br]Die folgende Aktivität skizziert das Vorgehen für das Verknüpfen "alter" vorhandener Applets im LIVE-Skripting.
Ausblick und typische Fehler
JavaScript ist zwar komplexer als GeoGebra Skript, bietet jedoch noch weitere sehr interessante Möglichkeiten.[br][br][icon]/images/ggb/toolbar/mode_viewinfrontof.png[/icon] [b][u][size=150]Gekoppelte Applets:[/size][/u][/b][br]Das Kapitel 7 des Workshops hat eine von vielen Anwendungsmöglichkeiten einer Kopplung von Applets beschrieben.[br]Dieses Wissen ermöglicht eine Vielzahl von weiteren zusätzlichen Anwendungsmöglichkeiten - zum Beispiel:[br][list][*]Aus dem Workshop: Punktestand übertragen [math]\longrightarrow[/math] Highscore[/*][*]Aus dem Workshop: verknüpfte Graphen von Funktion, 1. und 2. Ableitungsfunktion[br][/*][*]Escape-Room-Charakter von Aktivitäten - ein Kontrollkästchen in Applet 1 schaltet in Applet 2 eine weitere Herausforderung frei[br][/*][*]"Highscore über mehrere Buchseiten" [br][/*][*]... und vieles mehr :o)[/*][/list][br]Das folgende Buch zeigt die oben genannten und weitere Anwendungsmöglichkeiten:[br][url=https://www.geogebra.org/m/numzkews]https://www.geogebra.org/m/numzkews[br][br][/url]
[icon]https://www.geogebra.org/images/ggb/toolbar/mode_viewinfrontof.png[/icon] [b][u][size=150]Didaktisches Potenzial gekoppelter Applets:[/size][/u][/b][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_mincells.png[/icon] [u][b]Übersichtlichkeit:[/b][/u][br]Ein Applet wird nicht "überfrachtet" mit verschiedenen Funktionen / Schiebereglern / Punkten usw.[br]Trotzdem können Arbeitsschritte im folgenden Applet verarbeitet werden, z.B. die Eingabe einer passenden Funktionsgleichung.[br]Außerdem ist der Platz, den GeoGebra bietet, auf zwei Grafik-Fenster begrenzt. Durch Verknüpfen von Applets kann man beliebig viele Grafik-Fenster für das Erforschen von funktionalen Zusammenhängen nutzen.[br]Im Fullscreen-Modus hat man durch die Verteilung von Informationen auf mehrere Applets einen besseren Überblick.[br][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_mincells.png[/icon] [u][b]Highscore:[/b][/u][br]Erreichte Punkte bei Übungen können aufaddiert werden zu einem persönlichen Highscore.[br][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_mincells.png[/icon] [u][b]Mit einem Applet eine komplette Aktivität steuern:[/b][/u][br]Verknüpfte Kontrollkästchen oder verknüpfte Werte von Variablen erlauben das Steuern aller Aktivitäten durch ein einzelnes Applet, z.B. Bewegen eines Punktes in allen Applets einer Seite.[br][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_mincells.png[/icon] [u][b]Didaktische Entschleunigung:[/b][/u][br]Arbeitsschritte können kleinschrittig erfolgen, ohne dass im nächsten Applet oder Textfeld das Ergebnis sichtbar ist oder ein Applet überfrachtet wirkt. Bereits erzielte "Erfolge" in einem Applet werden automatisch ins nächste Applet übertragen.[br][b][u][br][icon]https://www.geogebra.org/images/ggb/toolbar/mode_mincells.png[/icon][/u] [u]Steuerung von Erarbeitungsphasen:[/u][/b][br]Einstieg, Erarbeitung und Ergebnissicherung erfolgen schrittweise - ein Merksatz wird erst nach Bearbeitung verschiedener Applets sichtbar.[br][br][b][i]... to be continued ...[/i][/b][br][br][br]
[icon]/images/ggb/toolbar/mode_sumcells.png[/icon] [b][u][size=150]Zusammenfassung - Schlussworte:[/size][/u][/b][br]Ziel dieses Workshops war es, möglichst niederschwellig und beispielhaft in das komplexe Thema JavaScript einzuführen. [br][br]Dabei wurde eine kleine Auswahl an Befehlen in JavaScript abgebildet. Die Kopplung von Applets oder das Speichern von Werten im Cache wurde am Ende kurz "angerissen", um das didaktische Potenzial aufzuzeigen.[br][br]Wenn die Teilnehmer den Workshop verlassen und sich dabei schon überlegen, wie sie das Kennengelernte anwenden können, haben wir unser Ziel erreicht :o)