LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Arduino IV.

V tomto díle si ukážeme řešení úkolu z minulého dílu, poté se vrátíme k pásu LED diod, na němž si ukážeme funkci 4-bitového dekodéru BCD kódu na 1 z 16 a funkci Map. Také si ukážeme logickou funkci If.

12.1.2012 00:00 | Zbyšek Voda | Články autora | přečteno 18509×

V minulém díle jsme si řekli něco o proměnných a cyklech. Ukázali sme si, jak funguje sériová komunikace a naučili jsme se číst analogová a digitální data. Nakonec jsme vyzkoušeli, jak funguje PWM.


Řešení úkolů

Úkol 1.


int cekej = 10; //kolik milisekund bude program čekat mezi jednotlivými kroky

void setup() {
  pinMode(12, OUTPUT);  //pin 12 nastaven jako výstupní
  Serial.begin(9600); //začátek sériové komunikace
}
void loop() {
  //tento cyklus rozsvěcuje LED
  for(int jas=0; jas < 255; jas++){    
    analogWrite(12, jas);
    Serial.println(jas);
    delay(cekej);
  }
  //tento ji zhasíná
  for(int jas=255; jas > 0; jas--){
    analogWrite(12, jas);
    Serial.println(jas);
    delay(cekej);
  }  
  //oba dva cykly posílají data o jasu led diody přes sériovou linku
}

Úkol 2.

void setup() {
  pinMode(12, OUTPUT);  //pin 12 nastaven jako výstupní
  Serial.begin(9600); //začátek sériové komunikace
}
void loop() {
  int jas = analogRead(A0) / 4; //čte hodnotu na potenciometru
  /*důvod,proč je hodnota vydělena 4 je jednoduchý
    funkce analogRead pracuje s 1024 hodnotami (0 - 1023), 
    kdežto analogWrite pouze s 256 hodnotami (0 - 255)
    1024 je čtyřnásobek čísla 256, proto pro úpravu na správnou hodnotu dělíme čtyřmi*/
  analogWrite(12, jas);
}

Pás z 10 LED

Vytvoříme si hada, jako v minulém díle, ale z 10 LED. Na něm si ukážeme užitečné funkce. Takto může vypadat kód, který postupně rozsvětsuje a zhasíná diody. Je to upravený kód z minulého dílu.


int cekej= 250;
int LED[10] = {12,11,10,9,8,7,6,5,4,3};


void setup() {                
  for (int x=0; x< 10; x++) { 
     pinMode(LED[x], OUTPUT);
  }     
}
void loop() {  
  for (int y=0; y< 10; y++) { 
  digitalWrite(LED[y], LOW);     
  delay(cekej);              
  }
  
  for (int z=0; z< 10; z++) { 
  digitalWrite(LED[z], HIGH);     
  delay(cekej);              
  }  
}  

Funkce Map

Tato funkce se používá, když chceme převést data nabývající rozsahu například 0-1023 na data 0-255 tak, aby procentuální podíl zůstal zachován. Následujícím příkladem můžeme nahradit dělení čtyřmi v úkolu 2. Pokud váháte, zda použít raději dělení, nebo funkci map, je to jen na vás. Při použití map je výsledek "elegantnějsí a čistčí". Na funkčnosti projektu se ale nic nemění. Při použití dělení by problém nastal, kdyby vstupní a výstupní rozsah byli nesoudělná čísla. Syntaxe je následovná:


  int jas1 = analogRead(A0);
  int jas2 = map(jas1, 0, 1023, 0, 255);
  //z rozsahu 0-1023 jsme přemapovali proměnnou jas1 na 0-255
  analogWrite(12, jas);

Podmínka IF

Do češtiny překládáme jako KDYŽ. Je to běžná funkce ve většině "vyšších" programovacích jazyků. Než se pustíme do podmínek, ukážeme si porovnávací operátory, které se v podmínkách vyskytují.

== - rovná se
!= - nerovná se
<  - menší než
>  - větší než
<= - menší nebo rovno
>= - větší nebo rovno

