Accelerometer Game Controller

by Technopolis STREAM in Circuits > Arduino

917 Views, 1 Favorites, 0 Comments

Accelerometer Game Controller

WALLPAPER - Protect Leonardo.png

Voorlopige Text...

MATERIAAL

TALK 01 - Beeldmateriaal.jpg
  • Arduino Leonardo: een microcontroller-bord als brein van onze game controller.
  • Micro USB kabel: om onze game controller aan te sluiten aan een computer.
  • Breadboard: zo hoeven we niet te solderen en blijft ons ontwerp makkelijk aanpasbaar.
  • Breadboard jumper wires: om alle componenten met elkaar te verbinden.
  • MPU6050 accelerometer: een sensor die versnellingen in de verschillende richtingen kan lezen, zoals je vaak in smartphones, hoverboards en balancerende robots vindt.
  • Twee mini push buttons: om knoppen te programmeren die los staan van onze accelerometer.

Optioneel:

  • Breadboard en Arduino houder: om compact te kunnen werken.

ARDUINO SOFTWARE

Voor we kunnen beginnen aan de bouw- en programmeerpret hebben we de juiste software nodig om het brein van onze game controller, een Arduino Leonardo, te kunnen besturen. Om dit te installeren, ga je als volgt te werk:

  • Ga via volgende link naar de downloadpagina van Arduino:
  • Kies voor de juiste software op basis van je operating systeem.
  • Klik op download.
  • Je hebt nu een (.exe) bestand dat je uitvoert door er op te dubbel klikken om de installatie te vervolledigen.

!!! Wij hebben onze controller gecreëerd met het gedownloade programma. De Windows App versie kan dit evengoed, maar kan kleine verschillen hebben in aanpak.

  • Open de Arduino software.
  • Connecteer je Arduino Leonardo met je micro USB kabel aan je computer, de Leonardo drivers worden automatisch geïnstalleerd (dit gebeurt enkel als het de eerst keer is dat je de Arduino aansluit).

