.. note:: Hallo und willkommen in der SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasten-Gemeinschaft auf Facebook! Tauchen Sie tiefer ein in die Welt von Raspberry Pi, Arduino und ESP32 mit anderen Enthusiasten. **Warum beitreten?** - **Expertenunterstützung**: Lösen Sie Nachverkaufsprobleme und technische Herausforderungen mit Hilfe unserer Gemeinschaft und unseres Teams. - **Lernen & Teilen**: Tauschen Sie Tipps und Anleitungen aus, um Ihre Fähigkeiten zu verbessern. - **Exklusive Vorschauen**: Erhalten Sie frühzeitigen Zugang zu neuen Produktankündigungen und exklusiven Einblicken. - **Spezialrabatte**: Genießen Sie exklusive Rabatte auf unsere neuesten Produkte. - **Festliche Aktionen und Gewinnspiele**: Nehmen Sie an Gewinnspielen und Feiertagsaktionen teil. 👉 Sind Sie bereit, mit uns zu erkunden und zu erschaffen? Klicken Sie auf [|link_sf_facebook|] und treten Sie heute bei! .. _2.1.3_js: 2.1.3 Berührungsschalter-Modul ================================= Einführung ------------------- In diesem Projekt lernen Sie das Berührungsschalter-Modul kennen. Es kann herkömmliche Schaltertypen ersetzen und bietet folgende Vorteile: einfache Bedienung, feines Tastgefühl, präzise Steuerung und minimaler mechanischer Verschleiß. Benötigte Komponenten ------------------------------ Für dieses Projekt benötigen wir die folgenden Komponenten. .. image:: ../img/2.1.3component.png :width: 700 :align: center Es ist definitiv praktisch, ein ganzes Set zu kaufen, hier ist der Link: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Name - ARTIKEL IN DIESEM KIT - LINK * - Raphael Kit - 337 - |link_Raphael_kit| Sie können sie auch einzeln über die untenstehenden Links kaufen. .. list-table:: :widths: 30 20 :header-rows: 1 * - KOMPONENTEN-ÜBERSICHT - KAUF-LINK * - :ref:`cpn_gpio_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| Schaltplan ----------------- .. image:: ../img/2.1.3circuit.png :width: 500 :align: center Experimentelle Verfahren ------------------------------ **Schritt 1:** Bauen Sie den Schaltkreis. .. image:: ../img/2.1.3fritzing.png :width: 700 :align: center **Schritt 2:** Navigieren Sie zum Code-Verzeichnis. .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **Schritt 3:** Starten Sie den Code. .. raw:: html .. code-block:: sudo node touch_switch.js Während der Code läuft, leuchtet die rote LED auf; wenn Sie das Berührungsschalter-Modul antippen, leuchtet die gelbe LED auf. **Code** .. 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); }); **Code-Erklärung** .. 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 }); Das Modul ``pigpio`` wird importiert und drei Objekte led1, led2, touchSwitch werden erstellt. Durch das Ablesen des IO-Ports von touchSwitch werden das Ein- und Ausschalten von led1 und led2 gesteuert. .. code-block:: js touchSwitch.on('interrupt', (level) => { led1.digitalWrite(level); led2.digitalWrite(!level); }); Wenn sich die Stufe des gelesenen touchSwitch IO-Ports ändert, Wird die gleiche Stufe an led1 und die entgegengesetzte Stufe an led2 geschrieben. Phänomen-Bild ------------------------ .. image:: ../img/2.1.3touch_switch_module.JPG :width: 500 :align: center