Fórum témák

» Több friss téma
Fórum » Arduino
A klónok CH340 Soros-USB illesztőjének drivere (Letöltés)
Lapozás: OK   327 / 852
(#) KoblogPerGyok válasza soskajoska hozzászólására (») Márc 4, 2017 /
 
Szia!

Szerintem megoldható, azonban jó lenne tudni, hogy maximum mennyi embert kell memóriában tartani, de szerintem ez nem lesz gond. A pontos(abb) időméréshez, RTC kell, ezen kívül kellene szerintem egy SD kártyaolvasó, illetve az RFID olvasó és egy I2C illesztő+LCD kijelző, később lehet még kelleni fog egy keypad. Attól függ milyen az arduino, lehet kell még a keypad-hoz i2C illesztő, de csak akkor, ha nincs elég digitális láb van a kiválasztott arduino-n.

Ellenállások, Led esetleg, stb.

Szerintem elsőnek ennyi.
(#) Kovidivi válasza KoblogPerGyok hozzászólására (») Márc 4, 2017 /
 
LCD mehet I2C illesztő nélkül is, felesleges túlbonyolítani. SD kártya sem lényeg, van bőven eeprom, abban el lehet férni szerintem.
(#) soskajoska válasza KoblogPerGyok hozzászólására (») Márc 4, 2017 /
 
Szia!
Alapvetően egy, max. 2 személy rögzítésére gondoltam. RTC rendben, csak mondjuk az RFID még ismeretlen a számomra. Data logger kapcsolásokat már elkezdtem tanulmányozni. Amin még agyalok, hogy gombnyomásra, vagy RFID kártyára éledjen, ha egyáltalán lehet az Arduinot stand-by üzemmódba rakni (akkus táplálás). A tárolt info: dátum, kezdő időpont, záró időpont. (Esetleg még az eltelt idő)
Az igazság az, hogy édesanyámnál a gondozónő jelenlétét szeretném ellenőrizni, mivel erős a gyanúm, hogy vastagon fog a ceruzájuk
A hozzászólás módosítva: Márc 4, 2017
(#) Kovidivi válasza soskajoska hozzászólására (») Márc 4, 2017 /
 
Ne legyen akku üzemmód. Egy 1$-os telefontöltővel megtáplálva nem lesz gondod vele. Akksival tovább fog bonyolódni a hardver.
(#) akosnagy hozzászólása Márc 4, 2017 /
 
Sziasztok!
Van egy kis WiFi gondom. Vettem egy Arduino Uno WiFi boardot. Az egyértelműség kedvéért: nem egy Uno és WiFi shieldet, hanem Uno-ra integrált WiFi.

  1. //#include <WiFi.h>
  2. //#include <WiFiUdp.h>
  3.  
  4. #include <SPI.h>
  5. #include <WiFi101.h>
  6.  
  7. IPAddress ip(192,168,100,109);
  8.  
  9. char ssid[] = "SunLion";
  10. char key[] = "k4v3c1g1";
  11.  
  12. int status = WL_IDLE_STATUS;
  13.  
  14. void setup() {
  15.   // put your setup code here, to run once:
  16.   Serial.begin(9600);
  17.  
  18.   if (WiFi.status() == WL_NO_SHIELD) {
  19.     Serial.println("WiFi shield not present");
  20.     // don't continue:
  21.     while (true);
  22.   }
  23.  
  24.   WiFi.config(ip);
  25.  
  26.     while(status != WL_CONNECTED) {
  27.       Serial.print("várakozás:  ");
  28.       Serial.println(ssid);
  29.       status = WiFi.begin(ssid, key);
  30.       delay(10000);
  31.     }
  32.  
  33.     Serial.print("IP Address: ");
  34.     Serial.println(WiFi.localIP());
  35. }
  36.  
  37. void loop() {
  38.   // put your main code here, to run repeatedly:
  39. }


Ez a kódom. A WiFi.status-nál akad el. WiFi shield not present

Ezen a linken találtam beállítást: http://www.arduino.org/learning/getting-started/getting-started-wit...o-wifi
Ezt végig csináltam. Mobiltelefon, számítógép, tablet látja az eszközt WiFi-n. Épp csak programozni nem tudom.
Ötlet?
(#) KoblogPerGyok válasza soskajoska hozzászólására (») Márc 4, 2017 /
 
Most fáradt vagyok, de írtad:

" vagy RFID kártyára éledjen, ha egyáltalán lehet az Arduinot stand-by üzemmódba rakni (akkus táplálás)."

RFID felélesztheti. De fix tápláláskor nem is kell. Az EEPROM is ok, de azt kiolvasni? Arduino kivesz, pc összeköt sketch feltölt ami kiolvas, majd a régi vissza? Ok, megoldható ez nélkül is, de akkor a kódot kell felkészíteni rá.

Akkor inkább mindkettő! Redundánsan meglenne minden adat! SD kártya csak azért, hogy a pc-ben fel tudd könnyem dolgozni az adatokat havonta.
(#) akosnagy válasza akosnagy hozzászólására (») Márc 4, 2017 /
 
Okulásképp! Én vagyok a hülye!
Ha egyszer nincs WiFi shield, persze, hogy nem találja.
A működő program

  1. /*
  2. File: WebServer.ino
  3. This example creates a simple web server on your Arduino Uno WiFi. It serves a
  4. simple web page which shows values of the analog pins, and refreshes every 20 seconds.
  5. Please type on your browser http://<IP>/arduino/webserver/ or http://<hostname>.local/arduino/webserver/
  6.  
  7. Note: works only with Arduino Uno WiFi Developer Edition.
  8.  
  9. http://www.arduino.org/learning/tutorials/boards-tutorials/webserver
  10. */
  11.  
  12. #include <Wire.h>
  13. #include <UnoWiFiDevEd.h>
  14. #include "cactus_io_BME280_I2C.h"
  15.  
  16. BME280_I2C bme(0x76);
  17.  
  18. void setup() {
  19.  Serial.begin(9600);
  20.  Wifi.begin();
  21.  Wifi.println("Web Server is up");
  22.  bme.begin();
  23.  bme.setTempCal(-1);
  24. }
  25.  
  26. void loop() {
  27.  
  28.  while(Wifi.available()){
  29.  process(Wifi);
  30.  }
  31.  delay(50);
  32. }
  33.  
  34. void process(WifiData client) {
  35.  // read the command
  36.  String command = client.readStringUntil('/');
  37.  
  38.  if (command == "webserver") {
  39.  WebServer(client);
  40.  }
  41. }
  42. void WebServer(WifiData client) {
  43.  client.println("HTTP/1.1 200 OK");
  44.  client.println("Content-Type: text/html");
  45.  client.println("Connection: close");
  46.  client.println("Refresh: 20"); // refresh the page automatically every sec
  47.  client.println();
  48.  client.println("<html>");
  49.  client.println("<head> <title>UNO WIFI Example</title> </head>");
  50.  client.print("<body>");
  51.  
  52. // for(int analogChannel = 0; analogChannel < 4; analogChannel++) {
  53. // int sensorReading = analogRead(analogChannel);
  54.  bme.readSensor();
  55.  
  56.  client.print("Pressure: ");
  57.  client.print(bme.getPressure_MB());
  58.  client.print("mb<br>");
  59.  client.print("Humidity: ");
  60.  client.print(bme.getHumidity());
  61.  client.print("%<br>");
  62.  client.print("Temperature: ");
  63.  client.print(bme.getTemperature_C());
  64.  client.print("C<br>");
  65.  
  66.  
  67.  
  68.  client.print("</body>");
  69.  client.println("</html>");
  70.  client.print(DELIMITER); // very important to end the communication !!!
  71. }
(#) Sanyessz hozzászólása Márc 5, 2017 /
 
Helló mindenkinek.
Lenne egy elég hülye problémám...
Van egy Megám és nyíván meghalt a 20-21-es lába, amit I2C kommunikációra használtam.
Valahogy lehetne másik portot használni ugyan erre a célra??
A hibát több mint valószínű az okozhatta, hogy nem csináltam rendes panelt csak úgy hipp-hopp összedobáltam hozzá a dolgokat, és ha majd működik akkor lehet szépíteni a dolgokat.
(#) Medve válasza Sanyessz hozzászólására (») Márc 5, 2017 /
 
SZia, szoftveres I2C-t használj, ott átirányíthatod a kommunikációt, "bármelyik" más lábra.
(#) Sanyessz válasza Medve hozzászólására (») Márc 6, 2017 /
 
Erre már én is gondoltam csak nem találtam rá leírást vagy valami példát. Az is megfordult a fejemben hogy a Mega pin...Arduino.h-ban átírom a lábak funkcióját, de ez a szoftveres dolog kényelmesebb lenne, mivel már megvan írva egy prog amit nem szeretnék nagyon változtatni.
Kaphatnék valami konkrétabb iránymutatást erre a szoftveres I2C -re?
Üdv
(#) KoblogPerGyok válasza Sanyessz hozzászólására (») Márc 6, 2017 /
 
Szia!

https://blog.arduino.cc/2010/10/01/softi2cmaster-library-lets-you-a...o-pin/

Ilyesmi lehet a megoldás esetleg, mint ahogy korábban Medve írta.
(#) Medve válasza KoblogPerGyok hozzászólására (») Márc 6, 2017 /
 
Például, én meg ezt találtam: Bővebben: Link, Portot is meg kell adni, és azon belül nem a lábszámot, hanem a bitjét. Aztán gépészkedni kell vele rendesen, de kitanulod a működését.
(#) kezdoke hozzászólása Márc 7, 2017 /
 
Sziasztok,

Teljesen kezdő vagyok ebben az arduinos témában.

A kérdésem hogy hogyan tudnám megoldani hogy etherneten keresztűl reléket tudjak kapcsolni? A probléma hogy kevés a memoria a weblap miatt esetlegesen nem lehet hogy egy sd kártyára a weblap kódját feltöltöm és azt jelenlítse meg ?

de ha valakinek van forrása hogy Uno R3-al és ethernetshieldel lanon keresztül tudjak 8 relét kapcsolni az is jó
(#) KoblogPerGyok válasza kezdoke hozzászólására (») Márc 7, 2017 /
 
(#) FDAssasin hozzászólása Márc 7, 2017 /
 
Sziasztok!
Lenne egy kisebb problémám egy DS3231 RTC modullal. Egy Arduino pro minit átállítottam 1MHz-re és azzal olvastatom róla az időt, mindkettő egy CR2032-es elemről megy. Az Arduino egy 4+6 ledes bináris óra számlapját vezérli, a kapott infók alapján. A gond az lenne, hogy amikor elindul az Arduino, beáll az idő 6:01-re és onnan lépked. Mindegy hogy meddig jut el, minden indulásnál beáll a 6:01, pedig van elem az RTC-ben. Mit szúrtam el?
  1. #include "Wire.h"
  2. //#include <avr/power.h>
  3. #define DS3231_I2C_ADDRESS 0x68
  4. int buttonpin = 2;
  5. int buttonstate = 0;
  6. int h1 = 12;
  7. int h2 = 11;
  8. int h4 = 10;
  9. int h8 = 9;
  10. int m1 = 8;
  11. int m2 = 7;
  12. int m4 = 6;
  13. int m8 = 5;
  14. int m16 = 4;
  15. int m32 = 3;
  16. int hourcheckbit = 0;
  17. byte decToBcd(byte val)
  18. {
  19.   return( (val/10*16) + (val%10) );
  20. }
  21. byte bcdToDec(byte val)
  22. {
  23.   return( (val/16*10) + (val%16) );
  24. }
  25. void setup()
  26. {
  27.   Wire.begin();
  28.   //Serial.begin(9600);
  29.   pinMode(h1, OUTPUT);
  30.   pinMode(h2, OUTPUT);
  31.   pinMode(h4, OUTPUT);
  32.   pinMode(h8, OUTPUT);
  33.   pinMode(m1, OUTPUT);
  34.   pinMode(m2, OUTPUT);
  35.   pinMode(m4, OUTPUT);
  36.   pinMode(m8, OUTPUT);
  37.   pinMode(m16, OUTPUT);
  38.   pinMode(m32, OUTPUT);
  39.   pinMode(buttonpin, INPUT_PULLUP);
  40.   pinMode(13, OUTPUT);
  41.   digitalWrite(13, LOW);
  42.   ADCSRA = ADCSRA & B01111111;
  43.   ACSR = B10000000;
  44.   DIDR0 = DIDR0 | B00111111;
  45.   //CLKPR = 0;
  46.   //CLKPR = (1<<CLKPCE);
  47.   //CLKPR = _BV(CLKPS1) | _BV(CLKPS0);
  48. }
  49. void readDS3231time(byte *second,
  50. byte *minute,
  51. byte *hour)
  52. {
  53.   Wire.beginTransmission(DS3231_I2C_ADDRESS);
  54.   Wire.write(0);
  55.   Wire.endTransmission();
  56.   Wire.requestFrom(DS3231_I2C_ADDRESS, 7);
  57.   *second = bcdToDec(Wire.read() & 0x7f);
  58.   *minute = bcdToDec(Wire.read());
  59.   *hour = bcdToDec(Wire.read() & 0x3f);
  60. }
  61. void displayTime()
  62. {
  63.   byte second, minute, hour;
  64.   if (hourcheckbit > 0) {
  65.     hour = hour + 12;
  66.     hourcheckbit = 0;
  67.   }
  68.   buttonstate = digitalRead(buttonpin);
  69.   if (buttonstate == LOW) {
  70.   minute++;
  71.   if (minute == 60) {
  72.     minute = 0;
  73.     hour++;
  74.   }
  75.   Wire.beginTransmission(DS3231_I2C_ADDRESS);
  76.     Wire.write(0); // set next input to start at the seconds register
  77.     Wire.write(decToBcd(second)); // set seconds
  78.     Wire.write(decToBcd(minute)); // set minutes
  79.     Wire.write(decToBcd(hour));
  80.     Wire.endTransmission();
  81.   }
  82.   // retrieve data from DS3231
  83.   readDS3231time(&second, &minute, &hour);
  84.   if (hour > 11) {
  85.     hour = hour - 12;
  86.     hourcheckbit++;
  87.   }
  88.   digitalWrite(h1, LOW);
  89.   digitalWrite(h2, LOW);
  90.   digitalWrite(h4, LOW);
  91.   digitalWrite(h8, LOW);
  92.   digitalWrite(m1, LOW);
  93.   digitalWrite(m2, LOW);
  94.   digitalWrite(m4, LOW);
  95.   digitalWrite(m8, LOW);
  96.   digitalWrite(m16, LOW);
  97.   digitalWrite(m32, LOW);
  98.   if (hour == 1) {
  99.   digitalWrite(h1, HIGH);
  100.   }
  101. if (hour == 2) {
  102.   digitalWrite(h2, HIGH);
  103.   }
  104. if (hour == 3) {
  105.   digitalWrite(h1, HIGH);
  106.   digitalWrite(h2, HIGH);
  107.   }
  108. if (hour == 4) {
  109.   digitalWrite(h4, HIGH);
  110.   }
  111. if (hour == 5) {
  112.   digitalWrite(h1, HIGH);
  113.   digitalWrite(h4, HIGH);
  114.   }
  115. if (hour == 6) {
  116.   digitalWrite(h2, HIGH);
  117.   digitalWrite(h4, HIGH);
  118.   }
  119. if (hour == 7) {
  120.   digitalWrite(h1, HIGH);
  121.   digitalWrite(h2, HIGH);
  122.   digitalWrite(h4, HIGH);
  123.   }
  124. if (hour == 8) {
  125.   digitalWrite(h8, HIGH);
  126.   }
  127. if (hour == 9) {
  128.   digitalWrite(h1, HIGH);
  129.   digitalWrite(h8, HIGH);
  130.   }
  131. if (hour == 10) {
  132.   digitalWrite(h2, HIGH);
  133.   digitalWrite(h8, HIGH);
  134.   }
  135. if (hour == 11) {
  136.   digitalWrite(h1, HIGH);
  137.   digitalWrite(h2, HIGH);
  138.   digitalWrite(h8, HIGH);
  139.   }
  140. if (minute == 1) {
  141.   digitalWrite(m1, HIGH);
  142.   }
  143. if (minute == 2) {
  144.   digitalWrite(m2, HIGH);
  145.   }
  146. if (minute == 3) {
  147.   digitalWrite(m1, HIGH);
  148.   digitalWrite(m2, HIGH);
  149.   }
  150. if (minute == 4) {
  151.   digitalWrite(m4, HIGH);
  152.   }
  153. if (minute == 5) {
  154.   digitalWrite(m1, HIGH);
  155.   digitalWrite(m4, HIGH);
  156.   }
  157. if (minute == 6) {
  158.   digitalWrite(m2, HIGH);
  159.   digitalWrite(m4, HIGH);
  160.   }
  161. if (minute == 7) {
  162.   digitalWrite(m1, HIGH);
  163.   digitalWrite(m2, HIGH);
  164.   digitalWrite(m4, HIGH);
  165.   }
  166. if (minute == 8) {
  167.   digitalWrite(m8, HIGH);
  168.   }
  169. if (minute == 9) {
  170.   digitalWrite(m1, HIGH);
  171.   digitalWrite(m8, HIGH);
  172.   }
  173. if (minute == 10) {
  174.   digitalWrite(m2, HIGH);
  175.   digitalWrite(m8, HIGH);
  176.   }
  177. if (minute == 11) {
  178.   digitalWrite(m1, HIGH);
  179.   digitalWrite(m2, HIGH);
  180.   digitalWrite(m8, HIGH);
  181.   }
  182. if (minute == 12) {
  183.   digitalWrite(m4, HIGH);
  184.   digitalWrite(m8, HIGH);
  185.   }
  186. if (minute == 13) {
  187.   digitalWrite(m1, HIGH);
  188.   digitalWrite(m4, HIGH);
  189.   digitalWrite(m8, HIGH);
  190.   }
  191. if (minute == 14) {
  192.   digitalWrite(m2, HIGH);
  193.   digitalWrite(m4, HIGH);
  194.   digitalWrite(m8, HIGH);
  195.   }
  196. if (minute == 15) {
  197.   digitalWrite(m1, HIGH);
  198.   digitalWrite(m2, HIGH);
  199.   digitalWrite(m4, HIGH);
  200.   digitalWrite(m8, HIGH);
  201.   }
  202. if (minute == 16) {
  203.   digitalWrite(m16, HIGH);
  204.   }
  205. if (minute == 17) {
  206.   digitalWrite(m1, HIGH);
  207.   digitalWrite(m16, HIGH);
  208.   }
  209. if (minute == 18) {
  210.   digitalWrite(m2, HIGH);
  211.   digitalWrite(m16, HIGH);
  212.   }
  213. if (minute == 19) {
  214.   digitalWrite(m1, HIGH);
  215.   digitalWrite(m2, HIGH);
  216.   digitalWrite(m16, HIGH);
  217.   }
  218. if (minute == 20) {
  219.   digitalWrite(m4, HIGH);
  220.   digitalWrite(m16, HIGH);
  221.   }
  222. if (minute == 21) {
  223.   digitalWrite(m1, HIGH);
  224.   digitalWrite(m4, HIGH);
  225.   digitalWrite(m16, HIGH);
  226.   }
  227. if (minute == 22) {
  228.   digitalWrite(m2, HIGH);
  229.   digitalWrite(m4, HIGH);
  230.   digitalWrite(m16, HIGH);
  231.   }
  232. if (minute == 23) {
  233.   digitalWrite(m1, HIGH);
  234.   digitalWrite(m2, HIGH);
  235.   digitalWrite(m4, HIGH);
  236.   digitalWrite(m16, HIGH);
  237.   }
  238. if (minute == 24) {
  239.   digitalWrite(m8, HIGH);
  240.   digitalWrite(m16, HIGH);
  241.   }
  242. if (minute == 25) {
  243.   digitalWrite(m1, HIGH);
  244.   digitalWrite(m8, HIGH);
  245.   digitalWrite(m16, HIGH);
  246.   }
  247. if (minute == 26) {
  248.   digitalWrite(m2, HIGH);
  249.   digitalWrite(m8, HIGH);
  250.   digitalWrite(m16, HIGH);
  251.   }
  252. if (minute == 27) {
  253.   digitalWrite(m1, HIGH);
  254.   digitalWrite(m2, HIGH);
  255.   digitalWrite(m8, HIGH);
  256.   digitalWrite(m16, HIGH);
  257.   }
  258. if (minute == 28) {
  259.   digitalWrite(m4, HIGH);
  260.   digitalWrite(m8, HIGH);
  261.   digitalWrite(m16, HIGH);
  262.   }
  263. if (minute == 29) {
  264.   digitalWrite(m1, HIGH);
  265.   digitalWrite(m4, HIGH);
  266.   digitalWrite(m8, HIGH);
  267.   digitalWrite(m16, HIGH);
  268.   }
  269. if (minute == 30) {
  270.   digitalWrite(m2, HIGH);
  271.   digitalWrite(m4, HIGH);
  272.   digitalWrite(m8, HIGH);
  273.   digitalWrite(m16, HIGH);
  274.   }
  275. if (minute == 31) {
  276.   digitalWrite(m1, HIGH);
  277.   digitalWrite(m2, HIGH);
  278.   digitalWrite(m4, HIGH);
  279.   digitalWrite(m8, HIGH);
  280.   digitalWrite(m16, HIGH);
  281.   }
  282. if (minute == 32) {
  283.   digitalWrite(m32, HIGH);
  284.   }
  285. if (minute == 33) {
  286.   digitalWrite(m1, HIGH);
  287.   digitalWrite(m32, HIGH);
  288.   }
  289. if (minute == 34) {
  290.   digitalWrite(m2, HIGH);
  291.   digitalWrite(m32, HIGH);
  292.   }
  293. if (minute == 35) {
  294.   digitalWrite(m1, HIGH);
  295.   digitalWrite(m2, HIGH);
  296.   digitalWrite(m32, HIGH);
  297.   }
  298. if (minute == 36) {
  299.   digitalWrite(m4, HIGH);
  300.   digitalWrite(m32, HIGH);
  301.   }
  302. if (minute == 37) {
  303.   digitalWrite(m1, HIGH);
  304.   digitalWrite(m4, HIGH);
  305.   digitalWrite(m32, HIGH);
  306.   }
  307. if (minute == 38) {
  308.   digitalWrite(m2, HIGH);
  309.   digitalWrite(m4, HIGH);
  310.   digitalWrite(m32, HIGH);
  311.   }
  312. if (minute == 39) {
  313.   digitalWrite(m1, HIGH);
  314.   digitalWrite(m2, HIGH);
  315.   digitalWrite(m4, HIGH);
  316.   digitalWrite(m32, HIGH);
  317.   }
  318. if (minute == 40) {
  319.   digitalWrite(m8, HIGH);
  320.   digitalWrite(m32, HIGH);
  321.   }
  322. if (minute == 41) {
  323.   digitalWrite(m1, HIGH);
  324.   digitalWrite(m8, HIGH);
  325.   digitalWrite(m32, HIGH);
  326.   }
  327. if (minute == 42) {
  328.   digitalWrite(m2, HIGH);
  329.   digitalWrite(m8, HIGH);
  330.   digitalWrite(m32, HIGH);
  331.   }
  332. if (minute == 43) {
  333.   digitalWrite(m1, HIGH);
  334.   digitalWrite(m2, HIGH);
  335.   digitalWrite(m8, HIGH);
  336.   digitalWrite(m32, HIGH);
  337.   }
  338. if (minute == 44) {
  339.   digitalWrite(m4, HIGH);
  340.   digitalWrite(m8, HIGH);
  341.   digitalWrite(m32, HIGH);
  342.   }
  343. if (minute == 45) {
  344.   digitalWrite(m1, HIGH);
  345.   digitalWrite(m4, HIGH);
  346.   digitalWrite(m8, HIGH);
  347.   digitalWrite(m32, HIGH);
  348.   }
  349. if (minute == 46) {
  350.   digitalWrite(m2, HIGH);
  351.   digitalWrite(m4, HIGH);
  352.   digitalWrite(m8, HIGH);
  353.   digitalWrite(m32, HIGH);
  354.   }
  355. if (minute == 47) {
  356.   digitalWrite(m1, HIGH);
  357.   digitalWrite(m2, HIGH);
  358.   digitalWrite(m4, HIGH);
  359.   digitalWrite(m8, HIGH);
  360.   digitalWrite(m32, HIGH);
  361.   }
  362. if (minute == 48) {
  363.   digitalWrite(m16, HIGH);
  364.   digitalWrite(m32, HIGH);
  365.   }
  366. if (minute == 49) {
  367.   digitalWrite(m1, HIGH);
  368.   digitalWrite(m16, HIGH);
  369.   digitalWrite(m32, HIGH);
  370.   }
  371. if (minute == 50) {
  372.   digitalWrite(m2, HIGH);
  373.   digitalWrite(m16, HIGH);
  374.   digitalWrite(m32, HIGH);
  375.   }
  376. if (minute == 51) {
  377.   digitalWrite(m1, HIGH);
  378.   digitalWrite(m2, HIGH);
  379.   digitalWrite(m16, HIGH);
  380.   digitalWrite(m32, HIGH);
  381.   }
  382. if (minute == 52) {
  383.   digitalWrite(m4, HIGH);
  384.   digitalWrite(m16, HIGH);
  385.   digitalWrite(m32, HIGH);
  386.   }
  387. if (minute == 53) {
  388.   digitalWrite(m1, HIGH);
  389.   digitalWrite(m4, HIGH);
  390.   digitalWrite(m16, HIGH);
  391.   digitalWrite(m32, HIGH);
  392.   }
  393. if (minute == 54) {
  394.   digitalWrite(m2, HIGH);
  395.   digitalWrite(m4, HIGH);
  396.   digitalWrite(m16, HIGH);
  397.   digitalWrite(m32, HIGH);
  398.   }
  399. if (minute == 55) {
  400.   digitalWrite(m1, HIGH);
  401.   digitalWrite(m2, HIGH);
  402.   digitalWrite(m4, HIGH);
  403.   digitalWrite(m16, HIGH);
  404.   digitalWrite(m32, HIGH);
  405.   }
  406. if (minute == 56) {
  407.   digitalWrite(m8, HIGH);
  408.   digitalWrite(m16, HIGH);
  409.   digitalWrite(m32, HIGH);
  410.   }
  411. if (minute == 57) {
  412.   digitalWrite(m1, HIGH);
  413.   digitalWrite(m8, HIGH);
  414.   digitalWrite(m16, HIGH);
  415.   digitalWrite(m32, HIGH);
  416.   }
  417. if (minute == 58) {
  418.   digitalWrite(m2, HIGH);
  419.   digitalWrite(m8, HIGH);
  420.   digitalWrite(m16, HIGH);
  421.   digitalWrite(m32, HIGH);
  422.   }
  423. if (minute == 59) {
  424.   digitalWrite(m1, HIGH);
  425.   digitalWrite(m2, HIGH);
  426.   digitalWrite(m8, HIGH);
  427.   digitalWrite(m16, HIGH);
  428.   digitalWrite(m32, HIGH);
  429.   }
  430.   /*
  431.   byte second, minute, hour;
  432.   // retrieve data from DS3231
  433.   readDS3231time(&second, &minute, &hour);
  434.   // send it to the serial monitor
  435.   Serial.print(hour, DEC);
  436.   // convert the byte variable to a decimal number when displayed
  437.   Serial.print(":");
  438.   if (minute<10)
  439.   {
  440.     Serial.print("0");
  441.   }
  442.   Serial.print(minute, DEC);
  443.   Serial.print(":");
  444.   if (second<10)
  445.   {
  446.     Serial.print("0");
  447.   }
  448.   Serial.print(second, DEC);
  449.   */
  450. }
  451. void loop()
  452. {
  453.   displayTime(); // display the real-time clock data on the Serial Monitor,
  454.   delay(1000); // every second
  455. }


Illetve ha valaki nagyon ráérne bogarászni ezt a spagetti kódot... hogy tudnám csökkenteni a méretét? Mert látszik, hogy a nagyrésze ismétlődő kód, de nem jövök rá hogy ez hogy lehetne kisebb. Ez így 6024 byte és nagyon jó lenne 4096 alá vinni, amennyire csak lehet. Eredetileg PWM vezérlésű volt, de az +400 byte, szóval kivettem. Köszi előre is, már annak is aki végigolvassa!

---UPDATE---
Annyit még hozzátennék, hogy előtte az RTC-t egy másik arduinoval programoztam, de 5:39-re. Mondjuk benne volt az elem egy ideig, lehet elment 6:01-ig.
A hozzászólás módosítva: Márc 7, 2017
(#) tbarath hozzászólása Márc 7, 2017 /
 
Vessetek a mókusok elé, de én nem tennék arduinora webservert. És ahogy hallottam ethernet chip-ből is van ami instabil tud lenni.

Én pi zero+homeassistant irányt tervezek ilyen relé (és sokminden más) kapcsolgatós témában.
(#) Kovidivi válasza tbarath hozzászólására (») Márc 7, 2017 /
 
Ágyúval verébre?
(#) icserny válasza FDAssasin hozzászólására (») Márc 7, 2017 /
 
Ha jól látom, a DisplayTime függvényben feltétel nélkül felülírod az RTC-ben az időt:
  1. Wire.beginTransmission(DS3231_I2C_ADDRESS);
  2. Wire.write(0); // set next input to start at the seconds register
  3. Wire.write(decToBcd(second)); // set seconds
  4. Wire.write(decToBcd(minute)); // set minutes
  5. Wire.write(decToBcd(hour));
  6. Wire.endTransmission();


Ezt valamilyen feltételhez kellene kötni!
(#) FDAssasin válasza icserny hozzászólására (») Márc 7, 2017 /
 
Nem, az időt akkor írom, ha a 2-es láb feszültségértéke alacsony:
  1. buttonstate = digitalRead(buttonpin);
  2.   if (buttonstate == LOW) {
  3.   minute++;
  4.   if (minute == 60) {
  5.     minute = 0;
  6.     hour++;
  7.   }
  8.   Wire.beginTransmission(DS3231_I2C_ADDRESS);
  9.     Wire.write(0); // set next input to start at the seconds register
  10.     Wire.write(decToBcd(second)); // set seconds
  11.     Wire.write(decToBcd(minute)); // set minutes
  12.     Wire.write(decToBcd(hour));
  13.     Wire.endTransmission();
  14.   }
(#) Bakman válasza tbarath hozzászólására (») Márc 7, 2017 /
 
Mi a baj a webszerver és Aurduino párossal?
(#) tbarath válasza Kovidivi hozzászólására (») Márc 7, 2017 /
 
Nézőpont kérdése.
Szerintem az arduino (pontosabban az atmega 368) egy nagyon jó _mikrokontroller_, de ez nem jelenti azt hogy webserver feladatra jó lenne.

Ugyanakkor nálam a homeassistant nem csak reléket kapcsolgatna, hanem egy kicsit nagyobb funkcionalitású dolog lenne (ez itt nagyrészt OFF).

A zero pedig - a szállítást nem számolva - kb. annyina kerül mint egy uno klón, szóval ez az irány 4 GBP szállítási költséggel és egy uSD kártya árával drágább. (A LAN csatlakozás és a relé mindkettőnél pénzbe kerül, kb. ugyanannyiba.)
(#) icserny válasza FDAssasin hozzászólására (») Márc 7, 2017 /
 
Bocs, akkor benéztem az if zárójel párosításokat.
(#) tbarath válasza Bakman hozzászólására (») Márc 7, 2017 / 1
 
A problémám az, hogy nagyon nehézkesen programozható (egyáltalán van hozzá "full" TCP/IP stack?), szóval küzdős, és gondolom a sebessége se túl acélos. Amiket eddig láttam arduino+webserver témában azok nagyrészt ilyen "Hello World" és "Analog 0 is 253" kategóriájú dolgok voltak, "so 1994" kinézettel. Arra mondjuk biztos jó.

Illetve még egy dolog: ahogy látom a google ki akarja nyírni a plain http-t, és szerintem a firefox is menni fog velük. Nem ma és nem holnap lesz az, hogy tiltani fogják, de előbb utóbb ez lesz. Egy "rendes" SoC-n pedig a HTTPS pedig Let's Encrypt-tel megoldható (mondjuk egy domain nem árt hozzá), erre pedig az Uno gyenge.
A hozzászólás módosítva: Márc 7, 2017
(#) tbarath válasza FDAssasin hozzászólására (») Márc 7, 2017 /
 
  1. digitalWrite(h1, LOW);
  2.   digitalWrite(h2, LOW);
  3.   digitalWrite(h4, LOW);
  4.   digitalWrite(h8, LOW);
  5. ...
  6.   if (hour == 1) {
  7.   digitalWrite(h1, HIGH);
  8.   }
  9. if (hour == 2) {
  10.   digitalWrite(h2, HIGH);
  11.   }
  12. if (hour == 3) {
  13.   digitalWrite(h1, HIGH);
  14.   digitalWrite(h2, HIGH);
  15.   }
  16. if (hour == 4) {
  17.   digitalWrite(h4, HIGH);
  18.   }


Ezt inkább valahogy így csinálnám (a kód simán lehet hibás, maga az elv a lényeg):
  1. digitalWrite(h1, hour % 2);
  2.   hour = hour / 2;
  3.   digitalWrite(h2, hour % 2);
  4.   hour = hour / 2;
  5.   digitalWrite(h4, hour % 2);
  6.   ...

Vagy mondjuk bitshift, vagy logikai operátorok, de semmiképp se úgy hogy 12 if az órához és 60 if a perchez
(#) FDAssasin válasza tbarath hozzászólására (») Márc 7, 2017 /
 
Ez nagyon jó ötlet, köszi!
Akkor már csak az idővisszaállást kellene valahogy megoldanom...
(#) tbarath válasza FDAssasin hozzászólására (») Márc 7, 2017 /
 
Tipp1: ki kellene olvasnod minden regisztert
Tipp2: a displayTime() fv-ben a 3 változó deklarása és a readDS3231time meghívása közötti részt kommentezd ki a fenébe, lehet ott a hiba.
(#) kapu48 válasza FDAssasin hozzászólására (») Márc 8, 2017 /
 
Szerintem a display rutin igy jó:
  1. ...
  2.   // retrieve data from DS3231
  3.   readDS3231time(&second, &minute, &hour);
  4.   if (hour > 11) {
  5.     hour = hour - 12;
  6.     hourcheckbit++;
  7.   }  
  8.   // átrakod a bit értékeit a kimenetekre
  9.   digitalWrite(h1, bitRead(hour, 0));
  10.   digitalWrite(h2, bitRead(hour, 1));
  11.   digitalWrite(h4, bitRead(hour, 2));
  12.   digitalWrite(h8, bitRead(hour, 3));
  13.  
  14.   digitalWrite(m1, bitRead(minute, 0));
  15.   digitalWrite(m2, bitRead(minute, 1));
  16.   digitalWrite(m4, bitRead(minute, 2));
  17.   digitalWrite(m8, bitRead(minute, 3));
  18.   digitalWrite(m16, bitRead(minute, 4));
  19.   digitalWrite(m32, bitRead(minute, 5));
  20. }
  21. ...
(#) FDAssasin hozzászólása Márc 9, 2017 /
 
Uraim, köszönöm szépen! Működik a dolog, a beállító gomb szépen pörgeti az időt ha nyomom, kikapcsolásnál nem ugrik vissza az alapértékre. Végül ez lett a jó megoldás, ha érdekelne valakit:
  1. #include "Wire.h"
  2. #define DS3231_I2C_ADDRESS 0x68
  3. int buttonpin = 2;
  4. int buttonstate = 0;
  5. int h1 = 12;
  6. int h2 = 11;
  7. int h4 = 10;
  8. int h8 = 9;
  9. int m1 = 8;
  10. int m2 = 7;
  11. int m4 = 6;
  12. int m8 = 5;
  13. int m16 = 4;
  14. int m32 = 3;
  15. int hourkeep = 0;
  16. int minutekeep = 0;
  17. int hourcheckbit = 0;
  18. byte decToBcd(byte val)
  19. {
  20.   return( (val/10*16) + (val%10) );
  21. }
  22. byte bcdToDec(byte val)
  23. {
  24.   return( (val/16*10) + (val%16) );
  25. }
  26. void setup()
  27. {
  28.   Wire.begin();
  29.   pinMode(h1, OUTPUT);
  30.   pinMode(h2, OUTPUT);
  31.   pinMode(h4, OUTPUT);
  32.   pinMode(h8, OUTPUT);
  33.   pinMode(m1, OUTPUT);
  34.   pinMode(m2, OUTPUT);
  35.   pinMode(m4, OUTPUT);
  36.   pinMode(m8, OUTPUT);
  37.   pinMode(m16, OUTPUT);
  38.   pinMode(m32, OUTPUT);
  39.   pinMode(buttonpin, INPUT_PULLUP);
  40.   pinMode(13, OUTPUT);
  41.   digitalWrite(13, LOW);
  42.   ADCSRA = ADCSRA & B01111111;
  43.   ACSR = B10000000;
  44.   DIDR0 = DIDR0 | B00111111;
  45. }
  46. void readDS3231time(byte *second,
  47. byte *minute,
  48. byte *hour,
  49. byte *dayOfWeek,
  50. byte *dayOfMonth,
  51. byte *month,
  52. byte *year)
  53. {
  54.   Wire.beginTransmission(DS3231_I2C_ADDRESS);
  55.   Wire.write(0);
  56.   Wire.endTransmission();
  57.   Wire.requestFrom(DS3231_I2C_ADDRESS, 7);
  58.   *second = bcdToDec(Wire.read() & 0x7f);
  59.   *minute = bcdToDec(Wire.read());
  60.   *hour = bcdToDec(Wire.read() & 0x3f);
  61.   *dayOfWeek = bcdToDec(Wire.read());
  62.   *dayOfMonth = bcdToDec(Wire.read());
  63.   *month = bcdToDec(Wire.read());
  64.   *year = bcdToDec(Wire.read());
  65. }
  66. void displayTime()
  67. {
  68.   byte second, minute, hour, dayOfWeek, dayOfMonth, month, year;
  69.   readDS3231time(&second, &minute, &hour, &dayOfWeek, &dayOfMonth, &month,
  70.   &year);
  71.   if (hour > 11) {
  72.     hour = hour - 12;
  73.     hourcheckbit++;
  74.   }
  75.   hourkeep = hour;
  76.   minutekeep = minute;
  77.   digitalWrite(h1, hour % 2);
  78.   hour = hour / 2;
  79.   digitalWrite(h2, hour % 2);
  80.   hour = hour / 2;
  81.   digitalWrite(h4, hour % 2);
  82.   hour = hour / 2;
  83.   digitalWrite(h8, hour % 2);
  84.   hour = hourkeep;
  85.   digitalWrite(m1, minute % 2);
  86.   minute = minute / 2;
  87.   digitalWrite(m2, minute % 2);
  88.   minute = minute / 2;
  89.   digitalWrite(m4, minute % 2);
  90.   minute = minute / 2;
  91.   digitalWrite(m8, minute % 2);
  92.   minute = minute / 2;
  93.   digitalWrite(m16, minute % 2);
  94.   minute = minute / 2;
  95.   digitalWrite(m32, minute % 2);
  96.   minute = minutekeep;
  97.   if (hourcheckbit > 0) {
  98.     hour = hour + 12;
  99.     hourcheckbit = 0;
  100.   }
  101.   buttonstate = digitalRead(buttonpin);
  102.   if (buttonstate == LOW) {
  103.     minute++;
  104.     if (minute == 60) {
  105.       minute = 0;
  106.       hour++;
  107.     }
  108.     setDS3231time(second,minute,hour,dayOfWeek,dayOfMonth,month,year);
  109.   }
  110. }
  111. void loop()
  112. {
  113.   displayTime(); // display the real-time clock data on the Serial Monitor,
  114.   delay(1000); // every second
  115. }
  116. void setDS3231time(byte second, byte minute, byte hour, byte dayOfWeek, byte
  117. dayOfMonth, byte month, byte year)
  118. {
  119.   // sets time and date data to DS3231
  120.   Wire.beginTransmission(DS3231_I2C_ADDRESS);
  121.   Wire.write(0); // set next input to start at the seconds register
  122.   Wire.write(decToBcd(second)); // set seconds
  123.   Wire.write(decToBcd(minute)); // set minutes
  124.   Wire.write(decToBcd(hour)); // set hours
  125.   Wire.write(decToBcd(dayOfWeek)); // set day of week (1=Sunday, 7=Saturday)
  126.   Wire.write(decToBcd(dayOfMonth)); // set date (1 to 31)
  127.   Wire.write(decToBcd(month)); // set month
  128.   Wire.write(decToBcd(year)); // set year (0 to 99)
  129.   Wire.endTransmission();
  130. }


Viszont most is lenne egy gondom, remélem erre is tud valaki megoldást. Ez a program 4114 byte így ahogy most van. Ezt valahogy bele kéne erőltetnem egy ATmega48PA-ba. Ha jól tudom, ahhoz 4096 bytenak kéne lennie maximum. Hogy tudnám ezt megoldani anélkül, hogy újraírom az egészet assemblyben? Azzal is próbálkoztam, de nekem sajnos magas, ha pedig nem értem a kódot, esélytelen a debug, ha egyszer szükség lenne rá.
(#) kapu48 válasza FDAssasin hozzászólására (») Márc 9, 2017 /
 
Amit fentebb javasoltam vezérlést! Nem vált be, vagy nem is próbáltad?
Bővebben: Link
(#) FDAssasin válasza kapu48 hozzászólására (») Márc 9, 2017 /
 
Nem töltöttem fel. Az IDE hiba nélkül fordította, de kicsit nagyobb lesz a végeredmény byteok terén, mint a másik megoldásnál. Ezért használom inkább ezt, de mint látod, így sem férek el sajnos

-UPDATE-

Meglett a megoldás azt hiszem. Arduino IDE 1.8.1-el 3460 byte. Eredetileg 1.0.6-tal fordítottam. Ez hogy lehet? A kód egy az egyben ugyanaz, csak 1.8.1-el nyitottam meg. Működést gondolom ez nem befolyásol
A hozzászólás módosítva: Márc 9, 2017
Következő: »»   327 / 852
Bejelentkezés

Belépés

Hirdetés
XDT.hu
Az oldalon sütiket használunk a helyes működéshez. Bővebb információt az adatvédelmi szabályzatban olvashatsz. Megértettem