Youtube Channel
scrivimi: fraranux@gmail.com
chiamami: 345 04.22.\pi

mercoledì 18 giugno 2014

Nuovo Game Controller con Arduino Micro, sensori capacitivi e play-doh

Ho costruito un paio di anni fa un controller per questo gioco al museo, richiedeva i caratteri QWERT, con Arduino Duemilanove è stato un pasticcio, inviao i caratteri sulla seriale e poi li leggevo con il monitor e poi il gioco in qualche modo (ma per me è ancora un mistero) se li ciucciava.
Poi è arrivato il Leonardo, carichi la libreria giusta ed il gioco è fatto.
Poi è arrivao il micro, idem come sopra.
Il Micro lo colleghi direttamente all'USB, lo programmi come un Arduino normale, i pin sono gli stessi. Fine.
In questo post pubblico semplicemente qualche foto del lavoro, i pochi componenti li ho saldati direttamente sulla scheda, un lavoro veloce veloce. Pubblico in fondo anche il codice.

Sulla sinistra in alto le 5 resistenze di elevato valore, in alto a destra i led che indicano la "pressione" del pulsante.



il collegamento dei pin verso l'esterno è affidato ad una serie di 5 coccodrilli (che verranno presumibilmente collegati ad oggetti modellati con il play doh)


questi i comandi inviati al PC

E qui sotto il lavoro completo e chiuso



Il circuitino a Fritzing:

Altre importanti informazioni in merito al circuito ed al sistema in quest'altro post.


Lo sketch:
#include <CapacitiveSensor.h>

CapacitiveSensor Q = CapacitiveSensor(13, 12);
CapacitiveSensor W = CapacitiveSensor(13, 11);
CapacitiveSensor E = CapacitiveSensor(13, 10);
CapacitiveSensor R = CapacitiveSensor(13, 9);
CapacitiveSensor T = CapacitiveSensor(13, 8);

int soglia = 100;

int ledQ= 6;
int ledW= 5;
int ledE= 4;
int ledR= 3;
int ledT= 2;

boolean QTouch = false;
boolean WTouch = false;
boolean ETouch = false;
boolean RTouch = false;
boolean TTouch = false;

void setup()
{
pinMode(ledQ, OUTPUT);  
pinMode(ledW, OUTPUT);  
pinMode(ledE, OUTPUT);  
pinMode(ledR, OUTPUT);  
pinMode(ledT, OUTPUT);  

 
  Keyboard.begin();

Q.set_CS_AutocaL_Millis(0xFFFFFFFF);
W.set_CS_AutocaL_Millis(0xFFFFFFFF);
E.set_CS_AutocaL_Millis(0xFFFFFFFF);
R.set_CS_AutocaL_Millis(0xFFFFFFFF);
T.set_CS_AutocaL_Millis(0xFFFFFFFF);

Serial.begin(9600);
}

void loop()
{
long start = millis();
long totaleQ = Q.capacitiveSensor(30);
long totaleW = W.capacitiveSensor(30);
long totaleE = E.capacitiveSensor(30);
long totaleR = R.capacitiveSensor(30);
long totaleT = T.capacitiveSensor(30);


if(totaleQ > soglia && !QTouch){
//Serial.println("Q");
Keyboard.write('Q');
QTouch = true;
digitalWrite(ledQ, HIGH);
delay(100);
}
else{QTouch = false;}
digitalWrite(ledQ, LOW);
if(totaleW > soglia && !WTouch){
//Serial.println("W");
Keyboard.write('W');
WTouch = true;
digitalWrite(ledW, HIGH);
delay(100);
}
else{WTouch = false;}
digitalWrite(ledW, LOW);

if(totaleE > soglia && !ETouch){
//Serial.println("E");
Keyboard.write('E');
ETouch = true;
digitalWrite(ledE, HIGH);
delay(100);
}
else{ETouch = false;}
digitalWrite(ledE, LOW);
if(totaleR > soglia && !RTouch){
Serial.println("R");
Keyboard.write('R');
RTouch = true;
digitalWrite(ledR, HIGH);
delay(100);
}
else{RTouch = false;}
digitalWrite(ledR, LOW);
if(totaleT > soglia && !TTouch){
//Serial.println("T");
Keyboard.write('T');
TTouch = true;
digitalWrite(ledT, HIGH);
delay(100);
}
else{TTouch = false;}
digitalWrite(ledT, LOW);

}


