Innholdsfortegnelse:
2025 Forfatter: John Day | [email protected]. Sist endret: 2025-01-13 06:58
HKU Project - ITTT (If This Then That) - Julia Berkouwer, 1B
Har du noen gang følt deg stresset og du bare ikke vet hvordan du skal roe deg selv, så bør du prøve disse avslapningsbrillene! Du tar på deg dem og lukker øynene, så spiller et pustemønster. Ved å følge dette pustemønsteret vil pusteytmen gå ned til å puste inn og ut 6 ganger i minuttet. Hvis du gjør dette, slipper du daglig stress.
Du kan også spore pusteintensiteten din ved å slå på en bryter ved hjelp av en FSR-sensor.
Med denne toturialen vil jeg guide deg gjennom å bygge dine egne avslapningsbriller trinn for trinn.
Trinn 1: Materialer og deler som trengs:
Materialer:
1x arduino uno;
1xbreadboard eller PCV;
3x 10k motstander
Ledninger (Fortrinnsvis forskjellige farger, så det er lettere å fortelle hvilke ting som går til bakken og hvilke som skal til forskjellige pinner, etc.);
Noen varmekrympende rør;
2x NeoPixel Ring - 16 x 5050 RGB LED med integrerte drivere;
1x bryter;
1x FSR -sensor;
1x SteamPunk -briller (Du kan kjøpe disse på en festbutikk, de er enkle å bruke fordi neopixelringen passer perfekt på brillene. Du prøver alltid å bruke andre briller eller lag din egen.);
1x en slags (elastikk) bånd å sette rundt brystet.
Verktøy: -Bærbar datamaskin
-Loddejern
-Arduino IDE programvare
Du vil se to knapper og en bryter på min pvc. Jeg bruker bare venstre knapp for å koble den til bryteren, jeg bruker ikke den andre knappen til høyre på bildet. Jeg satte knappene på pvc før jeg innså at jeg ikke trenger dem, og jeg trengte å bruke en bryter i stedet.
Nedenfor ser du bilder av alt jeg brukte:
Trinn 2: Neopixel ringer
Den hvite ledningen er koblet til bakken på baksiden av neopikselringen.
Den oransje ledningen er koblet til 5V.
Og den brune ledningen er koblet til datainngangen
Trinn 3: Tilkoblinger
Slik så brødbrettet mitt ut under prototyping, du kan bruke dette som referanse.
Jeg har også laget et oppsett av ledningene til hvordan det skal se ut med bare en knapp.
Trinn 4: Koden:
Det er sannsynligvis ikke den mest effektive koden, men det fungerer for meg. Utfordre deg selv og prøv å gjøre det mer effektivt; P
#inkludere
// Hvilken
pin på Arduino er koblet til NeoPixels?
#definere
PIN 6
// Hvilken
pin på Arduino er koblet til knappen
#definere
BUTTON_PIN 9
// Hvordan
mange NeoPixels er festet til Arduino?
#definere
NUMPIXELS 16
// Når
vi konfigurerer NeoPixel -biblioteket, vi forteller det hvor mange piksler og hvilken pin som skal brukes for å sende signaler.
// Merk
at for eldre NeoPixel-strips må du kanskje endre den tredje parameteren-se strandtesten
//
eksempel for mer informasjon om mulige verdier.
Adafruit_NeoPixel
piksler = Adafruit_NeoPixel (NUMPIXELS, PIN, NEO_GRB + NEO_KHZ800);
int pause
= 1; // forsinkelse2
int
pause2 = 80; // går ned når fsr brukes
int
pause3 = 150; // gjør opp når fsr brukes
int
delayval = 4; // forsinkelse1
int
fsrPin = 0; // FSR og 10K rullegardinmenyen er koblet til a0
int
fsrReading;
tomrom
setup () {
pinMode (BUTTON_PIN, INPUT);
Serial.begin (9600);
pixels.begin (); // Dette initialiserer
NeoPixel bibliotek.
piksler. vis ();
}
bool
knappetrykket (int pin) {
returner digitalRead (pin);
}
tomrom
loop () {// leser om pin -input er sann eller usann
fsrReading = analogRead (fsrPin);
Serial.print ("Analog lesing =");
Serial.print (fsrReading);
hvis (knappetrykket (BUTTON_PIN) == true) {
// lyseffekt ved bruk av FSR -sensor
hvis (fsrReading> 50) {
pixels.setPixelColor (0, 1, 0, 1);
pixels.setPixelColor (15, 1, 0, 1);
pixels.setPixelColor (1, 1, 0, 1);
pixels.setPixelColor (14, 1, 0, 1);
piksler. vis ();
forsinkelse (pause3);
}
hvis (fsrReading <52) {
pixels.setPixelColor (0, 0, 0, 0);
pixels.setPixelColor (15, 0, 0, 0);
pixels.setPixelColor (1, 0, 0, 0);
pixels.setPixelColor (14, 0, 0, 0);
piksler. vis ();
forsinkelse (pause2);
}
hvis (fsrReading> 57) {
pixels.setPixelColor (2, 1, 0, 1);
pixels.setPixelColor (13, 1, 0, 1);
pixels.setPixelColor (3, 1, 0, 1);
pixels.setPixelColor (12, 1, 0, 1);
piksler. vis ();
forsinkelse (pause3);
}
hvis (fsrReading <59) {
pixels.setPixelColor (2, 0, 0, 0);
pixels.setPixelColor (13, 0, 0, 0);
pixels.setPixelColor (3, 0, 0, 0);
pixels.setPixelColor (12, 0, 0, 0);
piksler. vis ();
forsinkelse (pause2);
}
hvis (fsrReading> 65) {
pixels.setPixelColor (4, 1, 0, 1);
pixels.setPixelColor (11, 1, 0, 1);
pixels.setPixelColor (5, 1, 0, 1);
pixels.setPixelColor (10, 1, 0, 1);
piksler. vis ();
forsinkelse (pause3);
}
hvis (fsrReading <67) {
pixels.setPixelColor (4, 0, 0, 0);
pixels.setPixelColor (11, 0, 0, 0);
pixels.setPixelColor (5, 0, 0, 0);
pixels.setPixelColor (10, 0, 0, 0);
piksler. vis ();
forsinkelse (40);
}
hvis (fsrReading> 79) {
pixels.setPixelColor (6, 1, 0, 1);
pixels.setPixelColor (9, 1, 0, 1);
pixels.setPixelColor (7, 1, 0, 1);
pixels.setPixelColor (8, 1, 0, 1);
piksler. vis ();
forsinkelse (pause3);
}
hvis (fsrReading <85) {
pixels.setPixelColor (6, 0, 0, 0);
pixels.setPixelColor (9, 0, 0, 0);
pixels.setPixelColor (7, 0, 0, 0);
pixels.setPixelColor (8, 0, 0, 0);
piksler. vis ();
forsinkelse (20);
}
}
ellers{
puste_blå (20, 100, 0, 1, 1); // vanlig
effekt
}
}
// Pause
= forsinkelse mellom overganger
// trinn
= antall trinn
// R, G, B = Full-on RGB-verdier
// De void breathe is for the licht effect als de
fsrsensor ikke brukes. Denne void blir in the void loop () weer aangeroepen.
void breathe_blue (int pause, int trinn, byte R, byte G, byte B) {
int
tmpR, tmpG, tmpB; // Temp -verdier
// Fade opp
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (0, tmpR, tmpG+1, tmpB);
pixels.setPixelColor (15, tmpR, tmpG+1, tmpB);
}
piksler. vis ();
forsinkelse (4);
}
// Fade up
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (1, tmpR, tmpG+1, tmpB);pixels.setPixelColor (14, tmpR, tmpG+1, tmpB);
}
piksler. vis ();
forsinkelse (4);
}
// Fade opp
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (2, tmpR, tmpG+2, tmpB);pixels.setPixelColor (13, tmpR, tmpG+2, tmpB);
}
piksler. vis ();
forsinkelse (3.5);
}
// Fade up
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (3, tmpR, tmpG+3, tmpB+5);pixels.setPixelColor (12, tmpR, tmpG+3, tmpB+5);
}
piksler. vis ();
forsinkelse (3);
}
for (int i = 0;
Jegpixels.setPixelColor (0, 0, 0, 0);pixels.setPixelColor (15, 0, 0, 0);
}
// Fade up
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jeg
pixels.setPixelColor (4, tmpR, tmpG+3, tmpB+15);pixels.setPixelColor (11, tmpR, tmpG+3, tmpB+15);
}
piksler. vis ();
forsinkelse (3);
}
// Fade up
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (5, tmpR, tmpG+4, tmpB+20);pixels.setPixelColor (10, tmpR, tmpG+4, tmpB+20);
}
piksler. vis ();
forsinkelse (2);
}
for (int i = 0;
Jegpixels.setPixelColor (1, 0, 0, 0);
pixels.setPixelColor (14, 0, 0, 0);
}
// Fade opp
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jegpixels.setPixelColor (6, tmpR, tmpG+2, tmpB+40);
pixels.setPixelColor (9, tmpR, tmpG+2, tmpB+40);
}
piksler. vis ();
forsinkelse (delayval);
}
for (int i = 0;
Jegpixels.setPixelColor (2, 0, 0, 0);pixels.setPixelColor (13, 0, 0, 0);
}
// Fade up
for (int s = 1; s <= trinn; s ++) {
tmpR = (R * s) /
trinn; // Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0;
Jeg
pixels.setPixelColor (7, tmpR, tmpG, tmpB+44);pixels.setPixelColor (8, tmpR, tmpG, tmpB+44);
}
piksler. vis ();
forsinkelse (delayval);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (7, tmpR, tmpG, tmpB);
pixels.setPixelColor (8, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (1);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (6, tmpR, tmpG, tmpB);
pixels.setPixelColor (9, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (1);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (5, tmpR, tmpG, tmpB);
pixels.setPixelColor (10, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (2);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (4, tmpR, tmpG, tmpB);
pixels.setPixelColor (11, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (2);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (3, tmpR, tmpG, tmpB);
pixels.setPixelColor (12, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (3);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; //
Multipliser først for å unngå avkortingsfeil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (2, tmpR, tmpG, tmpB);
pixels.setPixelColor (13, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (3);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (1, tmpR, tmpG, tmpB);
pixels.setPixelColor (14, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (4);
}
// Fade ned
for (int s = trinn; s> 0; s--) {
tmpR = (R * s) / trinn; // Multipliser først for å unngå avkortning
feil
tmpG = (G * s) / trinn;
tmpB = (B * s) / trinn;
for (int i = 0; i
pixels.setPixelColor (0, tmpR, tmpG, tmpB);
pixels.setPixelColor (15, tmpR, tmpG, tmpB);
}
piksler. vis ();
forsinkelse (4);
}
}
Trinn 5: Sett alt sammen:
Du kan bare la alle ledningene være koblet til brødbrettet eller en PVC, det er opp til deg (jeg valgte å legge en PVC på arduinoen, det er fint og pent på den måten).
Det neste trinnet er å sette varmekrympende rør rundt alle ledningene, så det blir mindre rot.
Hvis du valgte å bruke en PVC, burde du ha loddet alt sammen nå.
Etter det legger du neopikselringene på utsiden av beskyttelsesbrillene (sørg for at lysdiodene er justert på baksiden) og fest dem på plass med litt tape eller lim (jeg brukte tape).
Du kan velge å feste fsr-sensoren til elastikken med litt tape eller bare la den stå alene.
Kos deg med brillene dine:)