Arduino UNO Q - DIP-Schalter
DIP (Dual In-line Package) Schalter sind kompakte Konfigurationsschalter, die zum Festlegen von Adressen, Aktivieren von Funktionen oder Auswählen von Modi verwendet werden. In diesem Tutorial erfahren Sie, wie Sie einen 4-Positionen-DIP-Schalter an Arduino UNO Q anschließen, den EIN/AUS-Status jeder Position lesen, die Positionen in eine Zahl codieren und Werte remote über Telegram überprüfen.

Erforderliche Hardware
Oder Sie können die folgenden Kits kaufen:
| 1 | × | DIYables Sensor-Kit (18 Sensoren/Displays) |
Über DIP-Schalter
Ein DIP-Schalter ist eine Mehrpositions-Schiebeschalter-Einheit. Jede einzelne Position ist ein unabhängiger EIN/AUS-Schalter. Gängige Varianten haben 2, 4, 5, 6, 8 oder 10 Positionen.
Pinbelegung
Ein DIP-Schalter hat zwei Reihen von Pins — eine Reihe pro Seite jeder Position. Jedes Paar von gegenüberliegenden Pins bildet einen Schiebeschalter. Es spielt keine Rolle, welche Seite mit GND verbunden ist.

Funktionsweise
Verbinden Sie eine Seite jeder Position mit GND und die andere Seite mit einem digitalen Pin von Arduino UNO Q, der als INPUT_PULLUP konfiguriert ist. Die folgende Tabelle zeigt die Logik:
| DIP-Schalter Position | Schaltkreis-Status | Arduino UNO Q Pin-Status | Binär-Wert |
|---|---|---|---|
| EIN | GESCHLOSSEN | LOW | 1 |
| AUS | OFFEN | HIGH | 0 |
Dieses Tutorial verwendet einen 4-Positionen-DIP-Schalter an den Pins 2, 3, 4, 5. Der gleiche Ansatz funktioniert für 2, 5, 6, 8 oder 10 Positionen — passen Sie einfach die Anzahl der Pins an.
Schaltschema

Dieses Bild wurde mit Fritzing erstellt. Klicken Sie, um das Bild zu vergrößern.
MCU-Code — DIP-Schalter
Arduino UNO Q hat zwei Prozessoren: den STM32 MCU (verwaltet Echtzeit-Hardwaresteuerung) und den Qualcomm MPU (führt Debian Linux aus). In diesem Abschnitt wird nur der STM32 MCU programmiert — die Linux-Seite bleibt untätig. Ein späterer Abschnitt zeigt, wie beide Prozessoren zusammenarbeiten.
Es werden zwei Code-Beispiele bereitgestellt:
- Lesen jeder Position als EIN/AUS
- Codierung aller Positionen in eine einzelne Ganzzahl
MCU-Code — Lesen jeder DIP-Position als EIN/AUS
Schnelle Schritte
- Erste Verwendung mit Arduino UNO Q? Folgen Sie dem Tutorial Erste Schritte mit Arduino UNO Q, um Ihre Entwicklungsumgebung vorzubereiten, bevor Sie fortfahren.
- Schließen Sie den DIP-Schalter an: Verbinden Sie eine Seite jeder Position mit GND und die andere Seite mit den Pins 2–5 des Arduino UNO Q.
- Verbindung: Schließen Sie Arduino UNO Q mit einem USB-C-Kabel an Ihren Computer an.
- Öffnen Sie Arduino App Lab: Starten Sie Arduino App Lab und warten Sie, bis es Ihren Arduino UNO Q erkennt.
- Erstellen Sie eine neue App: Klicken Sie auf die Schaltfläche Neue App erstellen.

- Geben Sie der App einen Namen, zum Beispiel: DIYables_DIPSwitch
- Klicken Sie auf Erstellen, um zu bestätigen.
- Sie sehen einen Satz von Ordnern und Dateien, die in Ihrer neuen App generiert werden.

