Innehållsförteckning:
2025 Författare: John Day | [email protected]. Senast ändrad: 2025-01-23 15:11
Detta är en förlängning av Instructable
IOT123 - SOLAR TRACKER - TILT/PAN, PANEL RAM, LDR MOUNTS RIG. Här koncentrerar vi oss på servomotorn och sensorerna för solens position. Det är viktigt att påpeka att denna design förutsätter att två MCU: er kommer att användas: en (3,3V 8mHz Arduino Pro Mini) för solspåraren och en oberoende MCU för dina sensorer/aktörer.
Detta är version 0.3
Istället för att publicera alla projekt efter fullständig tillfredsställelse kommer jag att öva på kontinuerlig integration och leverera något oftare, ändra vad jag har levererat efter behov. Jag kommer att skriva en annan instruerbar för batteriladdaren, _när_ optimeringen av kontrollprogramvaran/hårdvaran är klar. Jag kommer att påpeka var optimeringarna behövs när vi går igenom detta.
En del av anledningen till detta tillvägagångssätt är feedback från kunder. Om ni ser ett behov eller har ett bättre tillvägagångssätt, kommentera, men kom ihåg att jag inte kan leverera allt och kanske inte till en tidsram som passar dig. Eftersom dessa förklaringar verkar mindre relevanta kommer de att raderas från den här artikeln.
Vad detta inkluderar:
- Använd LDR från den ursprungliga Instructable för att känna solens ungefärliga plats.
- Flytta servon mot solen.
- Alternativ för rörelsens känslighet.
- Alternativ för stegstorlek när du flyttar till solen.
- Alternativ för vinkelbegränsningarna som används på servon.
- Alternativ för fördröjningar av rörelserna.
- I2C -gränssnitt för inställning/hämtning av värden mellan MCU: er.
- Djupt sömn mellan rörelser.
Vad detta inte inkluderar (och kommer att behandlas när tiden tillåter):
- Använd bara ström under dagsljus.
- Kommer ihåg gryningspositionen och åker dit vid skymningsstängning.
- Ta bort regulatorn från MCU.
- Inaktivera lysdioderna på MCU: n.
- Omdirigerar strömmen via VCC snarare än RAW.
- Tillhandahåller lösningar för blinkning utan reglerad ström från USB till seriell TTL -omvandlare.
- Batterispänningsmätare.
HISTORIA
20 dec 2017 V0.1 KOD
Initialversionen spårar ljuskällan, alltid på, ingen laddning
7 jan 2018 V0.2 KOD
-
HÅRDVARUFÖRÄNDRINGAR
- Lägg till I2C -stift
- Lägg till switch till servo -GND: er
- Tryckt etikett på controllerboxen
-
PROGRAMVÄNDRINGAR
- Läs konfiguration från EEPROM
- I2C -bussstöd som slav till en annan MCU (3.3V)
- Ställ in konfiguration via I2C
- Set Enabled via I2C
- Få konfiguration via I2C
- Få körtidsegenskaper via I2C (för närvarande aktiverad och aktuell ljusintensitet)
- Ta bort seriell loggning (det påverkade I2C -värden)
19 jan, 2018 V0.3 KOD
- HÅRDVARA
Etiketten uppdaterad. Switch används nu för att välja antingen CONFIG eller TRACK -läge
- PROGRAMVARA
- I2C används endast för konfiguration
- Styrenheten väntar 5 sekunder innan spårningen initieras, möjliggör rörelse av händer
- För att kunna använda I2C -konfiguration måste SPDT vara på CONFIG som enhetsstövlar
- Mellan spårningsrörelsen är enheten i djupt viloläge för konfigurationsvärdet SLEEP MINUTES (standard 20 minuter).
Steg 1: Material och verktyg
Det finns nu en fullständig lista över material och källor.
- 3D -tryckta delar.
- Arduino Pro Mini 3.3V 8mHz
- 1 av 4x6cm dubbel sida prototyp PCB Universal kretskort (ska skäras i hälften)
- 1 av 40P hanrubrik (ska klippas i storlek).
- 1 av 40P kvinnlig header (ska klippas i storlek).
- 4 av 10K 1/4W restistorer.
- Anslutningstråd.
- Löd och järn.
- 20 av 4G x 6 mm rostfria pannhuvud självgängande skruvar.
- 4 av 4G x 6 mm rostfria försänkta självgängande skruvar.
- 1 av 3,7V LiPo -batteri och hållare (avslutas i 2P dupont -kontakter).
- 1 av 2P manlig rätvinklig header
- 1 av SPDT -omkopplare 3 -stifts 2,54 mm delning
- Kraftigt cyanoakrylatlim
- Dupont -kontaktdon 1P -header (1 av blått, 1 av grönt).
Steg 2: Montera kretsen
Kretsen har för närvarande inte spänningsdelaren (voltmätare).
- Skär 4x6cm dubbelsidiga prototyp PCB Universal Printed Circuit Board i hälften över den långa axeln.
-
Skär 40P hanrubriken i bitar:
- 2 av 12P
- 3 av 3P
- 6 av 2P.
-
Skär 40P kvinnlig header i bitar:
- 2 av 12P
- 1 av 6P
- Löd 2 av 12Pemal header som visas.
- Limma distansen bort från en 3P han (extra) rubrik på undersidan av SPDT -omkopplaren med cyanoakrylatlim
- På andra sidan placera sedan löd 6 av 2P, 2 av 3Pmale header och SPDT -omkopplaren som visas.
- Löd 4 av 10K motstånd (A, B, C, D svart) via ledning till GND -stifthuvud (#2 svart) och till A0 - A3 -huvudstiften (#5, #6, #7, #8) sedan genom hålet (gul) som visas (3 bilder + 1 diagram).
- Spåra 3.3V från LDR PINS -lödnings -PINS #4, #6, #8, #10 och trä genom hålet till feamale header VCC pin (grön).
- Spåra 3.3V på kvinnlig rubriksida som visas (röd) lödning till PINS #1, #12, #15.
- 3.3V genomgående hål, lödd över sidan (röd) RAW header PIN #1.
- Spåra orange anslutning från PIN #11 genom hålet till lödhonan stift på andra sidan som visas.
- Spåra och löd blå anslutningstråd från #20 till #30 och från #31 till #13 och #16.
- Lödning Kvinna Rubrik PIN #11 till Manlig Rubrik PIN #11 genomgående hål.
- Förbered 2 dupont -kontakter 30 mm långa med 1P -hona (1 av blått, 1 av grönt). Strimla och plåt andra änden.
- Lödblå Dupont -tråd till #28; lödgrön Dupont -tråd till #29.
- På ovansidan av Arduino fixar du 6P kvinnlig rubrik och sedan löd.
- På ovansidan av Arduino fixa 2P rätvinklig kvinnlig rubrik int #29 och #30 sedan lödning.
- På undersidan av Arduino fixera de 2 av 12P och 1 av 3P hanstiften och löd sedan.
- Sätt i Arduino hane 12P -stift i PCB 12P honhuvuden.
Steg 3: Blinkar MCU
Arduino Pro Mini blinkar bekvämt med hjälp av en FTDI232 USB till TTL -omvandlare med 6P kvinnlig rubrik. Se bilden ovan för inriktningen av de två brädorna.
Se till att 3.3V -inställningen är vald på din FTDI232. Följ instruktionerna här med koden nedan (använd länk till GIST).
Lowpower-biblioteket (bifogat och https://github.com/rocketscream/Low-Power) måste installeras.
När Arduino Pro Mini + PCB har installerats i höljet kan det fortfarande blinka när huvudstiften exponeras. Koppla bara bort styrenheten från panelramen och exponerar rubriken.
Tilt pan solar tracker med I2C/EEPROM -konfiguration och sömncykel mellan rörelser. Sömncykelns varaktighet minskar när längden ökar, men tillräcklig för detta ändamål
/* |
* modifierad från kod |
* av Mathias Leroy |
* |
* V0.2 MODIFIKATIONER |
** I2C SET GET |
** EEPROM SET GET |
** TA BORT SERIALUTGÅNGEN - PÅVERKAD I2C |
** Aktivera/inaktivera spårning |
** FLYT TJÄNSTER TILL GRÄNSER VIA I2C |
** LÄS AKTUELL AVG INTENSITET VIA I2C |
* V0.3 MODIFIKATIONER |
** KOPPLING FÖR 2 LÄGEN - TRACK (NO I2C) och CONFIGURE (USES I2C) |
** SÖVN I SPÅRLÄGE (MYCKET LÅG PRECISION TILL 8 ANDRA BITTER) |
** KOPPLING/FÄST SERVOS PÅ SÖVN/VAKNING (TRANSISTOR ANVÄNDS EVENTUELLT) |
** TA BORT KONFIGURERBAR INLEDNINGSPOSITION (REDUNDANT) |
** TA BORT KONFIGURERBARA WAKE SECONDS (REDUNDANT) |
** TA BORT KONFIGURERBAR AKTIVERA/INAKTIVERA (REDUNDANT) |
** TA BORT KONFIGURERBART TRACKER AKTIVERAT (ANVÄND HARDWARE SWITCH) |
** TA BORT SPÄNNINGSGETTER - SKA ANVÄNDA SEPARAT I2C -KOMPONENT |
** LÄGG TILL SERIELLOGGNING OM DU IKKE ANVÄNDER I2C |
*/ |
#omfatta |
#omfatta |
#omfatta |
#omfatta |
#omfatta |
#definieraEEPROM_VERSION1 |
#definiera2C_MSG_IN_SIZE3 |
#definePIN_LDR_TL A0 |
#definePIN_LDR_TR A1 |
#definePIN_LDR_BR A3 |
#definePIN_LDR_BL A2 |
#definieraPIN_SERVO_V11 |
#definieraPIN_SERVO_H5 |
#definieraIDX_I2C_ADDR0 |
#definieraIDX_V_ANGLE_MIN1 |
#definieraIDX_V_ANGLE_MAX2 |
#definieraIDX_V_SENSITIVITY3 |
#definieraIDX_V_STEP4 |
#definieraIDX_H_ANGLE_MIN5 |
#definieraIDX_H_ANGLE_MAX6 |
#definieraIDX_H_SENSITIVITY7 |
#definieraIDX_H_STEP8 |
#definieraIDX_SLEEP_MINUTES9 |
#definieraIDX_V_DAWN_ANGLE10 |
#definieraIDX_H_DAWN_ANGLE11 |
#definieraIDX_DAWN_INTENSITY12 // genomsnitt av alla LDRS |
#definieraIDX_DUSK_INTENSITY13 // genomsnitt av alla LDRS |
#definieraIDX_END_EEPROM_SET14 |
#definieraIDX_CURRENT_INTENSITY15 // genomsnitt av alla LDRS - används för att beräkna IDX_DAWN_INTENSITY ambient non -direct light |
#definieraIDX_END_VALUES_GET16 |
#definieraIDX_SIGN_117 |
#definieraIDX_SIGN_218 |
#definieraIDX_SIGN_319 |
Servo _servoH; |
Servo _servoV; |
byte _i2cVals [20] = {10, 10, 170, 20, 5, 10, 170, 20, 5, 20, 40, 10, 30, 40, 0, 0, 0, 0, 0, 0}; |
int _servoLoopDelay = 10; |
int _slowingDelay = 0; |
int _angleH = 90; |
int _angleV = 90; |
int _averageTop = 0; |
int _averageRight = 0; |
int _averageBottom = 0; |
int _averageLeft = 0; |
byte _i2cResponse = 0; |
bool _inConfigMode = false; |
voidsetup () |
{ |
Serial.begin (115200); |
getFromEeprom (); |
if (inConfigMode ()) { |
Serial.println ("Config Mode"); |
Serial.print ("I2C -adress:"); |
Serial.println (_i2cVals [IDX_I2C_ADDR]); |
Wire.begin (_i2cVals [IDX_I2C_ADDR]); |
Wire.onReceive (ReceiveEvent); |
Wire.onRequest (requestEvent); |
}annan{ |
Serial.println ("Spårningsläge"); |
fördröjning (5000); // tid att få händerna ur vägen när du ansluter batteriet etc. |
} |
} |
voidloop () |
{ |
getLightValues (); |
if (! _inConfigMode) { |
// ToDo: TÄNDA PÅ TRANSISTORBRYTAREN |
_servoH.attach (PIN_SERVO_H); |
_servoV.attach (PIN_SERVO_V); |
för (int i = 0; i <20; i ++) { |
om (i! = 0) { |
getLightValues (); |
} |
moveServos (); |
} |
fördröjning (500); |
_servoH.detach (); |
_servoV.detach (); |
// ToDo: STÄNG AV TRANSISTORBRYTAREN |
fördröjning (500); |
sleepFor ((_ i2cVals [IDX_SLEEP_MINUTES] * 60) / 8); |
} |
} |
// --------------------------------- AKTUELLT LÄGE |
boolinConfigMode () { |
pinMode (PIN_SERVO_H, INPUT); |
_inConfigMode = digitalRead (PIN_SERVO_H) == 1; |
return _inConfigMode; |
} |
// --------------------------------- EEPROM |
voidgetFromEeprom () { |
om( |
EEPROM.read (IDX_SIGN_1)! = 'S' || |
EEPROM.read (IDX_SIGN_2)! = 'T' || |
EEPROM.read (IDX_SIGN_3)! = EEPROM_VERSION |
) EEPROM_write_default_configuration (); |
EEPROM_read_configuration (); |
} |
voidEEPROM_write_default_configuration () { |
Serial.println ("EEPROM_write_default_configuration"); |
för (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
EEPROM.update (i, _i2cVals ); |
} |
EEPROM.update (IDX_SIGN_1, 'S'); |
EEPROM.update (IDX_SIGN_2, 'T'); |
EEPROM.update (IDX_SIGN_3, EEPROM_VERSION); |
} |
voidEEPROM_read_configuration () { |
Serial.println ("EEPROM_read_configuration"); |
för (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
_i2cVals = EEPROM.read (i); |
//Serial.println(String(i) + "=" + _i2cVals ); |
} |
} |
// --------------------------------- I2C |
voidreceiveEvent (int count) { |
if (count == I2C_MSG_IN_SIZE) |
{ |
char cmd = Wire.read (); |
byte index = Wire.read (); |
byte värde = Wire.read (); |
switch (cmd) { |
case'G ': |
if (index <IDX_END_VALUES_GET) { |
_i2cResponse = _i2cVals [index]; |
} |
ha sönder; |
fallets: |
if (index <IDX_END_EEPROM_SET) { |
_i2cVals [index] = värde; |
EEPROM.update (index, _i2cVals [index]); |
} |
ha sönder; |
standard: |
lämna tillbaka; |
} |
} |
} |
voidrequestEvent () |
{ |
Wire.write (_i2cResponse); |
} |
// --------------------------------- LDR |
voidgetLightValues () { |
int valueTopLeft = analogRead (PIN_LDR_TL); |
int valueTopRight = analogRead (PIN_LDR_TR); |
int valueBottomRight = analogRead (PIN_LDR_BR); |
int valueBottomLeft = analogRead (PIN_LDR_BL); |
_averageTop = (valueTopLeft + valueTopRight) / 2; |
_averageRight = (valueTopRight + valueBottomRight) / 2; |
_averageBottom = (valueBottomRight + valueBottomLeft) / 2; |
_averageLeft = (valueBottomLeft + valueTopLeft) / 2; |
int avgIntensity = (valueTopLeft + valueTopRight + valueBottomRight + valueBottomLeft) / 4; |
_i2cVals [IDX_CURRENT_INTENSITY] = map (avgIntensity, 0, 1024, 0, 255); |
} |
// --------------------------------- SERVOS |
voidmoveServos () { |
Serial.println ("moveServos"); |
if ((_averageLeft-_averageRight)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH-_i2cVals [IDX_H_STEP])> _ i2cVals [IDX_H_ANGLE_MIN]) { |
// går vänster |
Serial.println ("moveServos går till vänster"); |
delay (_slowingDelay); |
för (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH--); |
delay (_servoLoopDelay); |
} |
} |
elseif ((_averageRight-_averageLeft)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH+_i2cVals [IDX_H_STEP]) <_ i2cVals [IDX_H_ANGLE_MAX]) { |
// går rätt |
Serial.println ("moveServos går till vänster"); |
delay (_slowingDelay); |
för (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH ++); |
delay (_servoLoopDelay); |
} |
} |
annat { |
// gör inget |
Serial.println ("moveServos gör ingenting"); |
delay (_slowingDelay); |
} |
if ((_averageTop-_averageBottom)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV+_i2cVals [IDX_V_STEP]) <_ i2cVals [IDX_V_ANGLE_MAX]) { |
// Går upp |
Serial.println ("moveServos går upp"); |
delay (_slowingDelay); |
för (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV ++); |
delay (_servoLoopDelay); |
} |
} |
elseif ((_averageBottom-_averageTop)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV-_i2cVals [IDX_V_STEP])> _ i2cVals [IDX_V_ANGLE_MIN]) { |
// går ner |
Serial.println ("moveServos går ner"); |
delay (_slowingDelay); |
för (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV--); |
delay (_servoLoopDelay); |
} |
} |
annat { |
Serial.println ("moveServos gör ingenting"); |
delay (_slowingDelay); |
} |
} |
//---------------------------------SÖMN |
voidasleepFor (unsignedint eightSecondSegments) { |
Serial.println ("sleepFor"); |
för (unsignedint sleepCounter = eightSecondSegments; sleepCounter> 0; sleepCounter--) |
{ |
LowPower.powerDown (SLEEP_8S, ADC_OFF, BOD_OFF); |
} |
} |
visa rawtilt_pan_tracker_0.3.ino värd med ❤ av GitHub
Steg 4: Montering av kretshöljet
- Se till att Ardiuno Pro Mini är isatt i sidhuvudena på kretskortet.
- Sätt i SOLAR TRACKER -styrlådans bas i SOLAR TRACKER -styrlådans väggar och fäst med 2 av 4G x 6 mm försänkta självgängande skruvar.
- Sätt i Ardiuno Pro Mini + PCB med 6P Header som hakar in i tomrummet i SOLAR TRACKER -styrboxens bas.
- Sätt in locket till SOLAR TRACKER -styrboxen i SOLAR TRACKER -styrlådans väggar och fäst med 2 av 4G x 6 mm försänkta självgängande skruvar.
- Fäst monteringen ovan på panelramens bas med 4 av 4G x 6 mm rostfria försänkta självgängande skruvar.
Steg 5: Ansluta riggkablarna till styrenheten
De relevanta anslutningarna som är klara från föregående instruerbara är 4 av 2P LDR -anslutningar och 2 av 3P -anslutningar från servon. Det som är tillfälligt tills laddningen är klar är batteriet. Använd en 3,7V LiPo som slutar i en 2P DuPont -anslutning för tillfället.
-
Sätt i LDR -anslutningarna (ingen polaritet) uppifrån:
- Överst till höger
- Övre vänstra
- Nere till höger
- Nedre vänstra
-
Sätt i servoanslutningarna (med signalkabeln till vänster) uppifrån:
- Horisontell
- Vertikal
- Vänta tills det är klart för testet: Sätt i 3,7V likströmsledning +ve upptill, -ve till botten.
Steg 6: Testa styrenheten
Som tidigare nämnts har programvaran inte optimerats för arbetsflöde för solcellsladdning. Det kan dock testas och finjusteras med hjälp av naturliga (sol) och onaturliga ljuskällor.
För att testa spårningen i en kontrollerad miljö kan det vara bekvämt att ställa in SLEEP MINUTES till ett lägre värde (se nästa steg).
Steg 7: Konfigurera Via I2C med hjälp av konsolinmatning
Detta förklarar hur du konfigurerar regulatorn via en andra MCU, anger inställningar i ett konsolfönster.
- Ladda upp följande skript till en D1M WIFI -BLOCK (eller Wemos D1 Mini).
- Koppla bort USB från datorn
-
PIN-ANSLUTNINGAR: -ve (Controller) => GND (D1M)+ve (Controller) => 3V3 (D1M) SCL (Controller) => D1 (D1M)
SDA (styrenhet) => D2 (D1M)
- Vrid SPDT -omkopplaren till CONFIG
- Anslut USB till PC
- Från Arduino IDE starta ett konsolfönster med rätt COM -port
- Se till att "Newline" och "9600 baud" är markerade
- Kommandona kommer in i textrutan Skicka följt av Enter -tangenten
- Kommandona har formatet Teckenbyte -byte
- Om den andra byten (tredje segmentet) inte ingår 0 (noll) skickas av skriptet
- Var försiktig med att använda seriell ingång; granska vad du har angett innan du trycker på "Enter". Om du är utelåst (till exempel ändrar I2C -adressen till ett värde du har glömt) måste du blinka styrenhetens firmware igen.
De variationer som stöds i det första kommandotecknet är:
- E (Aktivera servospårning) användbar för att stoppa rörelse under konfiguration. Detta matas in med: E 0
- D (Inaktivera servospårning) användbart för att starta automatisk spårning om enheten inte startas om. Detta matas in med: D 0
- G (Hämta konfigurationsvärde) läser värden från EEPROM och IN -MEMORY: Detta matas in med: G (index är giltiga bytevärden 0 - 13 och 15)
- S (Ställ in EEPROM -värde) anger värden till EEPROM som är tillgängliga efter omstart. Detta matas in med: S (index är giltiga bytevärden 0 - 13, värdet är giltiga bytevärden och varierar per egenskap)
Koden är sanningens punkt för indexen men följande används för en guide för giltiga värden/kommentarer:
- I2C ADRESS 0 - controller -slavadress, mastern behöver detta för att kommunicera med regulatorn (standard 10)
- MINIMAL VERTIKAL VINKEL 1 - vertikal vertikal servo nedre gräns (standard 10, intervall 0 - 180)
- MAXIMAL VERTIKAL VINKEL 2 - vertikal vertikal servo övre gräns (standard 170, område 0 - 180)
- KÄNSLIGHET VERTIKAL LDR 3 - Vertikal LDR -läsmarginal (standard 20, intervall 0 - 1024)
- VERTIKALVINKEL STEG 4 - vertikala vertikala servosteg vid varje justering (standard 5, intervall 1 - 20)
- MINIMAL HORIZONTAL VINKEL 5 - vinkel horisontell servo nedre gräns (standard 10, intervall 0-180)
- MAXIMAL HORISONTAL VINKEL 6 - vinkel horisontell servo övre gräns (standard 170, intervall 0-180)
- KÄNSLIGHET HORIZONTAL LDR 7 - Horisontell LDR -läsmarginal (standard 20, intervall 0 - 1024)
- HORISONTALVINKELSTEG 8 - horisontella servosteg vid varje justering (standard 5, intervall 1 - 20)
- SLEEP MINUTES 9 - den ungefärliga sömnperioden mellan spårning (standard 20, intervall 1 - 255)
- VERTICAL DAWN ANGLE 10 - FRAMTIDANVÄNDNING - den vertikala vinkeln att återgå till när solen går ner
- HORIZONTAL DAWN ANGLE 11 - FRAMTIDA ANVÄNDNING - den horisontella vinkeln att återgå till när solen går ner
- DAWN INTENSITY 12 - FRAMTIDIG ANVÄNDNING - lägsta genomsnitt av alla LDR: er som utlöser en start av daglig solspårning
- DUSK INTENSITY 13 - FRAMTIDIG ANVÄNDNING - lägsta genomsnitt av alla LDR: er som utlöser ett slut på daglig solspårning
- SLUT AV EEPROM -VÄRDEMÄRKARE 14 - VÄRDE ANVÄNDS INTE
- AKTUELL INTENSITET 15 - den aktuella genomsnittliga procentandelen av ljusintensiteten
- SLUT PÅ MINNESVÄRDE MARKERING 16 - VÄRDE ANVÄNDS INTE.
Fångar seriell ingång (tangentbordsinmatning i konsolfönstret) och vidarebefordrar den till en I2C -slav i formatet char, byte, byte
#omfatta |
#definiera2C_MSG_IN_SIZE2 |
#definiera2C_MSG_OUT_SIZE3 |
#definiera2C_SLAVE_ADDRESS10 |
booleska _newData = false; |
const byte _numChars = 32; |
char _receivedChars [_numChars]; // en array för att lagra mottagen data |
voidsetup () { |
Serial.begin (9600); |
Wire.begin (D2, D1); |
fördröjning (5000); |
} |
voidloop () { |
recvWithEndMarker (); |
parseSendCommands (); |
} |
voidrecvWithEndMarker () { |
statisk byte ndx = 0; |
char endMarker = '\ n'; |
röding; |
medan (Serial.available ()> 0 && _newData == false) { |
rc = Serial.read (); |
if (rc! = endMarker) { |
_receivedChars [ndx] = rc; |
ndx ++; |
if (ndx> = _numChars) { |
ndx = _numChars - 1; |
} |
} annat { |
_receivedChars [ndx] = '\ 0'; // avsluta strängen |
ndx = 0; |
_newData = true; |
} |
} |
} |
voidparseSendCommands () { |
om (_newData == true) { |
constchar delim [2] = ""; |
char *token; |
token = strtok (_receivedChars, delim); |
char cmd = _receivedChars [0]; |
byteindex = 0; |
byte värde = 0; |
int i = 0; |
medan (token! = NULL) { |
//Serial.println(token); |
i ++; |
växla (i) { |
fall 1: |
token = strtok (NULL, delim); |
index = atoi (token); |
ha sönder; |
case2: |
token = strtok (NULL, delim); |
if (token! = NULL) { |
värde = atoi (token); |
} |
ha sönder; |
standard: |
token = NULL; |
} |
} |
sendCmd (cmd, index, värde); |
_newData = false; |
} |
} |
voidsendCmd (char cmd, byte index, byte värde) { |
Serial.println ("-----"); |
Serial.println ("Skickar kommando:"); |
Serial.println ("\ t" + String (cmd) + "" + String (index) + "" + String (värde)); |
Serial.println ("-----"); |
Wire.beginTransmission (I2C_SLAVE_ADDRESS); // överföra till enhet |
Wire.write (cmd); // skickar en röding |
Wire.write (index); // skickar en byte |
Wire.write (värde); // skickar en byte |
Wire.endTransmission (); |
bytesvar = 0; |
bool hadResponse = false; |
if (cmd == 'G') { |
Wire.requestFrom (I2C_SLAVE_ADDRESS, 1); |
medan (Wire.available ()) // slav kan skicka mindre än begärt |
{ |
hadResponse = true; |
svar = Wire.read (); |
} |
if (hadResponse == true) { |
Serial.println ("Få svar:"); |
Serial.println (svar); |
}annan{ |
Serial.println ("Inget svar, kontrollera adressen/anslutningen"); |
} |
} |
} |
visa rawd1m_serial_input_i2c_char_byte_byte_v0.1.ino värd med ❤ av GitHub
Steg 8: Nästa steg
Kontrollera regelbundet för att kontrollera om det finns ändringar i programvara/hårdvara.
Ändra programvaran/hårdvaran efter dina krav.
Kommentera eventuella önskemål/optimeringar.
Rekommenderad:
LoRa GPS Tracker Handledning - LoRaWAN med Dragino och TTN: 7 steg
LoRa GPS Tracker Handledning | LoRaWAN Med Dragino och TTN: Hej, vad händer, killar! Akarsh här från CETech. Ett par projekt tillbaka tittade vi på LoRaWAN Gateway från Dragino. Vi kopplade olika noder till Gateway och överförde data från noder till Gateway med TheThingsNetwork som s
DIY GPS Tracker --- Python-applikation: 5 steg (med bilder)
DIY GPS Tracker --- Python-applikation: Jag deltog i ett cykelevenemang för två veckor sedan. Efter att ha avslutat ville jag kontrollera rutten och hastigheten jag cyklade vid den tiden. Tyvärr uppnåddes det inte. Nu använder jag ESP32 för att göra en GPS -tracker, och jag tar den för att spela in min cykelväg
Desktop COVID19 Tracker med klocka! Raspberry Pi Powered Tracker: 6 steg
Desktop COVID19 Tracker med klocka! Raspberry Pi Powered Tracker: Vi vet att vi kan dö när som helst, även jag kan dö medan jag skriver det här inlägget, trots allt, jag mig, du, vi är alla dödliga. Hela världen skakade på grund av COVID19 -pandemin. Vi vet hur vi ska förhindra detta, men hej! vi vet hur man ber och varför man ber, gör vi
Akustisk levitation med Arduino Uno Steg-för-steg (8-steg): 8 steg
Akustisk levitation med Arduino Uno Steg-för-steg (8-steg): ultraljudsgivare L298N Dc kvinnlig adapter strömförsörjning med en manlig DC-pin Arduino UNOBreadboardHur det fungerar: Först laddar du upp kod till Arduino Uno (det är en mikrokontroller utrustad med digital och analoga portar för att konvertera kod (C ++)
Movie Tracker - Raspberry Pi Powered Theatrical Release Tracker: 15 steg (med bilder)
Movie Tracker - Raspberry Pi Powered Theatrical Release Tracker: Movie Tracker är en clapperboardformad, Raspberry Pi -driven Release Tracker. Den använder TMDb API för att skriva ut affischen, titeln, utgivningsdatumet och översikten över kommande filmer i din region, inom ett visst tidsintervall (t.ex. filmsläpp den här veckan) den