0 - Einleitung - 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]https://www.geogebra.org/images/ggb/toolbar/mode_zoom.png[/icon] [b][size=150][u]Beide Skripting-Arten im Vergleich:[/u][/size][/b][br]Am einfachsten ist [color=#6557d2][b]GeoGebra Skript[/b][/color], denn es wird einfach nur eine Auflistung von deutschsprachigen GeoGebra-Befehlen angegeben, wie man sie auch in der Eingabezeile eingeben kann. Beim Aufruf des Skriptes, werden die Befehle hintereinander ausgeführt. Befehle von GeoGebra Skript sind auch auf der [url=https://wiki.geogebra.org/de/Skripting_(Befehle)]GeogebraWiki-Seite[/url] hinterlegt.[br]Viele Anwendungen kommen mit 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 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]Nicht nur eine Ausgabe, auch die Programmstruktur ist übersichtlicher als in GeoGebra Skript.[br]So kann man z.B. 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. Klicken einer Schaltfläche) muss man sich vorher entscheiden, welches Skript man verwendet - in einem Applet jedoch kann man bei Bedarf eine Schaltfläche mit GeoGebra Skript und eine andere Schaltfläche mit JavaScript ein Skript ausführen lassen., 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]
2 - Auslesen von Zahlenwerten mit JavaScript
Mit der "alert"-Methode lassen sich Rückmeldungen in einem GeoGebra-Applet recht schnell und schick wiedergeben.[br][br]Der Befehl [b]ggbApplet.getValue("[/b][i]Variablenname_in_GeoGebra[/i][b]");[/b] überträgt den in der GeoGebra-Umgebung festgelegten Wert in die JavaScript-Umgebung.[br][br][icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u]Arbeitsauftrag:[/u][/b][br]Drücke den blauen Button. Beobachte die Ausgabe sowie das Eingabefeld.
Einstellung des Buttons
[quote][u]CODE zum Kopieren:[/u][br][color=#6557d2][b]var a = ggbApplet.getValue("a");[br]alert("Der Wert von a ist "+a+".");[br][/b][/color][/quote][br][b][u]Anmerkungen:[/u][/b][br]Der Befehl [b]var a = ggbApplet.getValue("a");[/b] holt sich den Wert der Zahl a aus dem GeoGebra-Applet und speichert ihn in der Skripting-Umgebung. Nun kann man hier mit der Variablen "arbeiten" (Rechnungen, Werte ändern, Ausgabe).[br][br]Der Befehl [b]alert("Der Wert von a ist " +a+".");[/b] verknüpft den Text "[i]Der Wert von a ist [/i]" mit dem [i]Wert von a[/i], der je nach eingegebenem Wert variabel sein muss.[br][i]"." [/i]am Ende des Befehls rundet den ausgegebenen Satz mit einem Satz-Ende-Punkt ab.[br]Die Pluszeichen verknüpfen die Eingaben.[br][br]Gibt man anstelle einer Zahl ein Zeichen oder eine Zeichenkette ein, so wird das Eingabefeld rot und in der Ausgabe erscheint "Der Wert von a ist [b]NaN[/b]." Das ist die Abkürzung für [b][u]N[/u][/b]ot [u][b]a[/b][/u] [u][b]N[/b][/u]umber.
5 - Verändern von Zahlenwerten mit JavaScript
Der Befehl [b]ggbApplet.getValue("[/b][i]Variablenname_in_GeoGebra[/i][b]");[/b] überträgt den in der GeoGebra-Umgebung festgelegten Wert in die JavaScript-Umgebung.[br][br]Der Befehl [b]ggbApplet.setValue("[/b][i]Variablenname_in_GeoGebra[/i][b]", [/b][i]Variablenwert_in_der_Skripting-Umgebung[/i][b]);[/b] überträgt den in der JavaScript-Umgebung festgelegten Wert in die GeoGebra-Umgebung.[br][br][icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u]Arbeitsauftrag:[/u][/b][br]Drücke den blauen Button. Beobachte die Ausgabe sowie das Eingabefeld.
Einstellung des Buttons
[quote][u]CODE zum Kopieren:[/u][br][color=#6557d2][b]var a = ggbApplet.getValue("a");[br]a=a+1;[br]ggbApplet.setValue("a",a);[br]alert("Der Wert von a ist "+a+".");[br][/b][/color][/quote][br][br][b][u]Anmerkungen:[/u][/b][br]Der Befehl [b]var a = ggbApplet.getValue("a");[/b] holt sich den Wert der Zahl a aus dem GeoGebra-Applet und speichert ihn in der Skripting-Umgebung. Nun kann man hier mit der Variablen "arbeiten" (Rechnungen, Werte ändern, Ausgabe).[br][br]Die Zeile [b]a = a + 1;[/b] erhöht den Wert von a um 1. Alternativ ist auch [b]a +=1;[/b] möglich.[br][br]Der Befehl [b]ggbApplet.setValue("a", a);[/b] speichert den neuen Wert aus der Skripting-Umgebung in der GeoGebra-Umgebung als neuen Wert der Zahl a ab.[br][br]Der Befehl [b]alert("Der Wert von a ist " +a+".");[/b] verknüpft den Text "[i]Der Wert von a ist [/i]" mit dem [i]Wert von a[/i], der je nach eingegebenem Wert variabel sein muss.[br][i]"." [/i]am Ende des Befehls rundet den ausgegebenen Satz mit einem Satz-Ende-Punkt ab.[br]Die Pluszeichen verknüpfen die Eingaben.[br][br][br][b][u]ZUSATZ:[/u][/b][br]Natürlich könnte man auch folgenden CODE verwenden:[br][color=#6557d2][b]var a = ggbApplet.getValue("a");[br]ggbApplet.setValue("a",a+1);[br]alert("Der Wert von a ist "+a+".");[br][br][/b][/color]In diesem CODE versteckt sich ein kleiner Denkfehler - probiere ihn doch einfach mal aus und überlege dir, warum Wert und Ausgabe nicht übereinstimmen.
8 - Wenn-dann mit JavaScript und alert-Ausgabe
Der Befehl [b]ggbApplet.getValue("[/b][i]Variablenname_in_GeoGebra[/i][b]");[/b] überträgt den in der GeoGebra-Umgebung festgelegten Wert in die JavaScript-Umgebung.[br][br]Für die Prüfung von Bedingungen benutzt man eine "wenn-dann-Anweisung" ("if-else-Anweisung"):[br][b]if ([/b][i]Bedingung[/i]) [b]{[/b][br][i]Anweisung1[/i][br][b]}[br][br][/b][b]else {[br][/b][i]Anweisung2[br][/i][b]}[br][/b][br]Die entsprechenden Blöcke sind durch geschweifte Klammern { } getrennt.[br][br][br][icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u]Arbeitsauftrag:[/u][/b][br]Drücke den blauen Button. Aktiviere das Kontrollfeld und drücke erneut den Button.
Einstellung des Buttons
[b][u]Anmerkungen:[/u][/b][br]Der Befehl [b]var a = ggbApplet.getValue("a");[/b] holt sich den Wert der Zahl a aus dem GeoGebra-Applet und speichert ihn in der Skripting-Umgebung. [br]Diese Variable a hat im Beispiel oben nur zwei Werte (boolesche Werte), nämlich wahr|true (Kontrollkästchen aktiviert) und falsch|false (Kontrollkästchen nicht aktiviert).[br][br][u][size=150]Wenn-dann-Anweisung:[/size][/u][br][b]if (a==true) { [/b] [color=#6aa84f][i]// "Wenn der Wert von a wahr ist, dann ..." [/i][/color][br][b]alert("Das Kästchen ist aktiviert.");[/b] [i][color=#6aa84f]// "... dann gib den Satz aus."[/color][/i][br][b]}[br]else {[/b] [color=#6aa84f][i]//"Ansonsten - also wenn in diesem Fall der Wert von a nicht wahr (d.h. falsch) ist, dann ..."[/i][/color][br][b]alert("Das Kästchen ist nicht aktiviert."); [/b][i][color=#6aa84f]// "... dann gib den Satz aus."[/color][/i][br]}[br][br]Je nachdem welche Bedingung wahr ist, wird der entsprechende Block aufgerufen und die Anweisung (hier: die Alert-Ausgabe) ausgeführt.[br][br][u]Wichtig dabei ist:[/u][br]Für die Überprüfung einer Bedingung muss man Ausdrücke vergleichen mit folgenden Operatoren:[br]== gleich[br]!= Ungleichzeichen[br]> größer[br]>= größer gleich[br]< kleiner[br]<= kleiner gleich
11 - Benutzung von GeoGebra-Befehlen mit evalCommand
[size=85](entnommen und angepasst aus: [url=https://wiki.geogebra.org/en/Reference:GeoGebra_Apps_API]https://wiki.geogebra.org/en/Reference:GeoGebra_Apps_API[/url])[/size][br][br]Nicht für jede Anwendung in GeoGebra steht ein eigener JavaScript-Befehl zur Verfügung.[br]GeoGebra Skript hingegen hat für jede Anwendung einen passenden Befehl.[br]Will man die Vorzüge von JavaScript nutzen und trotzdem die gewohnten GeoGebra Skript Befehle verwenden, so ist die Funktion [b]ggbApplet.evalCommand()[/b] die Lösung für dieses Problem. [br][br][b]ggbApplet.evalCommand("...")[/b] wertet die angegebene Zeichenkette so aus, wie sie bei der Eingabe in die Eingabeleiste von GeoGebra ausgewertet werden würde. [br]Mehrere Befehle könnte man auch auf einmal übergeben, indem man sie mit [b]\n[/b] trennt.[br][br][color=#ff0000][u][b]ACHTUNG:[/b][/u] Es müssen englische Befehlsnamen von GeoGebra Skript verwendet werden.[/color][br][br]Die typischsten Befehle finden sich unter: [url=https://wiki.geogebra.org/de/Skripting_(Befehle)]https://wiki.geogebra.org/de/Skripting_(Befehle)[/url] oder über die Suchfunktion auf dieser Seite.[br][br][b][u]TIPP:[/u][/b][br]Sobald man einen passenden deutschen Befehl gefunden hat, kann man auf der GeoGebra-Seite unten rechts die Sprache auf Englisch stellen und erhält den passenden Befehl für [b]ggbApplet.evalCommand("...")[/b].[br][img][/img]
[icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [b][u]Arbeitsauftrag 1:[/u][/b][br]Drücke den blauen Button und beobachte die Text-Ausgabe.[br]
Einstellung des Buttons
[quote][u]CODE zum Kopieren:[/u][br][color=#6557d2][b]ggbApplet.evalCommand("a=RandomBetween(1,6)");[/b][/color][/quote][br][b][u]Anmerkungen:[/u][/b][br]Der Befehl [b][color=#6557d2]ggbApplet.evalCommand("a=RandomBetween(1,6)");[/color][/b] erzeugt mithilfe des GeoGebra-Befehls [b][color=#6557d2]RandomBetween(1,6) [/color][/b]eine Zufallszahl zwischen 1 und 6.[br][br]Der GeoGebra-Befehl ist auf Englisch - der zugehörige deutschsprachige Befehl lautet [b]Zufallszahl(1,6)[/b].[br][br][u][i]VORGEHENSWEISE:[/i][/u][br][list][*]Finde den passenden Befehl für dein Skripting - HIER: [url=https://wiki.geogebra.org/de/Zufallszahl_(Befehl)]https://wiki.geogebra.org/de/Zufallszahl_(Befehl)[/url][br][/*][*]Stelle (wie oben beschrieben) die Seite auf Englisch um - HIER: [url=https://wiki.geogebra.org/en/RandomBetween_Command]https://wiki.geogebra.org/en/RandomBetween_Command[/url][/*][*]Verwende diesen englischsprachigen Befehl mit [b][color=#6557d2]ggbApplet.evalCommand("...");[/color][/b] in der JavaScript-Umgebung.[/*][/list]
[icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [u][b]Arbeitsauftrag 2:[/b][/u][br]Das folgende Applet soll die Benutzung von [b]ggbApplet.evalCommand("...")[/b] aufzeigen. Dazu ist zusätzlich unter der Schaltfläche das Skripting der Schaltfläche sichtbar. Auf der linken Seite befindet sich das (noch leere) Algebra-Fenster der GeoGebra-Umgebung.
12 - Button - Funktion vorstellen
[icon]/images/ggb/toolbar/mode_showhidelabel.png[/icon] [u][b]Arbeitsauftrag:[/b][/u][br]Betätige den Button.
[b][u]Skripting - Globales JavaScript:[/u][/b]
Eine Funktion ([b]function[/b]) ist ein Stück eines Codes, der von einer anderen Stelle (HIER: Die Betätigung des Buttons) beliebig oft aufgerufen werden kann.[br][br]Durch die Definition von Funktionen im Globalen JavaScript sind die wesentlichen Programmierbausteine an einer Stelle gesammelt. Beim Finden eines Fehlers muss man also meist nur diesen Quellcode durchschauen und nicht an vielen verschiedenen anderen Stellen nach dem möglichen Fehler suchen.
[b][u]Skripting - Schaltfläche - BEI MAUSKLICK:[/u][/b]
Die Funktion [b]test()[/b] aus dem Globalen JavaScript wird bei Mausklick aufgerufen.