Als je nog niet zo vertrouwd bent met Arduino software, of je controleert graag eens of je Arduino Leonardo foutloos verbinding maakt met je computer, dan kan je dat makkelijk testen met een voorbeeldprogramma:

  • Kies via Bestand > Voorbeelden > 01.Basics > Blink om een voorbeeldprogramma te openen.
  • Vervolgens kies je bij Hulpmiddelen > Board > Arduino Leonardo om de software te laten weten welk type board wij gaan gebruiken.
  • Selecteer de juiste seriële poort door bij Hulpmiddelen > Poort > COMx (Arduino Leonardo te kiezen. Dit doe je om aan te geven via welke USB poort je Arduino communiceert.
  • Klik in de linkerbovenhoek op het pijltje symbool om het voorbeeldprogramma te uploaden.
  • Links beneden zie je een indicatie die aantoont dat het programma aan het uploaden is, gevolgd door de boodschap 'uploaden voltooid' bij succes.

!!! Als het uploaden niet lukt en een rode foutmelding geeft dan ligt dit vaak aan een fout in de code. In dit geval gebruiken we een foutloze voorbeeldcode, waardoor de fout bij de connectie tussen de Leonardo en je computer moet liggen.

LIBRARY FOLDER

Arduino's zijn in staat om heel veel data te verwerken. Dit zorgt er voor dat er ook veel code nodig is om deze data correct te compileren. Om deze code niet eindeloos lang en complex te schrijven, maken wij gebruik van Arduino Libraries, bibliotheken van code die bepaalde sensors gaan sturen en ons werk een stuk makkelijker maken. Ons project gebruik drie soortgelijke libraries: Wire, I2Cdev en MPU6050. De Arduino software heeft een goede basis aan libraries ingebouwd, alsook onze eerste (Wire) bibliotheek, maar de twee andere dienen we zelf nog te installeren:

  • Volg deze link en klik op 'Clone or Download' en download de ZIP file
  • Pak de ZIP file uit om toegang te krijgen tot de bestanden.
  • In de bekomen map vind je via i2cdevlib-master > Arduino de folders 'I2Cdev' en MPU6050.
  • Kopieer beide mappen naar de Arduino map via C >Program Files > Arduino > Libraries.

!!! Indien je de bij de installatie van de software zelf een andere locatie opgegeven hebt dan, vind je de nodige mappen daar. Het is niet de bedoeling dat je zelf een map aanmaakt.

  • Sluit de Arduino software af en start ze opnieuw op om toegang tot de libraries te krijgen.
  • Via Schets > Bibliotheek Gebruiken kan je controleren of nu ook I2Cdev en MPU6050 te vinden zijn.

ACCELEROMETER - DE THEORIE

TALK 01 - Beeldmateriaal2.jpg

Een accelerometer werkt op basis van het piezoelectrisch effect. Stel je een kubusvormig doosje voor waar een klein balletje in zit (zoals in de bovenstaande illustratie) waar elke wand gemaakt is uit piezoelektrische kristallen. Wanneer je de kubus kantelt verplaatst het balletje zich naargelang de zwaartekracht. Waar het balletje de kubus wanden raakt ontstaat er piezoelectrische stroom. De drie paar evenwijdige wanden van de kubus worden gekoppeld aan de driedimensionale X, Y en Z assen. Afhankelijk van de piezoelectrische stroom geproduceerd langs deze wanden kunnen we zo de versnelling in drie dimensies bepalen.

Om een praktijkvoorbeeld te geven: In elke smartphone zit tegenwoordig ook standaard een accelerometer. Deze zorgt er onder andere voor dat je scherm automatisch meedraait als je smartphone kantelt.

ACCELEROMETER - DE PRAKTIJK

TALK 01 - Beeldmateriaal3.jpg

We weten nu dat een accelerometer de versnelling in de X, Y en Z as kan meten, maar met onze Arduino software kunnen we die data ook echt zien en opvolgen. Om dit te doen ga je als volgt te werk:

  • Sluit de accelerometer aan volgens bovenstaand schema en verbind de Arduino Leonardo met je computer.

!!! De accelerometer wordt voorzien van de nodige pinnen om makkelijk op een breadboard te prikken, maar deze pinnen dienen wel nog gesoldeerd te worden. Je krijgt de optie om die haaks op je breadboard te plaatsen (bespaart plaats) of evenwijdig zoals in ons voorbeeld.

  • Download ons 'MPU6050_intro' bestand en open deze in de Arduino software.
  • Controleer of je boardtype en poort nog steeds juist staan.
  • Klik in de linkerbovenhoek op het pijltje om het programma up te loaden.
  • Selecteer via Hulpmiddelen > Seriële Monitor
  • Een nieuw venster opent met 3 kolommen met getallen, dit zijn de versnellingen in de X, Y en Z assen.
  • Beweeg je accelerometer om de versnellingen in alle richtingen te zien.

Terwijl we onze versnellingsdata voor ons hebben kunnen we meteen verkennend werk doen voor onze game controller. Leg de Arduino en accelerometer plat op de tafel en noteer gemiddelde X en Y waarde (mag een ruwe schatting zijn). Onderneem daarna volgende stappen:

  • Kantel de accelerometer 45° naar rechts en noteer de gemiddelde X waarde.
  • Kantel de accelerometer 45° naar links en noteer de gemiddelde X waarde.
  • Kantel de accelerometer 45° naar voor en noteer de gemiddelde Y waarde.
  • Kantel de accelerometer 45° naar achter en noteer de gemiddelde Y waarde.

Downloads

GAME CONTROLLER

TALK 01 - Beeldmateriaal4.jpg

Klaar voor het echte werk! We gebruiken onze accelerometer samen met twee drukknoppen om het brein van onze eigen game controller te worden. Koppel de Arduino en accelerometer los en bouw het geheel opnieuw op volgens bovenstaand schema.

!!! De mini push buttons hebben vaak een buiging in hun beentjes. Druk die plat met een punttang om ze makkelijker in je breadboard te krijgen.

  • Download ons 'MPU6050_gamecontroller' bestand en open deze in de Arduino software.
  • Verbind je Arduino en klik in de linkerbovenhoek op het pijltje om het programma up te loaden.
  • De Arduino Leonardo stuurt nu constant informatie door naar je computer. Wil je de datavoer even pauzeren, koppel dan de jump wire op pin 12 even los, en verbind die opnieuw als je verder wilt gaan.
  • Proficiat! Je hebt nu een basis controller gemaakt, test het gerust eens uit op pacman.

Geen paniek als je controller niet metéén doet wat je had verwacht. Dat betekent gewoon dat we nog calibratie werk hebben om de controller aan te passen naar onze noden. Daarvoor duiken we in de Arduino code

CODE - USED LIBRARIES

TALK 01 - Beeldmateriaal5.jpg

Het leuke aan Arduino code is dat deze snel aanpasbaar is zonder dat je daarvoor een uitgebreide programmeerkennis moet hebben. Om je op weg te helpen overlopen we kort waar je wat vindt, en wat je kan aanpassen om je controller kalibreren.

In de 'MPU6050_gamecontroller' code vind je een heleboel lichtgrijze tekst. Dat is tekst die geen invloed heeft op de code, maar die dient om de code wat te structureren. Ook tekst die na // komt, staat los van de code en dient als verduidelijking. De eerste echte code vinden we terug onder de titel 'Used Libraries', daar herken je meteen de libraries die we in stap drie geïnstalleerd hebben.

  • #include <I2Cdev.h> geeft aan dat we de 'IC2dev' bibliotheek gaan gebruiken
  • const int ENABLE = 12 geeft aan dat we pin 12 gebruiken als veiligheid. Is deze pin niet verbonden dan stopt ons programma automatisch.
  • const int A_BUTTON = 6 geeft aan dat onze A knop aangesloten is op poort 5

!!! De code onder Setup zijn afspraken tussen je Arduino en je computer over hoe deze communiceren, in ons geval laten we dit deel code gewoon zoals ze is.

CODE: LOOP

TALK 01 - Beeldmateriaal6.jpg

Onder de titel 'Loop' vind je lijnen code die non stop draaien als onze Arduino Leonardo verbonden is met de computer en pin 12 is aangesloten. Het is ook meteen het deel van de code waar we het meest kunnen aanpassen. De code onder 'button A' en 'button B' is gekoppeld aan onze mini push buttons kan je aanpassen door in de code Keyboard.release ('a') en Keyboard.release ('a') twee maal de ('a') te vervangen door eender welke ander keyboard toets.

!!! Sommige keyboardtoetsen moet kan je niet rechtstreeks intypen maar hebben een code. Zo zou je de 'Delete' knop moet ingeven als 'KEY_DELETE' of als decimale waarde '212'. Een lijst van dit soort uitzonderingen binnen arduino vind je via deze link. Wil je nog meer info dan kijk je best eens naar de ASCII tabel.

Onder de right, left, up en down vind je vrij gelijkaardige code als bij de buttons, het grote verschil zit hem in het if (accx < -20000) deel van de code. Dit verwijst naar de accelerometer: als de accelerometer naar rechts kantelt en een waarde kleiner dan -20000 leest dan wordt de rechter pijltoets (KEY_RIGHT_ARROW) ingeduwd. Kantel je opnieuw naar links en wordt de waarde groter dan -20000 dan laat hij de rechter pijltoets opnieuw los.

Hier komen de genoteerde waarden uit stap vijf van pas. Pas de waarden aan naargelang je noties om zo jou specifieke accelerometer te kalibreren. Je kan deze waarden bijstellen naargelang je eigen speelstijl.

Tenslotte vinden we helemaal onderaan de code delay (50). Dat stukje code vertraagt het aantal keyboard toetsen die je computer doorkrijgt. Merkje dat je controller te veel commando's doorgeeft dan verhoog je dit getal met enkele tientallen. Reageert alles te traag dan verklein je het getal wat.

Trial en error is de boodschap!