venerdì 13 giugno 2014

Salvo l'uovo dal "Salva l'uovo!" mini arduino e sensori accelerometro

*** post incompleto***
Faccio un uovo elettronico.
Arduino mini, un accelerometro MMA8452, tre led e un porta batteria 2016 con batteria.
L'arduino i questione non si può collegare direttamente al pc, non ha la porta usb, quindi per programmarlo o vi trovate un arnese apposta oppure vi prendete un altro arduino e lo usate come programmatore.
Pubblico poi gli schemi con fritzing, intanto le foto:

Qui di seguito l'uovo elettronico assemblato, la schedina rossa è il sensore accelerometro, quello sotto blu ovviamente l'arduino, sopra tre led: verde= dispositivo acceso, giallo= forza compresa tra 3 e 4 g, rosso= oltre 4 g.

Il sensore il sensore MMA8452 si può tarare con valori massimi di 2, 4 oppure 8g, lo trovate qui per esempio, costa 9 euro.
Mini arduino pro si trova qui e costa 10 euro.
qui sotto uovo rotto e uovo salvo nel contenitore provvisiorio.


seguiranno aggiornamenti



Controller del quizzettone, Arduino Leonardo con sensori capacitivi.

nell'ultimo post, che potete trovare qui, vi raccontavo di arduino controllato con sensori capacitivi; a cosa serviva?
Per fare questo prototipo di un'altra cosa ancora più grande che posterò a metà luglio (pare).


Il modello è stato costruito dal collega Stefano. I tubini di plastica saranno dei bei tuboni da un metro in plexy o policarbonato, sotto il coperchio troverà posto una piastrina metallica per il contatto capacitivo.
Avvicinando la mano quindi si varia la capacità del circuito ed Arduino manderà, in base al tubo selezionato, un carattere al PC. Abbiamo concordato con Annalisa, che si sta occupando della programmazione del videogame, l'ordine dei tasti come: QWERTYUI. Qui sotto una anteprima del software:

Oltre all'invio del carattere Arduino provvederà ad illuminare i tasti selezionati, forse con delle dicroiche led, comandate da una serie di Mosfet. Nelle foto sotto ho utilizzato dei comuni led ad alta luminosità:


All'interno della scatola il solito arduino pimpato


Di seguito lo schema Fritzing del circuito (ma mica adesso lo faccio...)





mercoledì 4 giugno 2014

Arduino Leonardo e altri sensori capacitivi per una tastiera QWERTY


Sfiorando la guaina dei cavetti bianchi, al pc vendono inviati dei caratteri tastiera, da sinistra a destra (per scelta) QWERTYUI.
Il circuito è lo stesso di questo qui, sulla striscia blu del ground della bread bord ho collegato il piede numero 7 che in qualche modo è il "comune", le resistenze un po' grosse non sono tutte uguali (ho montato quelle che avevo).
Questo circuitino mi serve per costruire il controller di un videogame che produrrà l'amica e collega Annalisa. Ci siamo accordati per i quattro pulsanti delle due postazioni che saranno collegati ai caratteri della tastiera QWER e TYUI.
I due giocatori sfioreranno con le mani uno dei quattro tubi opalescenti davanti a loro, questi oltre ad inviare il carattere al pc si illumineranno con dei led colorati, pare...