- Suchen Sie die Datei sketch/sketch.ino — hier fügen Sie die MCU-Skizze ein.
- Install the library: Click the Add sketch library button (the open book icon with a + sign) in the left sidebar.

- Search for Arduino_RouterBridge created by Arduino and click the Install button.
- Hochladen: Klicken Sie auf die Schaltfläche Ausführen in Arduino App Lab, um zu kompilieren und auf den STM32 hochzuladen.

- Schalten Sie die DIP-Positionen nacheinander um. Der Status wird alle 500 ms gelesen und über Bridge Monitor im nächsten Abschnitt protokolliert.
- Profi-Tipp: Sie können POSITION_NUM und SWITCH_PINS[] erweitern, um 6, 8 oder 10-Positionen-DIP-Schalter zu unterstützen.
MCU-Code — Codierung von DIP-Positionen in eine Zahl
Schnelle Schritte
- Verwenden Sie die gleiche App und Verkabelung aus dem vorherigen Beispiel.
- Ersetzen Sie die Skizze durch den Codierungs-Code oben und klicken Sie auf Ausführen.
- Schalten Sie DIP-Positionen zu verschiedenen Kombinationen um und beobachten Sie die Änderung des codierten Werts im Bridge Monitor.
Linux + MCU Bridge-Programmierung
Arduino UNO Q hat zwei Prozessoren, die zusammenarbeiten: den MPU (Qualcomm, führt Debian Linux aus) und den MCU (STM32, führt Zephyr OS mit Ihrer Arduino-Skizze aus). Sie kommunizieren mit RPC über die Bibliothek Arduino_RouterBridge — nie über rohe serielle Anschlüsse.
- Der DIP-Schalter ist mit dem MCU (STM32) verbunden — verdrahtet mit digitalen Eingabepins auf dem STM32. Der MCU liest jede Position mit digitalRead() mit INPUT_PULLUP.
- Der MPU kann den DIP-Schalter nicht direkt lesen — er muss den Status über Bridge.call() vom MCU anfordern. Der MCU antwortet sofort.
- Der MPU hat Wi-Fi — da der MPU vollständiges Debian Linux mit Wi-Fi ausführt, kann er den DIP-Status bei Bedarf über Telegram melden.
- Kommunikation: Bridge.call() auf der Linux-Seite ruft Bridge.provide() Funktionen auf der MCU-Seite auf
- ⚠️ Reserviert: /dev/ttyHS1 (Linux) und Serial1 (MCU) werden vom Arduino Router verwendet — öffnen Sie sie nie direkt
Kurz gesagt: MPU fordert DIP-Status an → MCU liest Pins → MCU meldet Positionen und codierten Wert → MPU protokolliert oder leitet ihn weiter.
MCU-Skizze — DIP-Schalter mit Bridge und Monitor-Ausgabe:
Python-Skript (Arduino App Lab) — Pollen des DIP-Status von Linux:
- Hinweis: Stellen Sie sicher, dass Bridge.begin() in der MCU-Skizze aufgerufen wird und die Skizze hochgeladen wird, bevor Sie das Python-Skript auf der Linux-Seite ausführen.
- ⚠️ Warnung: Öffnen Sie nie direkt /dev/ttyHS1 (auf Linux) oder verwenden Sie Serial1 (auf MCU) in Ihrem Code — diese sind vom Arduino Router reserviert, und der Zugriff darauf unterbricht die Bridge.
Schnelle Schritte
- MCU-Skizze hochladen: Öffnen Sie Arduino App Lab, erstellen Sie eine neue App, fügen Sie die Bridge MCU-Skizze oben in sketch/sketch.ino ein, installieren Sie die Bibliothek Arduino_RouterBridge, und klicken Sie auf Ausführen.
- Fügen Sie das Python-Skript hinzu: Fügen Sie den Python-Code oben auf der Python-Registerkarte der gleichen App ein.
- Führen Sie die App aus: Klicken Sie auf Ausführen — die Python-Seite pollen den DIP-Schalter alle 2 Sekunden.
- Schalten Sie DIP-Positionen zu verschiedenen Kombinationen um.
- Überprüfen Sie die Konsole: Öffnen Sie die Registerkarte Konsole → MCU Monitor-Unterregisterkarte, um Positionen und codierten Wert in Echtzeit protokolliert zu sehen.
App Lab Konsolenausgabe
Telegram-Integration
Lesen Sie den aktuellen DIP-Schalter-Status remote von überall über Telegram.
Wenn Sie noch keinen Telegram-Bot haben, siehe So erstellen Sie einen Telegram-Bot, um Ihr Bot-Token vor dem Fortfahren zu erhalten.
MCU-Skizze: Behalten Sie die gleiche MCU-Skizze aus dem vorherigen Bridge-Abschnitt — keine Änderungen erforderlich. Stellen Sie sicher, dass sie bereits hochgeladen ist und auf dem STM32 läuft, bevor Sie fortfahren.
Python-Skript (Arduino App Lab) — Telegram-Bot für DIP-Schalter-Status:
- Hinweis: Ersetzen Sie YOUR_BOT_TOKEN durch das Token, das Sie von @BotFather auf Telegram erhalten haben.
- Senden Sie /state, um den EIN/AUS-Status jeder Position zu sehen.
- Senden Sie /value, um den codierten Ganzzahlwert (0–15 für einen 4-Positionen-DIP-Schalter) zu erhalten.
Schnelle Schritte
- MCU-Skizze hochladen: Verwenden Sie die Bridge MCU-Skizze aus dem vorherigen Abschnitt (laden Sie sie zuerst hoch, falls nicht bereits geschehen).
- Fügen Sie das Telegram-Skript ein: Kopieren Sie den Python-Code oben auf der Python-Registerkarte Ihrer App in Arduino App Lab ein.
- Legen Sie Ihr Token fest: Ersetzen Sie YOUR_BOT_TOKEN im Skript durch Ihr tatsächliches Bot-Token.
- Führen Sie die App aus: Klicken Sie auf Ausführen — der Bot beginnt, auf Telegram-Nachrichten zu lauschen.
- Testen Sie es: Schalten Sie einige DIP-Positionen um, senden Sie /value — bestätigen Sie, dass die Ganzzahl Ihrem Schalter-Muster entspricht.
App Lab Konsolenausgabe
ArduinoBot
OpenClaw-Integration
Sie können OpenClaw an dieses Tutorial anpassen, indem Sie die Anleitung zum Tutorial Arduino Uno Q - OpenClaw lesen.
Anwendungs- / Projektideen
- Adressauswahl: Verwenden Sie einen DIP-Schalter, um einer eindeutigen Geräteadresse in einem Mehrgeräte-Netzwerk zuzuweisen
- Fernmodus-Überprüfung: Senden Sie /value über Telegram, um zu überprüfen, welcher Betriebsmodus konfiguriert ist
- Feature-Flaggen: Weisen Sie jede DIP-Position einem Feature-Toggle zu (Debug-Modus, Protokollierung usw.)
- Sicherheits-Code-Eintrag: Verwenden Sie eine 4-Positionen-DIP-Schalter-Kombination als einfachen Zugriffscode
- Konfigurationsberichterstattung: Senden Sie den aktuellen DIP-Status automatisch über Telegram beim Hochfahren
Fordern Sie sich selbst heraus
- Einfach: Fügen Sie Code hinzu, um Positionsetiketten (z. B. "Debug: EIN", "Verbose: AUS") auf der Grundlage der Bedeutung jeder DIP-Position zu drucken
- Mittel: Erweitern Sie die Bridge-Skizze, um alle 4 Positionen einzeln als separate get_position_N() Rückrufe verfügbar zu machen
- Fortgeschritten: Erstellen Sie einen Telegram-Bot, der eine Benachrichtigung sendet, wann immer sich der codierte DIP-Wert ändert — verfolgen Sie den vorherigen Wert und vergleichen Sie auf jede Abfrage