Close

krokodile

Vytvořené odpovědi

Aktuálně je na stránce zobrazeno 30 příspěvků - 2,281. až 2,310. (celkem z 2,768)
  • Autor
    Příspěvky
  • odpověď na: 3.6 TFT TouchScreen MCUFRIEND na MEGA #6029
    posjirka
    Účastník

    Tady je otázka kde je problém. Opravdu zvláštní je, že to FAKT MUSÍM PSÁT V KAŽDÉM DOTAZU. BEZ KODU TI NIKDO NEPOMŮŽE.
    To že ti problikává barva nemusí být ovladači. Pokud si rozběhl paint tak ovladače jsou v pořádku. Spší když máš knihovnu nastavenou defaultně pro Arduino MEGA tak ho musíš upravit pro UNO, protože pravděpodobně bude používat ty pinu navíc co jsou v 2 řadém kontektoru napravo. Proto se nemusí nastavovat jaký pin co dělá. Pravděpodobně sisi popletl čísla analogových vstupů. Proto ti nejde kalibrace.
    S tím blikáním si myslím, že jsi dal do smyčky LOOP neustálé překreslování LCD a proto ti pod vrchní barvou problikává pozadí.

    Jak jsem psal na začátku … BEZ KODU TO NEJDE.

    odpověď na: DS18B20 #6012
    posjirka
    Účastník

    omlouvat se nemusíš, jsme jen lidi. Na nefunkčnost můžeme zkusit tradiční postup:
    1, překotroluj zapojení, případně rozeber a znovu postav (studeňáky, vypadlý drát,..)
    2, vyzkoušej jednoduchý program, který ti LED diodou bude signalizovat jaký je stav na tom pinu

    // kontrola stavu pinu
    // by JP 2016
    // na vystup s LED diodou zapisuje stav z kontrolovaného pinu
     
    int kontrolovanyPin = 8; // sem dej 49slo pinu, ktery potřebuješ ověřit 
    int LED = 13; // pin s LED diodou - pou6ij tu na desce
    
    void setup() {
    pinMode(kontrolovanyPin, INPUT); // nastaven9 pinu najako vstup
      pinMode(LED, OUTPUT); // nasteven9 pinu 13 na vystup - LED dioda na desce 
    }
    
    void loop() {
      digitalWrite(LED, digitalRead(kontrolovanyPin)); // zapis na pins S LED diodaou stav kontrolovaneho vstupu
    }

    3, zlus jiné čidlo nebo jiný pin (jedno je možná špatné)

    odpověď na: DS18B20 #6011
    Jindra413
    Účastník

    Omlouvám se za dezinformaci. Udělal jsem to přesně jak píšeš. Ale když to chci opět zprovoznit, tak to stále píše nuly. Ikdyž odpojím čidlo a odpor nechám zapojený.

    odpověď na: DS18B20 #6010
    posjirka
    Účastník

    chlape obávám se , že tvuj popis nené až tak úplný. Ty jsi totoiž neodpojil pin z DS18B20, ale opojil si zároveň i Pull-up odpor že? To ti totiž udělá přesně to co popisuješ. Celá věda s vyhodonocením chyby na DS18B20 je ta že, když odpojiž pin Arduina od všeho vypíše ti 0,00 st.C. je to proto, že mu nepřijde ani 1 bit log.1.
    kaž připojíš čidlo správně máš tam pemanentně log.1 a čidlo přes otevřený kolektor přizemńuje celou linku (log.0) počet log.0/log.1 ti vlastně dává výslednou teplotu. To je vpříkald kladných teplot. Záporné teploty fungují tak, že čidlo zvládne max. 126 st.C a cokoliv je nad je vlastně záporná teplota. Takže data 130 st.C = skutečně -4st.C. To vše končí v -127stC což je úplně mimo roszah čidla (max. -50st.C) a to je vlastně ona hláška „Error“. Když necháš pull-up odpor připojený bez čidla, dostane arduino samé log.1 takže b11111111 což v překladu do dec.soustavy = 255 a při převodu do zápodných hodnot = -127st.C.

    To jsem se rozepsal. No ve výsledku: odpoji čidlo ale pull-up odpor tam nech a vše bude v pořádku.

    odpověď na: DS18B20 #6007
    Jindra413
    Účastník

    Nic se mi na sériovou linku nevypíše.

    Pro vypisování na sériovou linku jsem používal toto:

    #include <OneWire.h>

    // OneWire DS18S20, DS18B20, DS1822 Temperature Example
    //
    // http://www.pjrc.com/teensy/td_libs_OneWire.html
    //
    // The DallasTemperature library can do all this work for you!
    // http://milesburton.com/Dallas_Temperature_Control_Library

    OneWire ds(10); // on pin 10 (a 4.7K resistor is necessary)

    void setup(void) {
    Serial.begin(9600);
    }

    void loop(void) {
    byte i;
    byte present = 0;
    byte type_s;
    byte data[12];
    byte addr[8];
    float celsius, fahrenheit;

    if ( !ds.search(addr)) {
    Serial.println(„No more addresses.“);
    Serial.println();
    ds.reset_search();
    delay(250);
    return;
    }

    Serial.print(„ROM =“);
    for( i = 0; i < 8; i++) {
    Serial.write(‚ ‚);
    Serial.print(addr[i], HEX);
    }

    if (OneWire::crc8(addr, 7) != addr[7]) {
    Serial.println(„CRC is not valid!“);
    return;
    }
    Serial.println();

    // the first ROM byte indicates which chip
    switch (addr[0]) {
    case 0x10:
    Serial.println(“ Chip = DS18S20″); // or old DS1820
    type_s = 1;
    break;
    case 0x28:
    Serial.println(“ Chip = DS18B20″);
    type_s = 0;
    break;
    case 0x22:
    Serial.println(“ Chip = DS1822″);
    type_s = 0;
    break;
    default:
    Serial.println(„Device is not a DS18x20 family device.“);
    return;
    }

    ds.reset();
    ds.select(addr);
    ds.write(0x44, 1); // start conversion, with parasite power on at the end

    delay(1000); // maybe 750ms is enough, maybe not
    // we might do a ds.depower() here, but the reset will take care of it.

    present = ds.reset();
    ds.select(addr);
    ds.write(0xBE); // Read Scratchpad

    Serial.print(“ Data = „);
    Serial.print(present, HEX);
    Serial.print(“ „);
    for ( i = 0; i < 9; i++) { // we need 9 bytes
    data[i] = ds.read();
    Serial.print(data[i], HEX);
    Serial.print(“ „);
    }
    Serial.print(“ CRC=“);
    Serial.print(OneWire::crc8(data, 8), HEX);
    Serial.println();

    // Convert the data to actual temperature
    // because the result is a 16 bit signed integer, it should
    // be stored to an „int16_t“ type, which is always 16 bits
    // even when compiled on a 32 bit processor.
    int16_t raw = (data[1] << 8) | data[0];
    if (type_s) {
    raw = raw << 3; // 9 bit resolution default
    if (data[7] == 0x10) {
    // „count remain“ gives full 12 bit resolution
    raw = (raw & 0xFFF0) + 12 – data[6];
    }
    } else {
    byte cfg = (data[4] & 0x60);
    // at lower res, the low bits are undefined, so let’s zero them
    if (cfg == 0x00) raw = raw & ~7; // 9 bit resolution, 93.75 ms
    else if (cfg == 0x20) raw = raw & ~3; // 10 bit res, 187.5 ms
    else if (cfg == 0x40) raw = raw & ~1; // 11 bit res, 375 ms
    //// default is 12 bit resolution, 750 ms conversion time
    }
    celsius = (float)raw / 16.0;
    fahrenheit = celsius * 1.8 + 32.0;
    Serial.print(“ Temperature = „);
    Serial.print(celsius);
    Serial.print(“ Celsius, „);
    Serial.print(fahrenheit);
    Serial.println(“ Fahrenheit“);
    }

    odpověď na: DS18B20 #6006
    Zbyšek Voda
    Účastník

    A když pod
    lcd.print(tempC);
    přidáte
    Serial.println(tempC);

    Co se Vám po sériové lince vypíše?

    odpověď na: DS18B20 #6004
    Jindra413
    Účastník
    Attachments:
    odpověď na: DS18B20 #6003
    Jindra413
    Účastník

    Ten kód je převzatý, malinko upravený. Pokud to bude fungovat, měl by to být termostat, který bude zapínat či vypínat podle nastavené teploty.

    // This Arduino sketch reads DS18B20 „1-Wire“ digital
    // temperature sensors.
    // Tutorial:
    // http://www.hacktronics.com/Tutorials/arduino-1-wire-tutorial.html

    #include <OneWire.h>
    #include <DallasTemperature.h>
    #include <LiquidCrystal.h>

    LiquidCrystal lcd(12, 11, 5, 4, 3, 2);

    // Data wire is plugged into pin 8 on the Arduino
    #define ONE_WIRE_BUS 8

    // Setup a oneWire instance to communicate with any OneWire devices
    OneWire oneWire(ONE_WIRE_BUS);

    // Pass our oneWire reference to Dallas Temperature.
    DallasTemperature sensors(&oneWire);

    // Assign the addresses of your 1-Wire temp sensors.
    // See the tutorial on how to obtain these addresses:
    // http://www.hacktronics.com/Tutorials/arduino-1-wire-address-finder.html

    DeviceAddress Thermometer = { 0x28, 0xFF, 0xC9, 0x09, 0xA5, 0x15, 0x01, 0x84 };

    void setup(void)
    {
    // Start up the library
    sensors.begin();
    // set the resolution to 10 bit (good enough?)
    sensors.setResolution(Thermometer, 10);

    lcd.begin(16,2); // columns, rows. use 16,2 for a 16×2 LCD, etc.
    lcd.clear(); // start with a blank screen

    }

    void printTemperature(DeviceAddress deviceAddress)
    {
    float tempC = sensors.getTempC(deviceAddress);
    if (tempC == -127.00) {
    lcd.print(„Error“);
    } else {
    lcd.print(tempC);

    }
    }

    void loop(void)
    {

    sensors.requestTemperatures();
    lcd.setCursor(0,0);
    lcd.print(„Teplota: „);
    printTemperature(Thermometer);
    lcd.print(“ C“);

    int teplota = 23.00;

    if (sensors.getTempC(Thermometer)>= teplota)
    { digitalWrite(13, HIGH);
    }
    else
    { digitalWrite(13, LOW);
    }
    delay(5000);
    }

    odpověď na: DS18B20 #6002
    Zbyšek Voda
    Účastník

    Dobrý den, zkuste nám prosím pro jistotu poslat kód 🙂

    odpověď na: Práce s pamětí #5969
    posjirka
    Účastník

    1. obávám se , že takto ti nikdo nepomůže.
    Je zvláštní , že to musím psát v každém vlákně, ale BEZ KODU TO PROSTĚ NEJDE.
    dej sem kod a můžeme ti poradit jak třeba ušetřit pár bytů.
    Ani ti pak nemůžeme poradit co ti nefunguje když nevíme CO VLASTNĚ DĚLÁŠ.
    Ušetření místa v SRAM se dá obecně docílit tím, že např:
    – nahradíš neměnné promenné (číslo pinu ledky apod) za konstanty
    – né všechny proměnné budou tyu integer ale máme třeba boolean, byte atd.
    záměnnou integer za byte ušetříš 1 byte (samozřejmě pokud potřebuješ hodnoty 0-255).
    – použitím funkcí a metod nemusíš některé kusy programu opakovat.

    2.Výsledný kod v assembleru najdeš tak, že si nastavíš:
    File – Preferences – Show verbose output during zatrhneš compilation.
    Tím se ti bude vypisovat průběh kompilace. Když se podíváš do výpisu tak jsou tam soubory *.eep a *.elf to jsou ty co hledáš.

    odpověď na: Ukazatel zařazené rychlosti na motorku #5967
    posjirka
    Účastník

    Tady vidím problém … jak mu řeknu, že jdu ze „2“ na „3“ a né na „1“, když je to ten samý směr?

    N 2 4
    \ / \ / \
    1 3 5

    tak jednoduše to asi nepůjde. Napadají mě 2 varianty:
    1, je třeba ještě dodatečná informace o směru (3-tí kontakt)
    2, využít jiného způsobu třebas i nepřímého měření jako třeba měření otáček motoru vs otáčky kola a podel poměru +/- vypočítat jaký byl použit převod. Ovšem fungovalo by to pouze za jízdy. Nevím motory a převodovky jsou pro mě věcí neznámou. Jsem spíš na elektro…

    odpověď na: Ukazatel zařazené rychlosti na motorku #5966
    pepa48
    Účastník

    Ano chápete to dobře jen je tady malý problém.

    Jde to N –> dolů –> 1 –> nahoru 2 –> ….. nahoru –> 5 (a zpátky opačně)

    takže to není normální sčítání a odčítání nahoru a dolů..

    odpověď na: Ukazatel zařazené rychlosti na motorku #5955
    posjirka
    Účastník

    Takže jestli to chápu dobře:
    pojmenujemme si LED diody od „0“ kdy „0“ = N, „1“ = 1, … „5“ = 5
    Po startu se rozsvítí LED0 a níž to nepůjde
    tlačítky „+“ a „-“ chceš posouvat LED nahoru/dolu až po LED5.
    Ta bude poslední a dál to nepůjde.
    Chápu to dobře?

    Je třeba si ještě uvědomit, že reakce na stisk tlačítka nemusí být ta správná cesta.
    Na tlačítku jsou při stisku zákmity a může se stát, že při stisku může tlačítko „vygenerovat“ řadu impulzů.
    Řesší se to time-out-em, kdy po stisku mikročip nereaguje po nastavenou dobu a pak zase čeká.
    Je třeba citlivě a z rozmyslem nastavit pak tento čas, protože při rychlém přepnutí nebude reagovat.

    odpověď na: IMIM120618001 vstupni svorky #5937
    posjirka
    Účastník

    Předpokládám, že :
    G je GND neboli zem
    + je kladný potenciál napájecího napětí (v tomto případe asi 3,3V)
    S je zkratka pro signal.

    Stačilo by si vzít multimetr a bylo by jasno …

    odpověď na: Meteostanice #5926
    Leo
    Účastník

    Zdravím.
    Potřebovali bychom senzory s meteostanice WH1080 – WH1090 připojít přimo k arduinu.
    http://www.hadex.cz/t110-vnejsi-mechanicke-dily-k-meteo-wh1080-a-wh1090/
    Neřešíl to už někdo?
    Děkují.

    odpověď na: IMIM120618001 vstupni svorky #5918
    Zbyšek Voda
    Účastník

    Dobrý den, moc nerozumím vaší otázce. Zkuste ji prosím formulovat trochu jinak, děkuji.

    odpověď na: Které Arduino #5914
    barak
    Účastník
    odpověď na: Dotaz od začátečníka – podmínka if #5913
    barak
    Účastník

    Mozna od temy ale take podminka IF.
    Chtel jsem pouzit IF. Sledoval jsem hodnotu y AO a potom dal IF, ale zacyklovalo se, stale cetlo posledni hodnotu. Taj sem to vyresil nize. Da se to vyresit aby se necyklovalo

    const int lamdaSig = A0; // Analogový vstup je nastaven na pi A0 pre lambdu sondu
    int napatie = 0; // Proměná pro hodnotu přečtenou z A0
    int led2 = 2;
    int led3 = 3;
    int led12=12;
    const int sensorPin = A1;
    const float baseLineTemp = 20;
    int t;

    void setup() {
    // Nastaví rychlost komunika na sériovám portu na 9600 bps:
    Serial.begin(9600);
    pinMode(led2, OUTPUT);
    pinMode(led3, OUTPUT);
    pinMode(led12, OUTPUT);
    }

    void loop() {

    int sensorVal = analogRead(sensorPin);

    napatie = analogRead(lamdaSig); // přečte hodnotu z A0 z lambda sondy
    napatie = ((napatie * 500.0) / 0.1) / 1024; //vysledok v mV
    // aby jsme videli vysledek, hodnotu odešleme přes sériový port
    Serial.print(“ napatie = “ ); // zapiše text hodnota =
    Serial.println(napatie); // zapiše proměnou hodnotu/napatie

    float teplota = ((sensorVal*5000.0)/30) /1024;
    Serial.print(“ teplota = „);

    Serial.println(teplota);
    delay(1000); // čekej 1000ms

    t=constrain(teplota, 20, 200); //ked je teplota mensi ako nastavene tak vrati 25,
    Serial.print(„upravene = „);
    Serial.println(t);

    switch(t){
    case 20:
    digitalWrite(led12, HIGH); //blika ked nie je teplota
    delay(1000);
    digitalWrite(led12, LOW);
    digitalWrite(led3,HIGH); //teplota mensi nez pozadovana otvari sa klapka1
    break;

    default: //ked je teplota v roymeyi nastavene par contrain
    digitalWrite(led3, LOW); //zatvori klapku1
    if (napatie < 200) { //mensi tak otvara klapku
    digitalWrite(led2, HIGH);
    delay(500);
    digitalWrite(led2, LOW); //klapka sa otvara len urcity cas pak zatvori
    }

    if (napatie > 200) { //vetsi zatvara klapku
    digitalWrite(led2, LOW);
    }

    if (napatie > 500) { //vetsi zatvara klapku
    digitalWrite(led3, HIGH);
    delay(500);
    digitalWrite(led3, LOW); //cas delay otvorena klapka pak zatvori
    }
    if (napatie < 500) {
    digitalWrite(led3, LOW);
    }

    delay(1000); //nacha reagovat po delay pak nove meranie

    break;

    }

    odpověď na: Dotaz od začátečníka – podmínka if #5912
    m.myska
    Účastník

    Opravdu mi chodí v serial monitoru svítí 🙂 , ale to je asi fuk.
    Kde a jak tedy položit podmínku k výpisu, aby reagovala po stavu HIGH i LOW?
    Díky.

    odpověď na: Dotaz od začátečníka – podmínka if #5911
    edmond
    Účastník

    Osobně si myslím, že Vám chodí stále že nesvítí. 🙂

    Váš program pracuje následovně:

    napětí na pin 2
    3 sekundy se nic neděje
    vypnutí pinu 2
    3 sekundy se nic neděje
    pak se ptáte v jakém stavu je LED a ta je vždy v tomto stavu vypnuta

    odpověď na: Arduino, 433 mhz , servo #5907
    boss1986
    Účastník
    odpověď na: Arduino, 433 mhz , servo #5906
    boss1986
    Účastník

    Tak jsem narazil na kod co jde bez knihovny. Posílá text. Ale nevím jak tam dosadit kod serva s knihovnou ServoTimer1. Nejsem ještě tolik v tomto zkušený. Díky za rady..

    odpověď na: Arduino, 433 mhz , servo #5891
    posjirka
    Účastník

    ale jde to . pouze sdílejí stejný časovač TIMMER 0, použij pro servo knihovnu využívající TIMMER 1 : https://playground.arduino.cc/ComponentLib/Servotimer1
    Proč jsou tam 3 arduina je vcelku jasné. 1 vysílací, 1 přijímací a 1 pro řízení serva.
    Ono servo má tu vlastnost, že reaguje na šírku pulzu s frekvencí cca 50Hz, tj 20ms.
    Když po 433MHz pošleš informace o identifikaci, uhel 3 serv a ukončovací sekvenci tak ti to může klidně trvat 10ms. To už ti rozhodí funkci časovače pro ovládání serva.
    Jde so udělat, jen je třeba si v klidu rozmyslet funkci, načasování a nepoužívat na všechno knihovny …

    odpověď na: připojení 1F motoru 600W #5890
    posjirka
    Účastník

    to je určitě super přístup i řešení. Spínání pomocí arduina není až tak problém a jen si koupíš zásuvku spínanou na 433MHz (cca 150-200kč) + vysílač (cca 25-50kč) a pak použiješ knihovnu RC switch.
    https://github.com/sui77/rc-switch

    jednoduché, dá se s tím kouzlit ve stylu, měření výšky hladiny v jezírku, časové spínání (nebo přes internet) atd.

    Jestli se chceš pustit do něčeho co má smysl postupuj po malých krůčcích a postupně to skládej. Vždy si dej takový úkol na kterém víš co děláš nebo jak má dopadnout a pak zjistíš že je to vlastně vcelku jednouché …. nu hodně štěstí a bastlení zdar

    odpověď na: připojení 1F motoru 600W #5889
    zz2012
    Účastník

    Dík za tip. Právě i kvůli bezpečnosti jsem se ptal. Jedná se o čerpadlo = voda … a ač je vše opticky oddělené, nevím jestli se mi do toho chce. Možná to skončí obyčejnou „vratkou“ vody spínanou 12V ventilem místo regulace otáček.
    Dík.

    posjirka
    Účastník

    jak jsme psal před chvíli na jiném vlákně:
    doporučuji podívat se sem:
    http://www.instructables.com/id/Arduino-controlled-light-dimmer-The-circuit/?ALLSTEPS

    odpověď na: připojení 1F motoru 600W #5878
    posjirka
    Účastník

    Doporučuji podívat se sem:
    http://www.instructables.com/id/Arduino-controlled-light-dimmer-The-circuit/?ALLSTEPS

    Samotný princip a řešení složité není, ale bez elektro vzdělání bych se do toho nepouštěl. Nejde ani tak o tvurce jako spíš o děti nebo nezasvěcěné, kteří nevhodnou manipulaci mohou přijít i o život .

    Za sebe bych spíš amatérské řešení viděl jako max. spínání pomocí bezdrátových zásuvek na 433Mhz. Je to bezpečné a člověk nepříjde do styku ze sítovým napětím.

    odpověď na: PIR + SIM800L volání #5870
    Soci
    Účastník

    Po úpravě byla reakce stále stejná, tak jsem začal zkoušet přehazovat drátky a místo ledky jsem použil nějaký rezistor co jsem tu měl a konečně se pak objevila nějaká odezva:
    GSM Shield testing.
    ATT: OK
    RIC:
    ATT: OK
    RIC:
    ATT: OK
    RIC:
    ATT: OK
    RIC:
    ATT: OK
    RIC:

    Pak jsem zkoušel v čem byl problém. Nefungovalo to když jsem místo rezistoru vrátil ledku, ani když jsem přehodil zpátky RX na TX a TX na RX jak by to mělo být (v současnosti mám tedy TX → TX) a dokonce ani při vrácení #define _GSM_TXPIN_ 2 #define _GSM_RXPIN_ 3. Všechny tyto věci se tedy musely změnit aby nastala tato reakce. Stále to nevolá, ale rozhodně jsem o něco dál. Děkuji.

    odpověď na: PIR + SIM800L volání #5869
    Aleš
    Účastník

    Najdi knihovnu GSM.cpp
    V ní najdi řádky:
    #define _GSM_TXPIN_ 2
    #define _GSM_RXPIN_ 3
    změň je na:
    #define _GSM_TXPIN_ 11
    #define _GSM_RXPIN_ 10

    Ještě upřesním: signál RX na modulu GSM bude zapojen na pin11, signál TX na pin10. Sériový port se zapojuje RX na TX a TX na RX.

    Když to bude chodit, tak bych to celé upravil a předělal na HW sériový port RX1 a TX1.

    Místo LED bych tam dal 2 diody. Není to kvůli proudu, ale kvůli snížení napětí. Přes LED neprojde potřebný proud!

    odpověď na: PIR + SIM800L volání #5854
    Soci
    Účastník

    Po vložení se mi vymazali mezery, tak ještě pro přehlednost:

    Mega2560 → GSM
    5V → VCC /tady jsem zmírnil proud pomocí jedné Led diody
    PWM 10 → RX
    PWM 11 → TX
    GND → GND

    Mega2560 → PIR
    5V → VCC
    A0 → OUT
    GND → GND

Aktuálně je na stránce zobrazeno 30 příspěvků - 2,281. až 2,310. (celkem z 2,768)