Lo sketch:
#include <CapacitiveSensor.h>
#include "pitches.h"
CapacitiveSensor Q = CapacitiveSensor(7, 11);
CapacitiveSensor W = CapacitiveSensor(7, 10);
CapacitiveSensor E = CapacitiveSensor(7, 9);
CapacitiveSensor R = CapacitiveSensor(7, 8);
CapacitiveSensor T = CapacitiveSensor(7, 6);
CapacitiveSensor Y = CapacitiveSensor(7, 5);
CapacitiveSensor U = CapacitiveSensor(7, 4);
CapacitiveSensor I = CapacitiveSensor(7, 3);
int soglia = 50;
boolean QTouch = false;
boolean WTouch = false;
boolean ETouch = false;
boolean RTouch = false;
boolean TTouch = false;
boolean YTouch = false;
boolean UTouch = false;
boolean ITouch = false;
void setup()
{
  Keyboard.begin();

Q.set_CS_AutocaL_Millis(0xFFFFFFFF);
W.set_CS_AutocaL_Millis(0xFFFFFFFF);
E.set_CS_AutocaL_Millis(0xFFFFFFFF);
R.set_CS_AutocaL_Millis(0xFFFFFFFF);
T.set_CS_AutocaL_Millis(0xFFFFFFFF);
Y.set_CS_AutocaL_Millis(0xFFFFFFFF);
U.set_CS_AutocaL_Millis(0xFFFFFFFF);
I.set_CS_AutocaL_Millis(0xFFFFFFFF);

Serial.begin(9600);
}

void loop()
{
long start = millis();
long totaleQ = Q.capacitiveSensor(30);
long totaleW = W.capacitiveSensor(30);
long totaleE = E.capacitiveSensor(30);
long totaleR = R.capacitiveSensor(30);
long totaleT = T.capacitiveSensor(30);
long totaleY = Y.capacitiveSensor(30);
long totaleU = U.capacitiveSensor(30);
long totaleI = I.capacitiveSensor(30);
/****************************/


if(totaleQ > soglia && !QTouch){
Serial.println("Q");
Keyboard.write('Q');
QTouch = true;
}
else{QTouch = false;}

if(totaleW > soglia && !WTouch){
Serial.println("W");
Keyboard.write('W');
WTouch = true;
}
else{WTouch = false;}

if(totaleE > soglia && !ETouch){
Serial.println("E");
Keyboard.write('E');
ETouch = true;
}
else{ETouch = false;}
if(totaleR > soglia && !RTouch){
Serial.println("R");
Keyboard.write('R');
RTouch = true;
}
else{RTouch = false;}
if(totaleT > soglia && !TTouch){
Serial.println("T");
Keyboard.write('T');
TTouch = true;
}
else{TTouch = false;}

if(totaleY > soglia && !YTouch){
Serial.println("Y");
Keyboard.write('Y');
YTouch = true;
}
else{YTouch = false;}
if(totaleU > soglia && !UTouch){
Serial.println("U");
Keyboard.write('U');
UTouch = true;
}
else{UTouch = false;}
if(totaleI > soglia && !ITouch){
Serial.println("I");
Keyboard.write('I');
ITouch = true;
}
else{ITouch = false;}

}


Arduino e sensori capacitivi


Questo nel filmato è il prototipo di un giocattolone che raggiungerà un metro e mezzo di lato. Il basamento in legno con tutti i tubini di ottone lo ha costruito il collega Stefano, non avrei mai potuto fare un lavoro così tanto preciso! Scopo del gioco? Far raggiungere l'altro capo di ogni tubino dalla piccola maniglia senza che questa tocchi mai il tubino stesso. Un po' come L'allegro chirurgo .

Come funziona?

Il sito sul quale ho trovato tutte le informazioni è questo:
http://playground.arduino.cc/Main/CapacitiveSensor?from=Main.CapSense
l'immagine che spiega bene tutto è questa qui:


Provo a spiegarlo anche io nel modo più semplice possibile

Il circuito è composto da un emettitore che invia un segnale ad un ricevitore, il tempo che intercorre tra invio e ricezione dipende tra le altre cose dalla Capacità del circuito. Questa capacità varia in funzione di quanto vi avvicinate voi, è proprio il vostro corpo infatti che funge da armatura -insieme al circuito stesso- di questo grosso condensatore (un po' come lo schermo del vostro smartphone, che è di vetro, ma comunica all'apparecchio dei segnali elettrici sfruttando proprio la variazione di capacità).

Parlando in termini di Arduino:

Prima di tutto si carica la libreria dei cap sensor
#include <CapacitiveSensor.h> che trovate qui
poi vado a dichiarare quale dei pin emette il pwm e quale riceve
CapacitiveSensor *nome del sensore*= CapacitiveSensor(*numero pin emettitore*, *numero pin ricevitore*);
Imposto così uno dei pin di Arduino come emettitore di un segnale PWM che invio ad un altro pin, quello ricevitore (di fatto in ascolto del segnale PWM inviato). Il tempo che intercorre tra l'invio e la ricezione di questo treno di impulsi dipende appunto oltre che dalla resistenza (fissa) anche dalla Capacità del circuito che varia più o meno in funzione della vostra presenza.
Nel resto del programma inserisco una tara sul valore di tempo tra "spedizione e ricezione", 30 msec in questo esempio, e poi un valore di soglia che serve ad aggiustare un po' il tiro sul valore totale.
Ho inserito anche la libreria "pitches.h", che riporto alla fine, serve per suonare una melodia differente ogni volta che si verifica la condizione di "tubo toccato".

Il circuito:

Come nel fantastico schemino qui sopra, si collega una resistenza tra il pin in unscita e quello in ingresso, a valle va il contatto capacitivo, tutto qui. Il valore della resistenza varia in funzione della sensibilità che, come indicato sul sito Arduino, sarà più o meno:
1   Mohm solo a contatto
10 Mohm tra 10 e 15 cm circa
40 Mohm tra 30 e 60 cm circa

Nella foto qui sopra il circuito un pochino pasticciato del prototipo, la shield era stata creata per un Arduino Mega, qui riciclata. 
In basso a destra c'è il cicalino collegato sul morsetto azzurro in basso a sinistra.
Il cavo grigio (un cavo ethernet cat 5 riciclato) collega i led bianchi sulla basetta in legno, appena a sinistra del connettore le resistenze per i led.
Subito sopra il connettore che collega i quattro sensori con le relative resistenze da 10 mega.
Una bella piattina riciclata da un bus dati collega i pin di uscita che comandano, tramide dei mosfet N, una barra led RGB che proviene dritta dritta dal mio camper. Quattro sensori = 4 colori, RGB e... in lato a destra un bell'accrocchio con dei diodi, la quarta uscita mosfet alimenta sia il rosso che il verde e quindi "giallo".

Lo sketch:
#include <CapacitiveSensor.h>
#include "pitches.h"
CapacitiveSensor Uno = CapacitiveSensor(7, 5);
CapacitiveSensor Due = CapacitiveSensor(7, 4);
CapacitiveSensor Tre = CapacitiveSensor(7, 3);
CapacitiveSensor Quattro = CapacitiveSensor(7, 2);
int soglia = 400;
int redPin = 8;
int greenPin = 9;
int bluePin = 10;
int yellowPin = 11;
int buzzer = 12;
boolean UnoTouch = false;
boolean DueTouch = false;
boolean TreTouch = false;
boolean QuattroTouch = false;
void setup()
{
  pinMode(redPin, OUTPUT);
  pinMode(greenPin, OUTPUT);
  pinMode(bluePin, OUTPUT);
  pinMode(yellowPin, OUTPUT);
  pinMode(buzzer, OUTPUT);

// Forza la disattivazione dell'autocalibrazione ma perchè
Uno.set_CS_AutocaL_Millis(0xFFFFFFFF);
Due.set_CS_AutocaL_Millis(0xFFFFFFFF);
Tre.set_CS_AutocaL_Millis(0xFFFFFFFF);
Quattro.set_CS_AutocaL_Millis(0xFFFFFFFF);
Serial.begin(9600);
}
void loop()
{
//**************************************************
long start = millis();
long totale1 = Uno.capacitiveSensor(30);
long totale2 = Due.capacitiveSensor(30);
long totale3 = Tre.capacitiveSensor(30);
long totale4 = Quattro.capacitiveSensor(30);
if(totale1 > soglia && !UnoTouch){
Serial.println("uno");
digitalWrite(redPin, HIGH);
tone(buzzer, 1500);
delay (200);
tone(buzzer, 800, 200);
UnoTouch = true;
}
else{UnoTouch = false;}

if(totale2 > soglia && !DueTouch){
Serial.println("due");
digitalWrite(greenPin, HIGH);
tone(buzzer, 800);
delay (200);
tone(buzzer, 1500, 200);
DueTouch = true;
}
else{DueTouch = false;}

if(totale3 > soglia && !TreTouch){
Serial.println("tre");
digitalWrite(bluePin, HIGH);
tone(buzzer, 1800);
delay (150);
noTone(buzzer);
delay(50);
tone(buzzer, 1800, 200);
TreTouch = true;
}
else{TreTouch = false;}

if(totale4 > soglia && !QuattroTouch){
Serial.println("quattro");
digitalWrite(yellowPin, HIGH);
tone(buzzer, 800);
delay (150);
noTone(buzzer);
delay(50);
tone(buzzer, 800, 200);
QuattroTouch = true;
}
else{QuattroTouch = false;}
//**************
digitalWrite(redPin, LOW);
digitalWrite(greenPin, LOW);
digitalWrite(bluePin, LOW);
digitalWrite(yellowPin, LOW);
}