&& - logické a (AND) - výsledek je logická 1, když jsou oba výroky pravdivé
|| - logické nebo (OR) - výsledek je logická 1, když je alespoň jeden výrok pravdivý 
!  - logická negace (NOT) - když je výrok pravdivý, po znegování je nepravdivý a naopak

Zápis podmínky vypadá takto.


 if(podmínka 1){ 
     //co se stane, když je splněna podmínka 
   } 
 else if(podmínka 2) { 
     //co se stane když je splněna 2 podmínka
     //tato část je nepovinná, může zde být libovolně mnohokrát 
   }    
 else { 
     //co se stane, když není splněna ani jedna podmínka
     //tato část je také nepovinná
   }    
   
příklad: 
   if(abc < 0){ 
     //když je proměnná abc menší než nula proběhne kód zde
   }  
   else if(abc == 0){ 
     //když je proměnná abc rovna kód zde
   } 
   else if((abc > 10) && (abc < 20)){ 
     //když je proměnná abc mezi 10 a 20 proběhne kód zde
   }  
   else{ 
     //když je proměnná abc větší než nula proběhne kód zde
   }  


4-bitový dekodér BCD kódu 1 z 16

Co to vlastně je? 4 bitový znamená, že dekodér pracuje se 4 bitovou vstupní informací. Jednoduše řečeno, má čtyři vstupní piny. Kombinací jedniček a nul na těchto vstupech se dá docílit nastavení logické 1 na jednom z 16 výstupů. BCD kód znamená binary coded decimal, neboli binárně zakódovaná číslice v desítkové soustavě. Převodní tabulky z BCD na desítkovou soustavu můžete najít ve spoustě zdrojů na internetu. Zapojení je pak jednoduché. Na internetu si najděte datasheet (popis) vašeho dekodéru a připojte napájení podle popisu v něm. Propojte vstupy dekodéru s Arduinem a na každý každý z výstupů dekodéru připojte LED diodu. Vše následující popíšu v kódu.

  int piny[4]={12,11,10,9}; //na těcto pinech je dekodér připojen
  //nastavíme, jaká kombinace je potřebná k rozsvícení každé LED
  int led[16][4]={{0,0,0,0},    //pod indexem 0 je uložena 
                  {1,0,0,0},    //kombinace 0,0,0,0 - bude svítit 1. LED 
                  {0,1,0,0},
                  {1,1,0,0},  
                  {0,0,1,0},
                  {1,0,1,0},
                  {0,1,1,0},
                  {1,1,1,0},
                  {0,0,0,1},
                  {1,0,0,1},
                  {0,1,0,1},
                  {1,1,0,1},
                  {0,0,1,1},
                  {1,0,1,1},
                  {0,1,1,1},
                  {1,1,1,1}};  
    int cislo = 10; //jakou led chceme zobrazit

void setup() {
  for(int x=0; x<4 ; x++){
     pinMode(piny[x],OUTPUT); 
  }
}

void loop() {
  for(int x=0; x<4 ; x++){
    digitalWrite(piny[x],led[cislo][x]);
  } 
}

Úkoly

Pro procvičení mám pro Vás dva úkoly.

  1. Pomocí potenciometru vyberte 1 z 16 LED (nápověda - 1. možnost: funkce Map 2. možnost: IF + For)
  2. Přidejte k prvnímu úkolu jeden potenciometr, kterým regulujte jas LED.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

16.7.2018 1:05 /František Kučera

Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.


Přidat komentář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

14.5.2018 7:28 /František Kučera
Květnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 17. 5. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: Audio – zvuk v GNU/Linuxu.
Přidat komentář

7.5.2018 16:20 /František Kučera
Na stránkách spolku OpenAlt vyšla fotoreportáž Pražské srazy 2017 dokumentující srazy za uplynulý rok. Květnový pražský sraz na téma audio se bude konat 17. 5. 2018 (místo a čas ještě upřesníme).
Přidat komentář

17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář

16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

16.1.2018 1:08 / Ivan Pittner
verejna ip od o2 ubuntu

15.1.2018 17:26 / Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?

30.12.2017 20:16 / Michal Knoll
odmocnina

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2018) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze