Inhaltsverzeichnis:
2025 Autor: John Day | [email protected]. Zuletzt bearbeitet: 2025-01-13 06:56
Der ADXL345 ist ein kleiner, dünner 3-Achsen-Beschleunigungsmesser mit extrem geringem Stromverbrauch und hoher Auflösung (13 Bit) bei bis zu ±16 g. Digitale Ausgangsdaten werden als 16-Bit-Zweierkomplement formatiert und sind über die digitale I2 C-Schnittstelle zugänglich. Es misst die statische Gravitationsbeschleunigung bei Neigungserkennungsanwendungen sowie die dynamische Beschleunigung aufgrund von Bewegungen oder Stößen. Seine hohe Auflösung (3,9 mg/LSB) ermöglicht die Messung von Neigungsänderungen unter 1,0°.
In diesem Tutorial wurde die Anbindung des ADXL345 Sensormoduls an Partikelphotonen veranschaulicht. Zum Auslesen der Beschleunigungswerte haben wir Partikel mit einem I2C-Adapter verwendet. Dieser I2C-Adapter macht die Verbindung zum Sensormodul einfach und zuverlässiger.
Schritt 1: Erforderliche Hardware:
Zu den Materialien, die wir zur Erreichung unseres Ziels benötigen, gehören die folgenden Hardwarekomponenten:
1. ADXL345
2. Teilchenphoton
3. I2C-Kabel
4. I2C-Schild für Teilchenphotonen
Schritt 2: Hardwareanschluss:
Der Abschnitt Hardware-Anschlüsse erklärt im Wesentlichen die erforderlichen Kabelverbindungen zwischen dem Sensor und dem Partikelphoton. Die Sicherstellung korrekter Verbindungen ist die Grundvoraussetzung bei der Arbeit an jedem System für die gewünschte Ausgabe. Die erforderlichen Verbindungen sind also wie folgt:
Der ADXL345 funktioniert über I2C. Hier ist das Beispiel-Verdrahtungsdiagramm, das zeigt, wie jede Schnittstelle des Sensors verdrahtet wird.
Out-of-the-box ist das Board für eine I2C-Schnittstelle konfiguriert, daher empfehlen wir, diesen Anschluss zu verwenden, wenn Sie ansonsten agnostisch sind.
Alles was Sie brauchen sind vier Drähte! Es werden nur vier Anschlüsse benötigt Vcc, Gnd, SCL und SDA Pins und diese werden mit Hilfe von I2C Kabel verbunden.
Diese Verbindungen sind in den obigen Bildern dargestellt.
Schritt 3: Code zur Messung der Beschleunigung:
Beginnen wir jetzt mit dem Partikelcode.
Bei der Verwendung des Sensormoduls mit dem Partikel binden wir die Bibliothek application.h und spark_wiring_i2c.h ein. Die Bibliothek "application.h" und spark_wiring_i2c.h enthält die Funktionen, die die i2c-Kommunikation zwischen Sensor und Partikel ermöglichen.
Der gesamte Partikelcode ist unten für die Benutzerfreundlichkeit angegeben:
#enthalten
#enthalten
// ADXL345 I2C-Adresse ist 0x53(83)
#define Addr 0x53
int xAccl = 0, yAccl = 0, zAccl = 0;
Void-Setup ()
{
// Variable setzen
Partikel.variable("i2cdevice", "ADXL345");
Partikel.variable("xAccl", xAccl);
Partikel.variable("yAccl", yAccl);
Partikel.variable("zAccl", zAccl);
// I2C-Kommunikation als MASTER initialisieren
Wire.begin();
// Serielle Kommunikation initialisieren, Baudrate = 9600. einstellen
Serial.begin (9600);
// I2C-Übertragung starten
Wire.beginTransmission(Addr);
// Bandbreitenratenregister auswählen
Wire.write (0x2C);
// Ausgangsdatenrate wählen = 100 Hz
Wire.write (0x0A);
// I2C-Übertragung stoppen
Wire.endTransmission();
// I2C-Übertragung starten
Wire.beginTransmission(Addr);
// Leistungssteuerregister auswählen
Wire.write (0x2D);
// Auto-Sleep-Deaktivierung auswählen
Wire.write (0x08);
// I2C-Übertragung stoppen
Wire.endTransmission();
// I2C-Übertragung starten
Wire.beginTransmission(Addr);
// Datenformatregister auswählen
Wire.write (0x31);
// Volle Auflösung wählen, +/-2g
Wire.write (0x08);
// I2C-Übertragung beenden
Wire.endTransmission();
Verzögerung (300);
}
Leere Schleife ()
{
unsignierte int-Daten[6];
for(int i = 0; i < 6; i++)
{
// I2C-Übertragung starten
Wire.beginTransmission(Addr);
// Datenregister auswählen
Wire.write((50+i));
// I2C-Übertragung stoppen
Wire.endTransmission();
// 1 Byte Daten vom Gerät anfordern
Wire.requestFrom(Addr, 1);
// 6 Byte Daten lesen
// xAccl lsb, xAccl msb, yAccl lsb, yAccl msb, zAccl lsb, zAccl msb
if(Draht.verfügbar()==1)
{
data = Wire.read();
}
Verzögerung (300);
}
// Konvertieren Sie die Daten in 10-Bits
int xAccl = (((Daten[1] & 0x03) * 256) + Daten[0]);
if(xAccl > 511)
{
xAccl –= 1024;
}
int yAccl = (((Daten[3] & 0x03) * 256) + Daten[2]);
if(yAccl > 511)
{
yAccl –= 1024;
}
int zAccl = (((Daten[5] & 0x03) * 256) + Daten[4]);
if(zAccl > 511)
{
zAccl –= 1024;
}
// Daten an Dashboard ausgeben
Particle.publish("Beschleunigung in X-Achse ist:", String(xAccl));
Particle.publish("Beschleunigung in Y-Achse ist:", String(yAccl));
Particle.publish("Beschleunigung in der Z-Achse ist:", String(zAccl));
}
Die Funktion Particle.variable() erstellt die Variablen zum Speichern der Ausgabe des Sensors und die Funktion Particle.publish() zeigt die Ausgabe auf dem Dashboard der Site an.
Der Sensorausgang ist im obigen Bild zu Ihrer Referenz dargestellt.
Schritt 4: Anwendungen:
ADXL345 ist ein kleiner, dünner 3-Achsen-Beschleunigungsmesser mit extrem geringem Stromverbrauch, der in Handsets, medizinischen Instrumenten usw. eingesetzt werden kann. Seine Anwendung umfasst auch Spiel- und Zeigegeräte, industrielle Instrumente, persönliche Navigationsgeräte und Festplattenschutz (HDD).