Wenn man Minecraft Pi installiert hat, ist auch die API also auch die Programmierschnittstelle verfügbar. Dann kann man mit wenigen Zeilen Python Sourcecode Modifikation und Erweiterungen programmieren. Wie wäre zum Anfang mit dem hinzufügen von explosivem TNT?
Grundsätzliches
Nachdem man Minecraft Pi mit dem simplen Aufruf sudo apt-get install minecraft-pi
installiert hat, steht nicht nur das Spiel (Creative Mode) sondern auch die Python 3 API, also die Programmierschnittstelle, zur Verfügung. Im Grunde gibt es nur wenige Befehle, die man nutzen kann. Mehr braucht es aber auch nicht um viele spaßige Dinge umsetzen zu können. Viele programmieren Spiele im Spiel (z. B. Snake) oder erweitern es um Zusatzfunktionen.
Eine tolle englische Anleitung bietet das MagPi Magazin Gratis Heft Essentials Minecraft.
Funktionen der API
Die Programmierschnittstelle bietet im wesentlichen folgende Funktionen:
- Auslesen der Spielerposition
- Setzen der Spielerposition (Teleportierung)
- Blocktyp auslesen
- Blocktyp setzen (Haupt und Untertyp)
- Ereignis bei Berührung eines Blocks mit dem Schwert
- Kameraposition ändern
- Nachricht im Spiel anzeigen
Initialisierung und Ausführen
Initialisiert wird die Schnittstelle mit folgendem Code
|
|
Der Verbindungsaufbau klappt aber nur, wenn das Spiel selbst gestartet ist, der Titelbildschirm reicht nicht. Mit dem mc
Objekt können dann alle Befehl ausgeführt werden. Für eine einfach Ausgabe muss man nur noch postToChat
hinzufügen.
|
|
Der Python Sourcecode muss in eine Datei gespeichert werden, z. B. tnt.py und mit dem Aufruf “python3 tnt.py” gestartet werden.
Spielerposition
Möchte man mit Positionen arbeiten ist zu beachten:
- X ist horizontal (links und rechts)
- Y ist vertikal (also oben und unten)
- Z ist in die Tiefe (hinten und vorne)
Folgender Sourcecode teleportiert, den Spieler 4 Blocke hoch.
|
|
Blöcke
Blöcke zu verändern ist auch sehr leicht, dazu verwendet man die Funktion getBlock
und setBlock
.
Folgender Sourcecode erzeugt unter dem Spieler einen TNT-Block, sofern er auf festem Untergrund steht.
|
|
Für den Block verwenden wir das Objekt block
um statt mit einer Nummer mit Namen die Böcke identifizieren zu können. Eine Liste der Blöcke bzw. Blocknamen findet man bei Minecraft Pi Edition API Reference. Der letzte Parameter der Funktion definiert die DataId des Blockes. Diese variiert den Blocktyp. Bei TNT definiert 1 eine aktivierbaren Typ, der dann durch das Schwert zum Explodieren gebracht werden kann.
Es gibt auch die Funktion setblocks
, damit können mehrere Blocke auf einmal gesetzt werden. Dazu gibt man zwei Positionen an, die den zu füllenden Bereich definieren. Optional kann auch wieder die DataId Nummer angegeben werden.
|
|
Ereignis bei Berührung eines Blocks (Schwert)
Eine spezielle Funktion ermöglicht es zu erkennen, wenn der Spieler Blöcke mit dem Schwert (rechten Maustaste) berührt.
Die Funktion pollBlockHits
holt sich diese Aktion in eine Variable. Die Feld-Variable kann dann einzeln abgearbeitet werden.
Allerdings muss man die Funktion zyklisch aufrufen. In diesem Beispiel wird für 15 Sekunden die Aktionen überwacht und eine Meldung ausgegeben.
|
|
Minecraft Pi - Sound Effects
Eine nützliche Idee hatte Martin O’Hanlon, er erweiterte das Programm um zusätzlich Soundeffekte. Das Spiel kommt nämlich im Original ganz ohne Soundausgabe daher. Dazu nutzte er einfach die Python 3 API um im richtigen Moment Sound zu erzeugen. Zum Beispiel Schrittgeräusche beim Laufen oder bei beim Einsatz des Schwerts. Das ganze wurde in seinem Blog im Eintrag Raspberry Pi - Minecraft - Sounds Effects beschrieben. Hier wurde aber die alte Python 2 Schnittstelle verwendet, sodass es aktuell nicht mehr nutzbar ist.
Der GC2 (Grazer Computer Club) hat sich nun dem Projekt angenommen und es auf Python 3 portiert und erweitert. Es ist auf dem GitHub Repository Minecraft Pi - Sound Effects verfügbar. Einerseits ist es nützlich für Spieler und andererseits zeigt es die Möglichkeiten der Python 3 API.
Folgende Änderungen wurden durchgeführt:
- Portierung auf Python 3
- Nur Public Domain Sounddateien
- Neue Sounddateien für (platschen, schwimmen, fliegen)
- Hintergrund Musik
- Sonstige Optimierungen
- Umwandlung von TNT auf explosives TNT (Aktivierung durch das Schwert)
- Erweiterung aktiviert sich nach dem Laden einer Karte (oder bei einem Absturz) automatisch
Installation
Zur Installation lädt man sich die Letztversion vom Repository herunter und startet das Python 3 Programm zusammen mit Minecraft.
cd ~
mkdir minecraft-sound
cd minecraft-sound
wget https://github.com/GrazerComputerClub/minecraft-sound/archive/0.3.zip
unzip 0.3.zip
cd minecraft-sound-0.3
Durch das modifizieren des Start-Scripts “/usr/bin/minecraft-pi”, wird die Sound Erweiterung automatisch gestartet und beendet.
#!/bin/sh
cd /home/pi/git/minecraft-sound
python3 minecraft-sound.py &
PID=$!
echo Minecraft Sound process PID is $PID
cd /opt/minecraft-pi || exit
if grep -q okay /proc/device-tree/soc/v3d@7ec00000/status \
/proc/device-tree/soc/firmwarekms@7e600000/status 2> /dev/null; then
export LD_PRELOAD=libbcm_host.so.1.0
export LD_LIBRARY_PATH=lib/mesa
else
export LD_LIBRARY_PATH=lib/brcm
fi
./minecraft-pi
echo stopping Minecraft Sound process
kill -KILL $PID
Beispielvideo für explosives TNT
Verlinkung
Minecraft Pi Edition API Reference
MagPi Magazin Essentials Minecraft
Ursprungsversion von Martin O’Hanlon, Raspberry Pi - Minecraft - Sounds Effects
GC2 Version Minecraft Pi - Sound Effects