.. note:: Ciao, benvenuto nella Community di appassionati di Raspberry Pi, Arduino e ESP32 di SunFounder su Facebook! Approfondisci le tue conoscenze su Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati. **Perché unirti a noi?** - **Supporto esperto**: Risolvi i problemi post-vendita e le sfide tecniche con l'aiuto della nostra community e del nostro team. - **Impara e condividi**: Scambia consigli e tutorial per migliorare le tue competenze. - **Anteprime esclusive**: Ottieni accesso anticipato ai nuovi annunci di prodotti e alle anteprime. - **Sconti speciali**: Godi di sconti esclusivi sui nostri prodotti più recenti. - **Promozioni festive e giveaway**: Partecipa a concorsi e promozioni durante le festività. 👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso! .. _2.1.3_js: 2.1.3 Modulo Interruttore a Tocco ==================================== Introduzione ---------------------- In questo progetto, imparerai a conoscere il modulo interruttore a tocco. Questo modulo può sostituire i tradizionali tipi di interruttore, offrendo vantaggi come: funzionamento conveniente, ottima sensibilità al tocco, controllo preciso e minima usura meccanica. Componenti necessari ------------------------ In questo progetto, abbiamo bisogno dei seguenti componenti. .. image:: ../img/2.1.3component.png :width: 700 :align: center È sicuramente conveniente acquistare un kit completo, ecco il link: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nome - OGGETTI IN QUESTO KIT - LINK * - Raphael Kit - 337 - |link_Raphael_kit| Puoi anche acquistarli separatamente dai link sottostanti. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUZIONE AI COMPONENTI - LINK PER L'ACQUISTO * - :ref:`cpn_gpio_extension_board` - |link_gpio_board_buy| * - :ref:`cpn_breadboard` - |link_breadboard_buy| * - :ref:`cpn_wires` - |link_wires_buy| * - :ref:`cpn_resistor` - |link_resistor_buy| * - :ref:`cpn_led` - |link_led_buy| * - :ref:`cpn_touch_switch` - |link_touch_buy| Schema elettrico -------------------- .. image:: ../img/2.1.3circuit.png :width: 500 :align: center Procedure sperimentali ------------------------- **Passo 1:** Costruisci il circuito. .. image:: ../img/2.1.3fritzing.png :width: 700 :align: center **Passo 2:** Vai alla cartella del codice. .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **Passo 3:** Esegui il codice. .. raw:: html .. code-block:: sudo node touch_switch.js Mentre il codice è in esecuzione, il LED rosso si accende; quando tocchi il modulo interruttore a tocco, il LED giallo si accenderà. **Codice** .. code-block:: js const Gpio = require('pigpio').Gpio; const led1 = new Gpio(22, {mode: Gpio.OUTPUT}); const led2 = new Gpio(27, {mode: Gpio.OUTPUT}); const touchSwitch = new Gpio(17, { mode: Gpio.INPUT, pullUpDown: Gpio.PUD_DOWN, edge: Gpio.EITHER_EDGE }); touchSwitch.on('interrupt', (level) => { led1.digitalWrite(level); led2.digitalWrite(!level); }); Spiegazione del Codice -------------------------- .. code-block:: js const Gpio = require('pigpio').Gpio; const led1 = new Gpio(22, {mode: Gpio.OUTPUT}); const led2 = new Gpio(27, {mode: Gpio.OUTPUT}); const touchSwitch = new Gpio(17, { mode: Gpio.INPUT, pullUpDown: Gpio.PUD_DOWN, edge: Gpio.EITHER_EDGE }); Importa il modulo ``pigpio`` e crea tre oggetti: led1, led2 e touchSwitch. Leggendo il livello della porta IO del touchSwitch, viene controllata l'accensione e lo spegnimento di led1 e led2. .. code-block:: js touchSwitch.on('interrupt', (level) => { led1.digitalWrite(level); led2.digitalWrite(!level); }); Quando il livello della porta IO del touchSwitch cambia, lo stesso livello viene scritto su led1 e il livello opposto su led2. Immagine del fenomeno ---------------------------- .. image:: ../img/2.1.3touch_switch_module.JPG :width: 500 :align: center