*********************
la libreria pitches.h

// This file contains a list of 8 octaves worth of pitches
//  that correspond to notes on the piano.
#define NOTE_B0  31
#define NOTE_C1  33
#define NOTE_CS1 35
#define NOTE_D1  37
#define NOTE_DS1 39
#define NOTE_E1  41
#define NOTE_F1  44
#define NOTE_FS1 46
#define NOTE_G1  49
#define NOTE_GS1 52
#define NOTE_A1  55
#define NOTE_AS1 58
#define NOTE_B1  62
#define NOTE_C2  65
#define NOTE_CS2 69
#define NOTE_D2  73
#define NOTE_DS2 78
#define NOTE_E2  82
#define NOTE_F2  87
#define NOTE_FS2 93
#define NOTE_G2  98
#define NOTE_GS2 104
#define NOTE_A2  110
#define NOTE_AS2 117
#define NOTE_B2  123
#define NOTE_C3  131
#define NOTE_CS3 139
#define NOTE_D3  147
#define NOTE_DS3 156
#define NOTE_E3  165
#define NOTE_F3  175
#define NOTE_FS3 185
#define NOTE_G3  196
#define NOTE_GS3 208
#define NOTE_A3  220
#define NOTE_AS3 233
#define NOTE_B3  247
#define NOTE_C4  262
#define NOTE_CS4 277
#define NOTE_D4  294
#define NOTE_DS4 311
#define NOTE_E4  330
#define NOTE_F4  349
#define NOTE_FS4 370
#define NOTE_G4  392
#define NOTE_GS4 415
#define NOTE_A4  440
#define NOTE_AS4 466
#define NOTE_B4  494
#define NOTE_C5  523
#define NOTE_CS5 554
#define NOTE_D5  587
#define NOTE_DS5 622
#define NOTE_E5  659
#define NOTE_F5  698
#define NOTE_FS5 740
#define NOTE_G5  784
#define NOTE_GS5 831
#define NOTE_A5  880
#define NOTE_AS5 932
#define NOTE_B5  988
#define NOTE_C6  1047
#define NOTE_CS6 1109
#define NOTE_D6  1175
#define NOTE_DS6 1245
#define NOTE_E6  1319
#define NOTE_F6  1397
#define NOTE_FS6 1480
#define NOTE_G6  1568
#define NOTE_GS6 1661
#define NOTE_A6  1760
#define NOTE_AS6 1865
#define NOTE_B6  1976
#define NOTE_C7  2093
#define NOTE_CS7 2217
#define NOTE_D7  2349
#define NOTE_DS7 2489
#define NOTE_E7  2637
#define NOTE_F7  2794
#define NOTE_FS7 2960
#define NOTE_G7  3136
#define NOTE_GS7 3322
#define NOTE_A7  3520
#define NOTE_AS7 3729
#define NOTE_B7  3951
#define NOTE_C8  4186
#define NOTE_CS8 4435
#define NOTE_D8  4699
#define NOTE_DS8 4978





non s'è capito molto neh?