Obsah:
2025 Autor: John Day | [email protected]. Naposledy zmenené: 2025-01-23 15:05
Ahoj! Toto je projekt na výrobu kalkulačky s dotykovým displejom pomocou Arduino Uno a štítu TFT LCD. Prišiel som s konceptom pre svoju hodinu programovania v domácej škole a skúsenosti s budovaním tohto projektu boli veľmi zaujímavé. Táto kalkulačka dokáže štyri jednoduché matematické operácie (sčítanie, odčítanie, násobenie a delenie). Tiež zobrazuje až dve desatinné miesta pre odpovede na delenie, ktoré ich majú. Poďme sa ponoriť priamo dovnútra! Dodávky pre tento projekt sú uvedené nižšie.
Zásoby
- Arduino Uno
-2,4 TFT LCD štít (tu som ho kúpil:
- kábel USB A na B (kábel na pripojenie Arduina k počítaču)
- Počítač s nainštalovaným IDE Arduino
- Budete si tiež musieť stiahnuť dve knižnice: MCUFRIEND_kbv a dotykový displej. Prvý z nich nájdete na github (odkaz: https://github.com/prenticedavid/MCUFRIEND_kbv) alebo môžete použiť súbor zip knižnice, ktorý uvádzam nižšie. Druhý je na nainštalovanie v správcovi knižníc Arduino.
Krok 1: Pripojenie hardvéru
Pripojenie štítu dotykovej obrazovky k Arduino Uno je jednoduché a rýchle. Stačí zoradiť najnižšie piny na štíte s najnižšími vývodmi na Arduine a štít zasunúť do čapov. Horný kolík 5 V a neoznačený kolík na strane napájania by nemali mať v sebe kolíky zo štítu, pričom rovnaké parametre platia pre kolíky označené SCL a SDA na druhej strane dosky. Teraz sme pripravení kódovať!
Krok 2: Kód: Globálne definície a nastavenie
#zahrnúť
MCUFRIEND_kbv tft; // každopádne pevne zapojené pre štíty UNO
#zahrnúť
#definovať YP A3
#definovať XM A2
#definovať YM 9
#define XP 8
TouchScreen ts = TouchScreen (XP, YP, XM, YM, 300);
#definovať MINPRESSURE 10
Toto je začiatok kódu, kde zahrnujeme knižnice (MCUFRIEND_kbv a dotyková obrazovka), definujeme piny X a Y, nastavujeme parametre dotykovej obrazovky a definujeme minimálny tlak potrebný na to, aby Arduino zaregistroval užívateľský lis.
int ID;
int user_selection;
float save_number = 0;
float term1;
int op_num;
plavákový výsledok;
int kurzorLocX = 5;
int kurzorLocY = 20;
Tesne pred nastavením musíme nastaviť niekoľko globálnych premenných. ID pomáha pri uvádzaní dotykovej obrazovky do prevádzky. user_selection obsahuje číslo, ktoré zodpovedá kľúču, ktorý používateľ zvolí pri stlačení dotykového displeja. uložené_číslo je premenná, ktorú vytlačíme na obrazovku po zadaní používateľa (viac o tom v slučke). Je to float, takže môže obsahovať desatinné čísla aj celé čísla. term1 je premenná, do ktorej je uložené prvé číslo rovnice po výbere operandu. op_num uloží operand ako číslo (1 na sčítanie, 2 na odčítanie, 3 na násobenie a 4 na delenie). Výsledkom je premenná, ktorá sa vytlačí na obrazovku potom, čo používateľ stlačí znamienko rovnosti. Je to tiež plavák. cursorLocX a cursorLocY sú body mapovania na dotykovej obrazovke, na ktorých je kurzor nastavený viackrát (nachádza sa v sivom pruhu v hornej časti, inak známy ako pole s výsledkami).
neplatné nastavenie () {
tft.reset ();
ID = tft.readID ();
tft.begin (ID);
tft.setRotation (0);
tft.fillScreen (TFT_DARKGREY);
štvorce ();
čísla ();
tft.setTextSize (3);
tft.setTextColor (TFT_BLUE, TFT_DARKGREY);
}
Naša funkcia nastavenia najskôr obsahuje inicializáciu štítu dotykovej obrazovky (riadky 1-3). Orientácia štítu sa nastavuje pomocou príkazu tft.setRotation (), pričom 0 je vzpriamený. Celá obrazovka je zafarbená na tmavosivú s príkazom tft.fillScreen (), ktorý napíšeme cez hornú časť (okrem poľa s výsledkami). Funkcie štvorcov () a číslic () nakreslia štvorce kalkulačky, štvorce vyfarbia čiernobielo a dajú šachovnicovým vzorom číslice/operandy na štvorce modrou farbou. K tým sa dostaneme v nasledujúcom kroku. Príkaz tft.setTextSize () nastaví veľkosť textu poľa s výsledkami na 3, čo je stredné písmo. Príkaz tft.setTextColor () nastaví farbu textu poľa s výsledkami na modrú, ktorá je zapísaná cez tmavosivé pole.
Krok 3: Kód: Slučka
void loop () {numberSelect ();
oneskorenie (100);
if (user_selection == 16) {
;
} else {
if (user_selection <10) {
uložené_číslo = uložené_číslo * 10 + výber používateľa;
tft.setCursor (cursorLocX, cursorLocY);
tft.print (uložené_číslo);
} else if (user_selection> 10) {
prepínač (výber používateľa) {
prípad 11:
op_num = 1;
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("+");
term1 = uložené_číslo;
uložené_číslo = 0;
prestávka;
prípad 12:
op_num = 2;
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("-");
term1 = uložené_číslo;
uložené_číslo = 0;
prestávka;
prípad 13:
op_num = 3;
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("X");
term1 = uložené_číslo;
uložené_číslo = 0;
prestávka;
prípad 14:
op_num = 4;
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("/");
term1 = uložené_číslo;
uložené_číslo = 0;
prestávka;
prípad 15:
uložené_číslo = 0;
termín1 = 0;
op_num = 0;
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("");
prestávka;
}
tft.setCursor (cursorLocX, cursorLocY);
Toto je veľa na žuvanie, takže vysvetlím, čo je vyššie. Začneme zavolaním funkcie numberSelect (), ktorá každému štvorcu na dotykovej obrazovke priradí číslo. Keď používateľ stlačí jeden z týchto štvorcov, funkcia nastaví premennú user_selection na číslo tohto štvorca. Prvý príkaz if má prejsť cyklom iba vtedy, ak bol vykonaný platný výber používateľa. Ak je, nasledujúci príkaz if sa pýta, či má user_selection v sebe uložené číslo menšie ako 10 (čísla 0-9). Ak áno, uložené_číslo sa vynásobí 10 a číslo vo výbere používateľa sa pridá k uloženému_číslu, ktoré sa vytlačí v poli s výsledkami na dotykovej obrazovke. Ak nie, nasledujúci príkaz if sa pýta, či má user_selection v sebe uložené číslo väčšie ako 10 (čísla operandov: 11 pre +, 12 pre -, 13 pre X, 14 pre /a 15 pre čistý štvorec obrazovky). O každý prípad (určený výberom užívateľa) sa stará funkcia prepínača. Premennej op_num je priradené číslo, ktoré zodpovedá operandu, ktorý bol vybratý (1 pre +, 2 pre -, 3 pre X a 4 pre /). Hodnota v uloženom_čísle sa uloží do premennej term1, aby sa premennú uloženého_čísla dalo použiť pre druhú polovicu rovnice. Symbol operandu sa vytlačí na obrazovku spolu s vymazaním akýchkoľvek čísel v poli s výsledkami. Jedinou výnimkou je jasný štvorec obrazovky, ktorý vynuluje všetky výpočtové premenné a vymaže pole s výsledkami čohokoľvek na ňom.
} else {
prepínač (op_num) {
prípad 1:
výsledok = termín1 + uložené_číslo;
tft.setCursor (cursorLocX, cursorLocY);
tft.print (dvojnásobok (výsledok));
prestávka;
prípad 2:
výsledok = termín1 - uložené_číslo;
tft.setCursor (cursorLocX, cursorLocY);
tft.print (dvojnásobok (výsledok));
prestávka;
prípad 3:
výsledok = termín1 * uložené_číslo;
tft.setCursor (cursorLocX, cursorLocY);
tft.print (dvojnásobok (výsledok));
prestávka;
prípad 4:
výsledok = float (termín1) / float (uložené_číslo);
tft.setCursor (cursorLocX, cursorLocY);
tft.print (výsledok);
prestávka;
}
tft.setCursor (cursorLocX, cursorLocY);
uložené_číslo = výsledok;
termín1 = 0;
op_num = 0;
oneskorenie (1000);
}
}
}
Posledná časť cyklu sa zaoberá udalosťou, keď používateľ vyberie znamienko rovnosti (user_selection == 10). Ďalšia prepínacia funkcia funguje cez štyri matematické funkcie (určené op_num). Sčítávací prípad (prípad 1) sčíta term1 a uložené_číslo a uloží číslo do výslednej premennej. Výsledok sa vytlačí do poľa výsledkov ako dvojnásobok. Odčítanie prípadu (prípad 2) odčíta uložené_číslo od výrazu1 a číslo uloží do premennej výsledku. Výsledok sa vytlačí do poľa s výsledkami ako dvojnásobok. Prípad násobenia (prípad 3) vynásobí výraz1 uloženým číslom a číslo uloží do výslednej premennej. Výsledok sa vytlačí do poľa s výsledkami ako dvojnásobok. Rozdelenie (prípad 4) vydelí výraz1 výrazom uložené_číslo dohromady a číslo uloží do premennej výsledku. Výsledok sa vytlačí do poľa s výsledkami ako float (pretože odpovede na delenie môžu byť desatinné čísla). Po vytlačení čísla, operandu alebo výsledku na obrazovku sa kurzor resetuje, uložené_číslo sa nastaví na predchádzajúci výsledok a term1 a op_num sa vynulujú.
Niekoľko poznámok: používateľ nemôže do kalkulačky zadávať desatinné čísla kvôli nedostatku štvorca s desatinnou čiarkou. Užívateľ môže tiež urobiť iba jednu rovnicu súčasne. Výsledok nemôžete vypočítať a potom tento výsledok sčítať/odčítať/násobiť/deliť. Vo funkcii numberSelect () je funkcia, ktorá po vytlačení výsledku vyčistí obrazovku, ak používateľ stlačil iný štvorec.
Krok 4: Kód: Funkcia štvorcov
prázdne štvorce () {
// čiernobiele štvorce sa striedajú v každom riadku a prvý a tretí riadok majú opačný vzor ako druhý a štvrtý riadok
tft.fillRect (0, 60, 60, 65, TFT_BLACK); // začína prvý riadok štvorcov, čierny až biely tft.fillRect (60, 60, 60, 65, TFT_WHITE);
tft.fillRect (120, 60, 60, 65, TFT_BLACK);
tft.fillRect (180, 60, 60, 65, TFT_WHITE); // končí prvý riadok štvorcov
tft.fillRect (0, 125, 60, 65, TFT_WHITE); // druhý riadok štvorcov sa začína, biely až čierny tft.fillRect (60, 125, 60, 65, TFT_BLACK);
tft.fillRect (120, 125, 60, 65, TFT_WHITE);
tft.fillRect (180, 125, 60, 65, TFT_BLACK); // končí druhý rad štvorcov
tft.fillRect (0, 190, 60, 65, TFT_BLACK); // tretí rad štvorcov začína, čiernobielo tft.fillRect (60, 190, 60, 65, TFT_WHITE);
tft.fillRect (120, 190, 60, 65, TFT_BLACK);
tft.fillRect (180, 190, 60, 65, TFT_WHITE); // tretí rad štvorcov končí
tft.fillRect (0, 255, 60, 65, TFT_WHITE); // štvrtý riadok štvorcov sa začína, biely až čierny tft.fillRect (60, 255, 60, 65, TFT_BLACK);
tft.fillRect (120, 255, 60, 65, TFT_WHITE);
tft.fillRect (180, 255, 60, 65, TFT_BLACK); // končí štvrtý rad štvorcov
}
Funkcia square () je veľmi jednoduchá. Príkaz tft.fillRect (X1, Y1, X2, Y2, TFT_COLOR) nakreslí obdĺžnik podľa parametrov, ktoré mu boli odovzdané, ktorými sú prvé polohy x a y, druhé polohy x a y a farba, ktorou je obdĺžnik vyplnený.. Táto funkcia nakreslí všetky štyri rady štvorcov (technicky obdĺžnikov) a vyplní každé políčko druhou farbou.
Krok 5: Funkcia Code: Numbers
neplatné čísla () {
tft.setTextColor (TFT_BLUE); // nastaví farbu čísla/znaku na modrú
tft.setTextSize (5); // nastaví číslo/veľkosť znaku na 5
tft.setCursor (18, 75); // nastaví kurzor na prvý riadok číslic/znakov
tft.print ("7 8 9 /"); // vytlačí prvý riadok číslic/znakov
tft.setCursor (18, 140); // nastaví kurzor na druhý riadok číslic/znakov
tft.print ("4 5 6 X"); // vytlačí druhý riadok čísel/znakov
tft.setCursor (18, 205); // nastaví kurzor na tretí riadok číslic/znakov
tft.print ("1 2 3 -"); // vytlačí tretí riadok číslic/znakov
tft.setCursor (18, 270); // nastaví kurzor na štvrtý riadok číslic/znakov
tft.print ("C 0 = +"); // vytlačí štvrtý riadok číslic/znakov
}
Funkcia number () je tiež jednoduchá. Prvé dva riadky nastavia väčšiu veľkosť textu a farbu na modrú. Príkaz tft.setCursor () nastaví kurzor na pozíciu v každom riadku, od ktorého začína písanie čísel. Potom príkaz tft.print () vytlačí čísla/znaky na štvorce.
Krok 6: Funkcia Code: NumberSelect
zrušiť číslo Vybrať () {
TSPoint p = ts.getPoint ();
pinMode (XM, VÝSTUP);
pinMode (YP, OUTPUT);
ak (p.z> MINISTRUK) {
p.x = mapa (s.x, 250, 845, 0, 239);
p.y = mapa (p.y, 245, 860, 0, 319);
if (result! = 0) {
výsledok = 0;
uložené_číslo = 0;
tft.print ("JASNÉ HODNOTY");
oneskorenie (500);
tft.setCursor (cursorLocX, cursorLocY);
tft.print ("");
tft.setCursor (cursorLocX, cursorLocY);
}
Na začiatku funkcie numberSelect () požiadame používateľa o zadanie z dotykovej obrazovky príkazom ts.getPoint (). Po zhromaždení týchto údajov skontrolujeme, či nebol prekročený minimálny tlak (alebo inými slovami, či používateľ niekde stlačil dotykový displej). Ak je, súradnice x a y sú mapované z karteziánskych súradníc na súradnice špecifické pre dotykový displej. (0, 0) je ľavý horný roh dotykovej obrazovky, pričom os x smeruje naprieč a os y smeruje nadol. V ďalšej časti sa kontroluje, či je vo výsledku uložené číslo. Ak existuje, výsledok a uložené_číslo sa resetujú na 0. Nad poľom s výsledkami sa vytlačí správa „VYMAZAŤ HODNOTY“a obrazovka sa vyčistí s kurzorom späť do východiskovej polohy.
if (str.y 60) {// prvý rad štvorcov
ak (str.x <60)
user_selection = 7;
inak ak (s.x <120)
user_selection = 8;
inak ak (str.x <180)
user_selection = 9;
else user_selection = 14;
} else if (str. 125) {// druhý rad štvorcov
ak (str.x <60)
user_selection = 4;
inak ak (s.x <120)
user_selection = 5;
inak ak (str.x <180)
user_selection = 6;
else user_selection = 13;
} else if (str. 190) {// tretí rad štvorcov
ak (str.x <60)
user_selection = 1;
inak ak (s.x <120)
user_selection = 2;
inak ak (str.x <180)
user_selection = 3;
else user_selection = 12;
} else if (str.y> 255) {// štvrtý rad štvorcov
ak (s.x <60)
user_selection = 15;
inak ak (s.x <120)
user_selection = 0;
inak ak (str.x <180)
user_selection = 10;
else user_selection = 11;
}
} else {
user_selection = 16; // user_selection je nastavený na 16 (nič premenné)
}
}
Toto je časť, ktorá určuje, ktoré tlačidlo bolo vybraté. Počnúc horným radom štvorcov a končiacim spodným radom Arduino hľadá, kde bola obrazovka v skutočnosti stlačená. Potom štvorcu priradí číslo a toto číslo uloží do výberu používateľa. Čísla 0-9 zodpovedajú štvorcom s číslami, čísla 11-15 zodpovedajú operandovým štvorcom a voľnému štvorcu a číslo 10 zodpovedá štvorcu so znamienkom rovnosti. Ak nebol vybratý žiadny štvorec, potom je user_selection nastavený na 16, čím sa slučka začne znova (pozri funkciu slučky).
Krok 7: Užite si svoj dokončený projekt
Tu to máte! Teraz máte k dispozícii kalkulačku s dotykovým displejom, ktorá dokáže sčítať, odčítať, násobiť a deliť. Tento projekt zmenil celý spôsob, akým som si myslel, že kalkulačka funguje. Keď som pracoval na tomto projekte, pamätám si, ako som svojmu učiteľovi na hodine povedal: „Už sa nikdy nebudem pozerať na kalkulačku rovnako!“Funkcie, o ktorých si ako používateľ myslíte, že sú jednoduché, sú trochu náročné, keď sa pokúšate napodobniť svoj nápad za počítačom. Dúfam, že sa vám projekt páčil, a dúfam, že sa zmenilo aj vaše myslenie na to, ako kalkulačka funguje!
Tu je celý kód pre vaše pohodlie. Je plná komentárov, takže ak máte nejaké problémy, mali by vám ukázať, čo jednotlivé riadky robia.
Odporúča:
Otočenie displeja a dotykovej obrazovky Raspberry Pi: 4 kroky
Otočenie displeja a dotykovej obrazovky Raspberry Pi: Toto je základný návod, ktorý vám ukáže, ako otočiť vstup displeja a dotykovej obrazovky pre akékoľvek zariadenie Raspberry Pi s operačným systémom Buster Raspbian, ale túto metódu používam už od Jessie. Obrázky použité v tomto sú z Raspberry Pi
Tlačidlá Gameboy na dotykovej obrazovke !: 10 krokov
Tlačidlá Gameboy na dotykovej obrazovke!: Odkedy som bol malý chlapec, chcel som gameboy. Rýchlo dopredu niekoľko rokov, stále nemám herného chlapca, rozhodol som sa stiahnuť emulátor. Ale …. virtuálne tlačidlá necítite! Preto som sa rozhodol, že tlačidlá, ktoré môžem umiestniť na obrazovku, sa budú prekrývať
Kalkulačka Arduino s LED výstupom: 5 krokov
Kalkulačka Arduino s LED výstupom: Hej, chlapci! Chcete sa naučiť používať vstup a výstup sériového monitora. Tak tu máte perfektný návod, ako na to! V tomto návode vás prevediem jednoduchými krokmi potrebnými na vytvorenie kalkulačky pomocou sériového meracieho zariadenia Arduino
Dverový zámok dotykovej obrazovky Arduino TFT: 5 krokov
Dverový zámok dotykovej obrazovky Arduino TFT: Toto je môj prvý pokyn. Tento projekt používa Arduino a 2,8 " Dotyková obrazovka TFT s náčrtom hesla na aktiváciu relé, ktoré rozpojí obvod k dverám mag lock. V pozadí sa zámok RFID na dverách pri práci zlomil, a nie znova zapojil
Čistenie hliníkovej klávesnice Apple . alebo akejkoľvek inej dotykovej klávesnice: 5 krokov
Čistenie hliníkovej klávesnice Apple …. alebo akejkoľvek inej klávesnice s dotykovým ovládaním: Tak čisté, ako by ste sa my alebo ja mohli snažiť udržať naše hliníkové klávesnice Apple, budú zhruba po roku špinavé. Tento návod vám pomôže s jeho vyčistením. Buďte opatrní, pretože nie som zodpovedný za to, že sa vám pri tom pokazí klávesnica …. SUCKS F