Innehållsförteckning:

IOT123 - I2C 2CH RELAY BRICK: 5 Steg (med bilder)
IOT123 - I2C 2CH RELAY BRICK: 5 Steg (med bilder)

Video: IOT123 - I2C 2CH RELAY BRICK: 5 Steg (med bilder)

Video: IOT123 - I2C 2CH RELAY BRICK: 5 Steg (med bilder)
Video: IOT123 - ICOS10: STRUCTURE 2024, Juni
Anonim
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL
IOT123 - I2C 2CH RELÄ TEGL

IOT123 BRICKS är DIY modulära enheter som kan mosas ihop med andra IOT123 BRICKS, för att lägga till funktionalitet till en nod eller bärbar. De är baserade på tums fyrkantiga, dubbelsidiga protoboards med sammankopplade genomgående hål.

Ett antal av dessa BRICKS förväntas finnas på flera noder (Master MCU: er - ESP8266 eller ATTINY84) på en webbplats. MCU behöver ingen förkunskap om sensorernas syfte eller programvarubehov. Den söker efter I2C -noder och begär sedan en egendomsdump (sensordata) från varje slav. Dessa BRICK levererar 5.0V, 3.3V och en annan AUX -linje som kan anpassas.

Denna I2C 2CH RELAY BRICK utökar funktionaliteten för I2C KY019 BRICK och har två läs-/skrivegenskaper:

2CH RELAYS [0] (true/false)

2CH RELÄER [1] (true/false)

De genomgående hålen intill ATTINY85 har lämnats oanvända för att möjliggöra en pogo-stiftprogrammerare medan DIP8 löds till kretskortet. En ytterligare abstraktion, förpackning av BRICKS i små cylindrar som ansluts till ett D1M WIFI BLOCK -nav, som pumpar värdena till en MQTT -server, utvecklas.

Steg 1: Material och verktyg

Material och verktyg
Material och verktyg
Material och verktyg
Material och verktyg
Material och verktyg
Material och verktyg

Det finns en fullständig lista över material och inköpslista.

  1. 2 -kanalsrelä (1)
  2. ATTINY85 20PU (1)
  3. 1 "dubbelsidig protoboard (1)
  4. Manlig header 90º (3P, 3P)
  5. Manlig huvud (2P, 2P)
  6. Tröja Shunt (1)
  7. Anslutningstråd (~ 7)
  8. Löd och järn (1)

Steg 2: Förbered ATTINY85

Förbered ATTINY85
Förbered ATTINY85
Förbered ATTINY85
Förbered ATTINY85
Förbered ATTINY85
Förbered ATTINY85

OBS: Om du tänker ha Crouton -integration, använd biblioteket härifrån och använd exemplet installerat "attiny_2ch_relay".

AttinyCore från styrelsechefen behövs. Bränn bootloader "EEPROM Behållen", "8mHZ Internal" (all konfiguration visas ovan).

Kodförvaret hittar du här.

En ZIP av biblioteket hittar du här.

Instruktioner för "Importera ett ZIP -bibliotek" här.

När biblioteket är installerat kan du öppna exemplet "attiny_2ch_relay".

För att ladda upp firmware till ATTINY85 kan du hitta mer information i dessa instruktioner:

www.instructables.com/id/How-to-Program-A…

www.instructables.com/id/Programming-the-…

www.instructables.com/id/Programming-the-…

www.instructables.com/id/Programming-the-…

Bäst att testa via brödbräda innan du fortsätter.

Om du har befintliga ASSIMILATE SENSORS, se till att slavadressen är annorlunda på en SENSOR/MCU -värdkombination, dvs alla reläaktörer kan ha samma adress så länge du bara har en reläaktör på en MCU/nod.

Steg 3: Montera kretsen

Montera kretsen
Montera kretsen
Montera kretsen
Montera kretsen
Montera kretsen
Montera kretsen
  1. På framsidan, sätt in komponenterna ATTINY85 (1), 3P 90deg hanrubriker (2) (3), 3P hanrubriker (4) (5) och löd av på baksidan.
  2. På baksidan, spåra en gul tråd från GUL1 till GUL 2 och löd.
  3. På baksidan, spåra en orange tråd från ORANGE1 till ORANGE2 och löd.
  4. På baksidan, spåra en blå tråd från BLUE1 till BLUE2 och löd.
  5. På baksidan, spåra en grön tråd från GREEN1 till GREEN2 och löd.
  6. På baksidan, spåra en svart tråd från BLACK1 till BLACK2 och löd.
  7. På baksidan, spåra en svart tråd från BLACK3 till BLACK4 och löd.
  8. På baksidan, spåra en röd tråd från RED1 till RED2 och löd.
  9. På baksidan, spåra en bar tråd från RED3 till RED4 och löd.
  10. På baksidan, spåra en bar tråd från SILVER1 till SILVER2 och löd.
  11. Lägg till en bygel på 5V eller 3V3 linjen.

Reläet kan nu anslutas direkt via sina stift till kretskortet eller via ledningar, till de punkter som visas i stiftkontraktet.

Steg 4: Testning

Testning
Testning
Testning
Testning
Testning
Testning
Testning
Testning

Ett antal av dessa BRICKS förväntas finnas på flera noder (MCU: er - ESP8266 eller ATTINY84) i en miljö. Detta är ett enhetstest: skickar I2C -kommandon från UNO till ATTINY som öppnar eller stänger reläerna.

Vi har tidigare byggt ett I2C SHIELD för Arduino.

Om du vill panera det istället:

  1. Anslut 5.0V på UNO till en VCC på BRICK.
  2. Anslut GND på UNO till GND på BRICK.
  3. Anslut A5 på UNO till SCL på BRICK.
  4. Anslut A4 på UNO till SDA på BRICK.
  5. Anslut ett upptagningsmotstånd 4K7 från SDA till VCC.
  6. Anslut ett 4K7 uppdragningsmotstånd från SCL till VCC.

Kör testet

  1. Anslut din UNO till din Dev PC med USB.
  2. Ladda upp koden till UNO.
  3. Öppna Arduino -konsolen.
  4. Välj 9600 baud (starta om UNO och öppna konsolen igen om du måste).
  5. Slavens adress skrivs ut till konsolen.
  6. När, skriv in i sändningsrutan 2 0: 1 (alltså 15 2 0: 1) och CH1 -reläet slås på.

  7. När, skriv in i sändningsrutan 2 0: 0 (alltså 15 2 0: 0) och CH1 -reläet stängs av.
  8. När, skriv in i sändningsrutan 2 1: 1 (alltså 15 2 1: 1) och CH2 -reläet slås på.
  9. När, skriv in i sändningsrutan 2 1: 0 (alltså 15 2 0: 0) och CH2 -reläet stängs av.

I2C BRICK adhoc -kommandon för slavar från UNO master

#omfatta
const byte _num_chars = 32;
char _received_chars [_num_chars]; // en array för att lagra mottagen data
booleska _has_new_data = false;
voidsetup () {
Serial.begin (9600);
Serial.println ();
Serial.println ("ASSIMILATE IOT ACTOR/SENSOR EEPROM EDITOR");
Serial.println ("se till att ny rad har valts i konsolfönstret");
Serial.println ();
Serial.println ("ADRESS 1 CONFIRM METADATA RECEIPT N/A (FOR M2M)");
Serial.println ("ADRESS 2 ACTOR COMMAND");
Serial.println ();
Serial.println ("ADRESSES ON BUS:");
scan_i2c_addresses ();
Serial.println ();
Serial.println ("");
}
voidscan_i2c_addresses () {
int device_count = 0;
för (byte -adress = 8; adress <127; adress ++)
{
Wire.beginTransmission (adress);
const byte error = Wire.endTransmission ();
om (fel == 0)
{
Serial.println (adress);
}
}
}
voidloop () {
recv_with_end_marker ();
send_to_i2c ();
}
voidrecv_with_end_marker () {
statisk byte ndx = 0;
char end_marker = '\ n';
röding;
medan (Serial.available ()> 0 && _has_new_data == false) {
rc = Serial.read ();
if (rc! = end_marker) {
_received_chars [ndx] = rc;
ndx ++;
if (ndx> = _num_chars) {
ndx = _num_chars - 1;
}
}
annat {
_received_chars [ndx] = '\ 0'; // avsluta strängen
ndx = 0;
_has_new_data = true;
}
}
}
voidsend_to_i2c () {
char param_buf [16];
const String received_string = String (_received_chars);
om (_has_new_data == true) {
int idx1 = received_string.indexOf ('');
String address = received_string.substring (0, idx1);
int address_int = address.toInt ();
if (address_int <8 || address_int> 127) {
Serial.println ("OGILTIG ADRESSINGÅNG:");
Serial.println (adress);
lämna tillbaka;
}
int idx2 = received_string.indexOf ('', idx1+1);
Strängkod;
om (idx2 == -1) {
kod = mottagen_sträng.substräng (idx1+1);
}annan{
kod = mottagen_sträng.substräng (idx1+1, idx2+1);
}
int code_int = code.toInt ();
if (code_int <0 || code_int> 5) {
Serial.println ("INGÅNG KODINGÅNG:");
Serial.println (kod);
lämna tillbaka;
}
bool has_parameter = idx2> -1;
Strängparameter;
if (has_parameter) {
parameter = received_string.substring (idx2 + 1, idx2 + 17); // 16 tecken max
if (parameter.length () <1) {
Serial.println ("PARTAMETER MIN. LÄNGD 1");
_has_new_data = false;
lämna tillbaka;
}
}annan{
om (code_int> 1) {
Serial.println ("PARAMETER KRÄVS!");
_has_new_data = false;
lämna tillbaka;
}
}
Serial.println ();
Serial.print ("input orig =");
Serial.println (mottagen_sträng);
Serial.print ("address =");
Serial.println (adress);
Serial.print ("kod =");
Serial.println (kod);
Serial.print ("parameter =");
Serial.println (parameter);
// SKICKA VIA I2C
Wire.beginTransmission (address_int);
Wire.write (code_int);
if (has_parameter) {
parameter.trim ();
strcpy (param_buf, parameter.c_str ());
Wire.write (param_buf);
}
Wire.endTransmission ();
Serial.println ();
Serial.println ("SKICKAD VIA I2C!");
Serial.println ();
Serial.println ("");
_has_new_data = false;
}
}

visa rawuno_i2c_command_input.ino värd med ❤ av GitHub

Steg 5: Nästa steg

Nästa steg
Nästa steg
Nästa steg
Nästa steg
Nästa steg
Nästa steg
Nästa steg
Nästa steg

Uppföljningen ASSIMILATE ACTOR: 2CH RELAY som använder denna tegel har automatisk konfiguration för Crouton via metadata som redan är installerad i ATTINY85 här. JSON -paketet som skickas till Crouton skickas via den senaste firmware för ICOS10. Du kan göra ett Proof-of-concept på en vanlig ESP8266, om bygget är för mycket för nu.

UNO -skissen som används i testning har en funktion för att spara en ny slavadress till EEPROM på ATTINY85, om du har en kollision på din mål -I2C -buss. Några scheman har lagts till, men det finns olika sätt att koppla nedströms -kretsen beroende på vad du vill uppnå, så jag lämnar det åt dig:)

Rekommenderad: