Ardublockly - eine einfache Programmieroberfläche für die senseBox:edu

Von Mario am 27/06/2017
Ardublockly - eine einfache Programmieroberfläche für die senseBox:edu - Logo

Ardublockly für die senseBox:edu

Mit der senseBox:edu wollen wir einen einfachen Einstieg in die Programmierung und den Bau von Umweltmessgeräten schaffen. Bisher musste immer direkt in der Arduino IDE mithilfe von Programmierbefehlen programmiert werden. Nun ermöglicht eine grafische Oberfläche mit Blöcken einen noch einfacheren und schnelleren Einstieg.

Aktueller Stand und Funktionen

In die Oberfläche wurden Blöcke für die einzelnen Sensoren der senseBox:edu integriert. Die Sensoren können so einfach ausgelesen werden, wie es im Beispiel gezeigt wird.

/images/blog/2017-06-27-ardublocklysenseBox/ardublockly1.gif - Logo

Da der Arduino kein Display besitzt, müssen anderen Ausgabemöglichkeiten genutzt werden. Hier kann der Nutzer auswählen zwischen

Die senseBox Blöcke sind in drei Kategorien eingeteilt:

Installation

Grundvoraussetzung für die Verwendung von Ardublockly ist, dass die Arduino IDE installiert ist. (weitere Information auch hier)

Unter Arbublockly befindet sich eine online Version der Oberfläche, die ohne Installation auf den gängigen Browsern läuft. Hierbei muss allerdings der generierte Code mittels Copy and Paste in die Arduino IDE kopiert werden.

Die Offline-Variante der Ardublockly Oberfläche befinden sich im Github Repository in den Releases (die Releases werden in unregelmäßigen Abständen neu veröffentlicht). Hier gibt es für die gängigen Betriebssysteme (Windows, MacOS, Linux) eine jeweilige Version. Für die Offline Variante muss Python (mind. Version 2.7) installiert sein. Weitere Informationen und der Download der Software befinden sich auf der Python Homepgage. Unter MacOS ist Python bereits vorinstalliert. Hierbei muss nur die Ardublock.app in den Programmordner kopiert werden. Damit der direkte Upload oder das direkte Öffnen des Sketches in der Arduino IDE funktioniert, muss der Programmpfad in den Einstellungen gesetzt werden.

Damit die Sensoren ausgelesen werden können wird, eine Software Bibliothek benötigt. Diese beeinhaltet die Software für alle Sensoren, die in der senseBox:edu enthalten sind (senseBox-Library). Die Software Library muss heruntergeladen werden und in die Arduino IDE integriert werden (mehr Informationen dazu hier).

Verwendung der Oberfläche

Der Screenshot zeigt den Grundaufbau der Ardublockly Oberläche. Im Auswahlmenü rechts können die Programmierblöcke herausgezogen und in der Programmieroberfläche zusammengesetzt werden. Es empfiehlt sich mit dem Block “Arduino Führe zuerst aus/Arduino Endlosschleife” aus dem Bereich Funktionen zu starten.

Im rechten Fenster wird der generierte Code angezeigt. Mithilfe dieser Ansicht lässt sich nachvollziehen, welche Programmierbefehle hinter den Blöcken stehen. Neben den senseBox Blöcken gibt es eine Vielzahl von verschiedenen Blöcken, die es ermöglichen, komplexe Proramme zu schreiben ohne die Syntax der Programmiersprache mühsam erlernen zu müssen. Mithilfe der Ardublockly Oberfläche können auch schon jüngere Nachwuchswissenschaftler mit der senseBox:edu arbeiten. Durch das Parallele Anzeigen des Programmcodes wird der Schritt zu den ersten Textbasierten Programmen deutlich erleichtert.

/images/blog/2017-06-27-ardublocklysenseBox/ardublockly2.jpg - Logo

Ausblick

Wir arbeiten zurzeit an einem Buch (ähnlich unserer Anleitung zur senseBox:edu) speziell für die Ardublockly Oberfläche. Durch die starke Vereinfachung können nun die ersten Projekte in kürzerer Zeit durchgeführt werden und es bleibt mehr Zeit im Unterricht oder in Projekttagen, um die Messgeräte zu verwenden oder das Projekt noch komplexer auszubauen.

Die Oberfläche und vorallem die Übersetzung ins Deutsche sind noch nicht 100 Prozent fertiggestellt und beeinhalten noch kleinere Fehler. Solltet ihr Fehler feststellen, melden sie uns doch bitte über Github.

Credits und Lizenz

Die Grundoberfläche von Ardublockly stammt von carlosperate und basiert auf Google Blockly. Veröffentlicht ist das Projekt unter Apache License 2.0 (mehr informationen hier)